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");
}
}
如图所示编译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的控制台上可以看到:
再次运行tomcat可以看到:
请求过程如下:
当用户通过浏览器输入一个路径,这个路径对应的servlet被调用的时候,该Servlet就会被实例化
所以我们最先看到的是“doGet”,该实例为LoginServlet显式提供一个构造方法 LoginServlet(),所以此时输出"LoginServlet 构造方法 被调用";
LoginServlet 继承了HttpServlet,同时也继承了init(ServletConfig) 方法;
init 方法是一个实例方法,所以会在构造方法执行后执行,此时输出“init”;
无论访问了多少次LoginSerlvet,init初始化 只会执行一次;
无论访问了多少次LoginServlet,LoginSerlvet构造方法 只会执行一次,所以在第二次的tomcat启动之后控制台只输出了“doGet”,所以Serlvet是单实例的;
销毁过程:
在如下几种情况下,会调用destroy()
- 该Servlet所在的web应用重新启动
在serverl.xml中配置该web应用的时候用到了
<Context path="/" docBase="e:\project\j2ee\web" debug="0" reloadable="false" />
如果把 reloadable="false" 改为reloadable="true" 就表示有任何类发生的更新,web应用会自动重启
当web应用自动重启的时候,destroy()方法就会被调用 - 关闭tomcat的时候 destroy()方法会被调用,但是这个一般都发生的很快,不易被发现。