JSP学习8-JSP 生命周期
JSP 生命周期
认证:var code = “405f4086-0c70-4e23-9eeb-66d4f1f52cc3”
JSP生命周期就是从创建到销毁的整个过程,类似于servlet生命周期,区别在于JSP生命周期还包括将JSP文件编译成servlet。
以下是JSP生命周期中所走过的几个阶段:
-
编译阶段:
servlet容器编译servlet源文件,生成servlet类。具体过程是:
- 解析JSP文件。
- 将JSP文件转为servlet。
- 编译servlet。
-
初始化阶段:
加载与JSP对应的servlet类,创建其实例,并调用它的初始化方法
-
执行阶段:
调用与JSP对应的servlet实例的服务方法
-
销毁阶段:
调用与JSP对应的servlet实例的销毁方法,然后销毁servlet实例

概括的来说JSP完成了初始化(init)→服务(destory)→销毁(destory) 的流程。实际仍然是通过Servlet来完成的,有一个编译阶段转换为servlet的过程。
<%@ page language="java" contentType="text/html; charset=UTF-8"
pageEncoding="UTF-8"%>
<html>
<head>
<title>life.jsp</title>
</head>
<body>
<%!
private int initVar=0;
private int serviceVar=0;
private int destroyVar=0;
%>
<%!
public void jspInit(){
initVar++;
System.out.println("jspInit(): JSP被初始化了"+initVar+"次");
}
public void jspDestroy(){
destroyVar++;
System.out.println("jspDestroy(): JSP被销毁了"+destroyVar+"次");
}
%>
<%
out.println("JSP进行服务");
serviceVar++;
System.out.println("_jspService(): JSP共响应了"+serviceVar+"次请求");
String content1="初始化次数 : "+initVar;
String content2="响应客户请求次数 : "+serviceVar;
String content3="销毁次数 : "+destroyVar;
%>
<h1>菜鸟教程 JSP 测试实例</h1>
<p><%=content1 %></p>
<p><%=content2 %></p>
<p><%=content3 %></p>
</body>
</html>
输出如下
jspInit(): JSP被初始化了1次
_jspService(): JSP共响应了1次请求
_jspService(): JSP共响应了2次请求
jspInit(): JSP被初始化了1次
_jspService(): JSP共响应了1次请求
11月 01, 2024 9:13:56 上午 org.apache.catalina.core.StandardServer await
信息: 通过关闭端口接收到有效的关闭命令。正在停止服务器实例。
11月 01, 2024 9:13:56 上午 org.apache.coyote.AbstractProtocol pause
信息: 暂停ProtocolHandler["http-nio-8080"]
11月 01, 2024 9:13:56 上午 org.apache.catalina.core.StandardService stopInternal
信息: 正在停止服务[Catalina]
jspDestroy(): JSP被销毁了1次
11月 01, 2024 9:13:56 上午
org.apache.coyote.AbstractProtocol stop
信息: 正在停止ProtocolHandler ["http-nio-8080"]
11月 01, 2024 9:13:56 上午 org.apache.coyote.AbstractProtocol destroy
信息: 正在摧毁协议处理器 ["http-nio-8080"]

tProtocol destroy
信息: 正在摧毁协议处理器 [“http-nio-8080”]
[外链图片转存中...(img-rxKsqwcv-1731553593828)]

浙公网安备 33010602011771号