作者:零乱772_553 | 来源:互联网 | 2023-10-16 18:02
这里是修真院前端小课堂,本篇分析的主题是【什么是jsp?jsp的内置对象有哪些?】每篇分享文从【背景介绍】【知识剖析】【常见问题】【解决方案】【编码实战】【扩展思考】【更多讨论
这里是修真院尖端小教室,本篇分析的主题是
【什么是jsp? jsp的内置对象是什么? 】
所有的共享语句都是
【背景介绍】【知识分析】【常见问题】【解决方案】【编码实战】【思维拓展】【更多讨论】【参考文献】
从8个方面深入解析前端知识/技能,本篇分享的是:
【什么是jsp? jsp的内置对象是什么? 】
1、背景介绍百度百科这样介绍JSP :“JSP是动态网页技术标准。 其根本原因是为了简化servlet的设计,是由Sun Microsystems公司提出并由多家企业参与设立的动态web技术标准。 ”
通过以上介绍,可以看到servlet先出,jsp后出。
所以,如果你想知道jsp,请先学习servlet。
在地址栏中键入test3访问servlet时,浏览器将返回与以下内容类似的结果:
在网页源代码上单击鼠标右键,可以看到它是一个非常常见的HTML代码。
也就是说,servlet将各种HTML代码连接在一起,最终将HTML页返回给客户端。
我们要做的动态网站,如果所有的HTML页面都是这样形成的,会不会太繁琐了?
于是,jsp诞生了。
jsp怎么样呢?
访问浏览器的结果:
如您所见,jsp页面的
%for(intI=0; i4; I )等中嵌入的类似java代码的东西消失了。 出现了四次helloworld这个词。 因此,jsp推测是不是要在HTML页面中嵌入java代码,以某种方式执行这些java代码,最终返回到想要生成的HTML页面。
在系统所在的路径下,可以找到由tomcat解析为java类的jsp页。 然后一个是. class文件,另一个是java文件。
这不是我们熟悉的java类及其编译到. class字节码文件中吗?
打开test_jsp文件可以看到重要的部分。
publicvoid_JSP服务(final javax.servlet.http.httpservletrequestrequest,final javax.servlet.http.http servlet respop javax.servlet.servlet exception javax.servlet.http.http会话会话=null; final javax.servlet.servlet上下文APP; final javax.servlet.servletconfig config; jvax.servlet.JSP.jspwriter out=null; final java.lang.Object page=this; jvax.servlet.JSP.jspwriter _ jspx _ out=null; avax.servlet.JSP.pagecontext _ jspx _ page _ cOntext=null; try { response.set content type (' text/html; charset=UTF-8 '; pagecOntext=_ jspx factory.get pagecontext (this,request,response,null,true,8192,true ); _jspx_page_cOntext=pageContext; application=pagecontext.getservletcontext (; cOnfig=pagecontext.get servletconfig (; session=pageContext.getSession (; out=pageContext.getOut (; _jspx_out=out; out.write('\r\n ' ); out.write('\r\n ' ); out.write(html\r\n ); out.write(head\r\n ); out.write(title测试/title\r\n ); out.write ()/head\r\n ); out.write(body\r\n ); out.write('\r\n ' );
out.write(" "); for(int i=0; i<4;i++) { out.write("\r\n"); out.write(" helloWorld!
\r\n"); out.write("\r\n"); out.write(" "); } out.write("\r\n"); out.write("\r\n"); out.write("\r\n"); out.write("\r\n"); } catch (java.lang.Throwable t) { if (!(t instanceof javax.servlet.jsp.SkipPageException)){ out = _jspx_out; if (out != null && out.getBufferSize() != 0) try { if (response.isCommitted()) { out.flush(); } else { out.clearBuffer(); } } catch (java.io.IOException e) {} if (_jspx_page_context != null) _jspx_page_context.handlePageException(t); else throw new ServletException(t); } } finally { _jspxFactory.releasePageContext(_jspx_page_context); } }
2、知识剖析:
来看一下jsp的执行流程:
注意,只有jsp是新创建或是修改后第一次访问时,jsp parser才会将其编译成servlet程序。之后调用JSDK将对应的servlet程序编译成servlet字节码。
而且,它并非是将页面本身发送给客户端,而是把页面执行的结果发送给客户端。
客户端收到这个文件后,就可以正常显示在客户端了。
比如我要要访问test.jsp,然后利用Tomcat的解析器,他会将jsp文件转化为java文件,这个java文件就是servlet,
所以jsp本质上就是servlet。
jsp能实现的,servlet也能实现。不管你最终写的是一个多么复杂的jsp文件,它最后总能转化为一个html文件。
jsp的9个内置对象和4个作用域:
request 请求对象 类型 javax.servlet.ServletRequest 作用域 Requestresponse 响应对象 类型 javax.servlet.SrvletResponse 作用域 PagepageContext 页面上下文对象 类型 javax.servlet.jsp.PageContext 作用域 Pagesession 会话对象 类型 javax.servlet.http.HttpSession 作用域 Sessionapplication 应用程序对象 类型 javax.servlet.ServletContext 作用域 Applicationout 输出对象 类型 javax.servlet.jsp.JspWriter 作用域 Pageconfig 配置对象 类型 javax.servlet.ServletConfig 作用域 Pagepage 页面对象 类型 javax.lang.Object 作用域 Pageexception 例外对象 类型 javax.lang.Throwable 作用域 page
同样 来看一个例子:
这里有两个jsp页面,page01和page02。
jsp useBean 标签表示 创建一个由class属性指定的类的实例,然后把它绑定到其名字由id属性给出的变量上。
那这里我创建了4个字符串缓冲类的实例,他们的作用域分别是page, request, session,application。
<%@ page language="java" cOntentType="text/html; charset=UTF-8" pageEncoding="UTF-8"%>
<% pageVar.append("page01"); requestVar.append("page01"); sessionVar.append("page01"); applicationVar.append("page01");%>
<%@ page language="java" import="java.util.*" cOntentType="text/html; charset=UTF-8" pageEncoding="UTF-8"%>
这里是page02,是从page1转来的
name<% pageVar.append("page02"); requestVar.append("page02"); sessionVar.append("page02"); applicationVar.append("page02");%>
page
= <%=pageVar.toString()%>
request
= <%=requestVar.toString()%>
session
= <%=sessionVar.toString()%>
application
= <%=applicationVar.toString()%>
jsp forward 标签表示 当走到这里的时候,页面会跳转到page02.jsp。 这刚好就是一个会话的场景,
现在我们刷新一下页面,可以看到,page作用域变量的输出的值为page02,原本它的page01已经不见了。
request作用域的变量只在当前请求的中有效,当前的请求就是从page01到page02的一次跳转。
所以它的值把page01和page02都显示出来了。
session作用域的变量为当前会话,也就是只要浏览器不关闭,page02能一直叠加到上去。
application 对所有应用有效,也就是只要这个应用启动着,都要叠加。