正在调用 Servlet 的服务和 init 方法,但没有调用 doGet

Cod*_*ein 1 java eclipse servlets

我有一个简单的 Servlet,如下所示:

import java.io.IOException;
import java.io.PrintWriter;

import javax.servlet.ServletException;
import javax.servlet.ServletRequest;
import javax.servlet.ServletResponse;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;

public class Bla extends HttpServlet {

    private static final long serialVersionUID = 16252534;

    @Override
    public void init() throws ServletException {
        System.out.println("init");
    }
    @Override
    public void doGet(HttpServletRequest req, HttpServletResponse resp)
            throws ServletException, IOException {
        System.out.println("doGet");
        resp.setContentType("text/html");
        PrintWriter out = resp.getWriter();
        out.println("<html><h1>It works!!</h1></html>");
    }

    @Override
    public void service(ServletRequest req, ServletResponse resp) throws ServletException, IOException {
        System.out.println("service");

    }

    @Override
    public void doPost(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
        System.out.println("doPost");
    }

    @Override
    public void destroy() {
        System.out.println("Destroy servlet");
    }
}   
Run Code Online (Sandbox Code Playgroud)

和一个看起来像这样的web.xml

<?xml version="1.0" encoding="UTF-8" ?>

<web-app>
    <display-name>Archetype Created Web Application</display-name>

    <welcome-file-list>
        <welcome-file>index.jsp</welcome-file>
    </welcome-file-list>

    <servlet>
        <servlet-name>Bla</servlet-name>
        <servlet-class>instrurental_proj.servlets.Bla</servlet-class>
    </servlet>
    <servlet-mapping>
        <servlet-name>Bla</servlet-name>
        <url-pattern>/bla</url-pattern>
    </servlet-mapping>  
</web-app>
Run Code Online (Sandbox Code Playgroud)

当我访问 url 时http://localhost:8080/instrurental/bla,控制台会打印出以下内容:

init
service
Run Code Online (Sandbox Code Playgroud)

但不像doGet我期望的那样。此外,浏览器中没有打印任何内容!(我期待它说“它有效”)。

从昨天开始,我一直在为这个问题苦苦挣扎。有没有人有任何建议,可能是什么问题?

Nir*_*iru 5

你为什么要覆盖服务方法。没有必要。删除它或调用

super.service(request,response);
Run Code Online (Sandbox Code Playgroud)

原因
尝试查看 HttpServlet 类的来源。在那里您将看到,根据用于调用 servlet 的方法,即 GET/POST,必要的方法 doGet() 或 doPost() 被调用。当容器实际收到请求时,它会启动一个新线程并通过调用 service() 方法为客户端提供服务。因此,如果您覆盖它并且不调用超类的服务方法或定义您自己的策略如何调用 GET,则永远不会调用 doGet() 方法。您的请求从不调用 doGet() 方法,它是调用它的 service() 方法。