jsp的本质是一个servlet程序
当我们第一次访问jsp页面的时候,Tomcat服务器会帮我们把jsp页面翻译成为一个java源文件,并且对它进行编译成为.class字节码程序,
跟踪原代码发现, HttpjspBase 类。 z直接继承了HttpServlet类,也即是说,jsp 翻译出来的 java 类, 它间接了继承了 HttpServlet 类。 也就是说, 翻译出来的是一个 Servlet 程序
总结: 通过翻译的 java 源代码我们就可以得到结果: jsp 就是 Servlet 程序
去观察翻译出来的 Servlet 程序的源代码, 不难发现。 其底层实现, 也是通过输出流。 把 html 页面数据回传给客户端
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-MmlXWcKA-1613905972909)(tu/04-1.png)]
jsp 的 page 指令可以修改 jsp 页面中一些重要的属性, 或者行为。
i. language 属性 表示 jsp 翻译后是什么语言文件。暂时只支持 java。
ii. contentType 属性 表示 jsp 返回的数据类型是什么。也是源码中 response.setContentType()参数值
iii. pageEncoding 属性 表示当前 jsp 页面文件本身的字符集。
iv. import 属性 跟java 源代码中一样。用于导包,导类。
====两个属性是给 out 输出流使用
v. autoFlush 属性 设置当 out 输出流缓冲区满了之后,是否自动刷新冲级区。默认值是 true。
vi. buffer 属性 设置out 缓冲区的大小。默认是 8kb out缓冲区满了之后不能自动刷新,就会报错
vii. errorPage 属性 设置当 jsp 页面运行时出错,自动跳转去的错误页面路径。
viii. isErrorPage 属性 设置当前 jsp 页面是否是错误信息页面。默认是 false。如果是 true 可以
获取异常信息。
ix. session 属性 设置访问当前 jsp 页面,是否会创建HttpSession 对象。默认是 true。
x. extends 属性 设置jsp 翻译出来的java 类默认继承谁。
viii. isErrorPage 属性 设置当前 jsp 页面是否是错误信息页面。默认是 false。如果是 true 可以
获取异常信息。
ix. session 属性 设置访问当前 jsp 页面,是否会创建HttpSession 对象。默认是 true。
x. extends 属性 设置jsp 翻译出来的java 类默认继承谁。
表达式脚本的格式是: <%=表达式%>
表达式脚本的作用是: 的 jsp 页面上输出数据。
表达式脚本的特点:
1、 所有的表达式脚本都会被翻译到_jspService() 方法中
2、 表达式脚本都会被翻译成为 out.print()输出到页面上
3、 由于表达式脚本翻译的内容都在_jspService() 方法中,所以_jspService()方法中的对象都可以直接使用。
4、 表达式脚本中的表达式不能以分号结束。
代码脚本的格式是:
<%
java 语句
%>
代码脚本的作用是: 可以在 jsp 页面中, 编写我们自己需要的功能(写的是 java 语句) 。
脚本代码的特点:
翻译之后都在_jspService 方法中
翻译到_jspService()方法中, 所以在_jspService() 方法中的现有对象都可以直接使用
还可以由多个代码脚本组合完成一个完整的java语句
代码脚本还可以和表达式脚本一起组合使用,子啊jsp页面上输出数据
jsp中的内置对象,是指Tomcat在翻译jsp页面成为Servlet 源代码后,内部提供的九大内置对象,叫内置对象。
request | 封装客户端的请求,其中包含来自GET或POST请求的参数; | 1 |
---|---|---|
response | 封装服务器对客户端的响应 | 2 |
pageContext | 通过该对象可以获取其他对象 | 3 |
session | 封装用户会话的对象 | 4 |
application | 封装服务器运行环境的对象 | 5 |
out | 输出服务器响应的输出流对象; | 6 |
config | Web应用的配置对象; | 7 |
page | JSP页面本身(相当于Java程序中的this); | 8 |
exception | 封装页面抛出异常的对象。 | 9 |
1 | pageContext | (PageContextImpl 类) | 当前 jsp 页面范围内有效 |
---|---|---|---|
2 | request | (HttpServletRequest 类) | 一次请求内有效….一个请求可能跨越多个页面,涉及多个Web组件;需要在页面显示的临时数据可以置于此作用域。 |
3 | session | (HttpSession 类) | 一个会话范围内有效(打开浏览器访问服务器, 直到关闭浏览器) |
4 | application | (ServletContext 类) | 整个 web 工程范围内都有效(只要 web 工程不停止, 数据都在) |
域对象是可以像 Map 一样存取数据的对象。 四个域对象功能一样。 不同的是它们对数据的存取范围。
虽然四个域对象都可以存取数据。 在使用上它们是有优先顺序的。
由小到大
pageContext == request ==session >>> application
response中表示响应:设置返回给客户端的内容(输出)
out 也是给用户做输出使用的。
总结:
当前jsp页面中所有代码执行完成后会
由于 jsp 翻译之后, 底层源代码都是使用 out 来进行输出, 所以一般情况下。 我们在 jsp 页面中统一使用 out 来进行输出。 避免打乱页面输出内容的顺序
out.write() 输出字符串没有问题
out.print() 输出任意数据都没有问题(都转换成为字符串后调用的 write 输出)
JSP静态包含
<%@ include file="/include/footer.jsp"%>
<%--
<%@ include file=""%>
就是静态包含
file 属性指定你要包含的 jsp 页面的路径
地址中第一个斜杠 / 表示为 http://ip:port/工程路径/ 映射到代码的 web 目录
静态包含的特点:
1、 静态包含不会翻译被包含的 jsp 页面。
2、 静态包含其实是把被包含的 jsp 页面的代码拷贝到包含的位置执行输出。
--%>
动态包含的特点:
JspRuntimeLibrary.include(request, response, "/include/footer.jsp", out, false);
<jsp:forward page="/scope2.jsp"></jsp:forward>
<%--
<jsp:forward page=""></jsp:forward> 是请求转发标签, 它的功能就是请求转发
page 属性设置请求转发的路径
--%>
Servlet是一个特殊的Java程序,它运行于服务器的JVM中,能够依靠服务器的支持向浏览器提供显示内容,jsp的本质是Servlet的一种简易形式,JSP会被服务器处理成为一个类似Servlet的Java程序.可以简化页面内容的生成,
Servlet和JSP最主要的不同点在于
对于JSP页面,可以通过page指令进行设置。
<%@page isThreadSafe=”false”%>
对于Servlet,可以让自定义的Servlet实现SingleThreadModel标识接口。
SingleThreadModel
如果将JSP或Servlet设置成单线程工作模式,会导致每个请求创建一个Servlet实例,这种实践将导致严重的性能问题(服务器的内存压力很大,还会导致频繁的垃圾回收),所以通常情况下并不会这么做