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实例

img

概括的来说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"]

image-20241101091458894

tProtocol destroy
信息: 正在摧毁协议处理器 [“http-nio-8080”]


[外链图片转存中...(img-rxKsqwcv-1731553593828)]

posted @ 2024-11-18 08:00  Ackley  阅读(58)  评论(0)    收藏  举报  来源