这个HttpServlet的service()方法究竟是什么?

时间:2014-11-25 09:12:01

标签: java jsp java-ee servlets

这是我第一次使用 HttpServlet 的Java项目。

所以我知道 HttpServlet 是一个在Web应用程序服务器上运行的程序,它充当来自Web浏览器或其他HTTP客户端的请求与数据库或应用程序之间的中间层。 HTTP服务器。因此servlet扩展了我的应用程序服务器的能力。

我有一些疑问是要了解这个servlet在我的项目中的确切工作,进入 web.xml 文件我发现了这个配置:

<?xml version="1.0" encoding="ISO-8859-1"?>
<!DOCTYPE web-app PUBLIC
        "-//Sun Microsystems, Inc.//DTD Web Application 2.3//EN"
        "http://java.sun.com/dtd/web-app_2_3.dtd">    
<web-app>

    <display-name>My Project</display-name>

    <listener>
        <listener-class>it.sistinf.ediweb.quartz.QuartzListener</listener-class>
    </listener>

    <servlet>
        <servlet-name>edimon</servlet-name>    
        <servlet-class>it.sistinf.ediweb.monitor.servlets.Monitoraggio</servlet-class>   
        <load-on-startup>0</load-on-startup>
    </servlet>

    <servlet-mapping>
        <servlet-name>edimon</servlet-name>    
        <url-pattern>/edimon.do/*</url-pattern>
    </servlet-mapping>

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

    <taglib>
        <taglib-uri>displaytag</taglib-uri>
        <taglib-location>/WEB-INF/displaytag-11.tld</taglib-location>
    </taglib>

</web-app>

因此,阅读一些文档似乎理解我必须告诉servlet容器(或应用程序服务器)要部署哪些servlet,以及将servlet映射到的URL。

在上一个案例中,我正在配置由 Monitoraggio 类实现的名为 edimon 的servlet。

然后将servlet映射到URL或URL模式。在这种情况下, edimon servlet将使用 /edimon.do / * 网址格式进行映射。因此,当它被称为与先前模式匹配的东西时,执行edimon servlet。

然后进入实现 HttpServlet Monitoraggio 类,我找到了 service()方法:

public void service(HttpServletRequest req, HttpServletResponse res) throws ServletException, IOException {
        LoggerMDC.setup(req, res);
        Logger logger = (Logger) Logger.getStdLogger(Monitoraggio.class); // do not declare 'logger' as static field in order to work with MDC

        String service = req.getParameter("serv");

        char serviceId = Utility.getServizio(req.getParameter("serv"));

        if (checkSession(req, serviceId) == false) {
            gotoPage(ConfigurationFactory.getPropertiesPages().getProperty("pagina_errore_session"), req, res);
            return;
        }

        LoggerWatch loggerWatch = new LoggerWatch(Monitoraggio.class, Long.valueOf(System.getProperty(Constants.Keys.CONFIG_STATS_WARNING_THRESHOLD, String.valueOf(LoggerWatch.DEFAULT_WARNING_THRESHOLD))).longValue());
        if (logger.isTraceEnabled())
            logger.trace("lanciaServizio() | logger threshold: " + loggerWatch.getWarningThreshold());

        loggerWatch.start();
        loggerWatch.info(new StringBuffer("service() | servizio: [").append(service).append("] | service start").toString());

        String paginaDaLanciare = lanciaServizio(serviceId, req, res);
        String executionTime = loggerWatch.getInfoTime();

        //Modifica per export
        if (req.getSession().getAttribute("export") == null) {
            gotoPage(paginaDaLanciare, req, res);
        }

        loggerWatch.info(new StringBuffer("service() | servizio: [").append(service).append("] | [").append(executionTime).append("] after forward to ").append(paginaDaLanciare).toString(), true);
        loggerWatch.stop();

        req.getSession().removeAttribute("export");
        req.getSession().removeAttribute("stringaXML");
        req.getSession().removeAttribute("downbyte");

        return;
    }

阅读文档从公共服务方法接收标准HTTP请求,并将它们分派给此类中定义的doXXX方法

那么这种方法有什么好处呢?我无法理解servlet如何加载JSP

1 个答案:

答案 0 :(得分:1)

您阅读的文档描述了默认情况下HttpServlet的service()方法。由于您的servlet会覆盖service()方法并提供不同的实现,因此它不再执行此操作。相反,它确实......方法中的代码做了什么。

servlet没有加载JSP&#34;。我不知道JSP如何与您发布的servlet代码有任何关系。也许gotoPage()告诉容器将请求转发给JSP。您应该查看该方法的文档和/或代码,以了解它的作用。