开发笔记

通过IDEA实例了解Servlet生命周期

2018-08-05  本文已影响0人  顾烟凉

1.生命周期

2. 实例分析

2.1 新建LoginServlet并编译

新建一个web项目并新建LoginServlet类

package main.com.guyanliang;

import java.io.IOException;

import javax.servlet.ServletConfig;
import javax.servlet.ServletException;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;

public class LoginServlet extends HttpServlet {
    public LoginServlet(){
        System.out.println("LoginServlet 构造方法 被调用");
    }

    @Override
    public void destroy() {
        System.out.println("销毁");
    }

    @Override
    public void init(ServletConfig config) throws ServletException {
        System.out.println("init");
    }

    protected void service(HttpServletRequest request, HttpServletResponse response)
            throws ServletException, IOException {

        System.out.println("doGet");

    }
}
如图所示编译 image.png

2.2 配置web.xml

<?xml version="1.0" encoding="UTF-8"?>
<web-app xmlns="http://xmlns.jcp.org/xml/ns/javaee"
         xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
         xsi:schemaLocation="http://xmlns.jcp.org/xml/ns/javaee http://xmlns.jcp.org/xml/ns/javaee/web-app_4_0.xsd"
         version="4.0">

            <servlet>
                <servlet-name>LS</servlet-name>
                <servlet-class>main.com.guyanliang.LoginServlet</servlet-class>
            </servlet>
            <servlet-mapping>
                <servlet-name>LS</servlet-name>
                <url-pattern>/main.com.guyanliang.ls</url-pattern>
            </servlet-mapping>

</web-app>

2.3 部署调试

把tomcat部署下,在浏览器地址输入http://localhost:8080/main.com.guyanliang.ls,在IDEA的控制台上可以看到:

image.png
再次运行tomcat可以看到:
image.png
请求过程如下:

当用户通过浏览器输入一个路径,这个路径对应的servlet被调用的时候,该Servlet就会被实例化
所以我们最先看到的是“doGet”,该实例为LoginServlet显式提供一个构造方法 LoginServlet(),所以此时输出"LoginServlet 构造方法 被调用";
LoginServlet 继承了HttpServlet,同时也继承了init(ServletConfig) 方法;
init 方法是一个实例方法,所以会在构造方法执行后执行,此时输出“init”;
无论访问了多少次LoginSerlvet,init初始化 只会执行一次;
无论访问了多少次LoginServlet,LoginSerlvet构造方法 只会执行一次,所以在第二次的tomcat启动之后控制台只输出了“doGet”,所以Serlvet是单实例的;

销毁过程:
在如下几种情况下,会调用destroy()

  1. 该Servlet所在的web应用重新启动
    在serverl.xml中配置该web应用的时候用到了
    <Context path="/" docBase="e:\project\j2ee\web" debug="0" reloadable="false" />
    如果把 reloadable="false" 改为reloadable="true" 就表示有任何类发生的更新,web应用会自动重启
    当web应用自动重启的时候,destroy()方法就会被调用
  2. 关闭tomcat的时候 destroy()方法会被调用,但是这个一般都发生的很快,不易被发现。
上一篇 下一篇

猜你喜欢

热点阅读