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

1.生命周期

通过IDEA实例了解Servlet生命周期_第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");

    }
}

如图所示编译
通过IDEA实例了解Servlet生命周期_第2张图片
image.png

2.2 配置web.xml




            
                LS
                main.com.guyanliang.LoginServlet
            
            
                LS
                /main.com.guyanliang.ls
            


2.3 部署调试

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

通过IDEA实例了解Servlet生命周期_第3张图片
image.png

再次运行tomcat可以看到:
通过IDEA实例了解Servlet生命周期_第4张图片
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应用的时候用到了

    如果把 reloadable="false" 改为reloadable="true" 就表示有任何类发生的更新,web应用会自动重启
    当web应用自动重启的时候,destroy()方法就会被调用
  2. 关闭tomcat的时候 destroy()方法会被调用,但是这个一般都发生的很快,不易被发现。

你可能感兴趣的:(通过IDEA实例了解Servlet生命周期)