文章目录
1. 什么是jsp, 它有什么用
- jsp的全称是java server pages。java的服务器页面
- jsp的主要作用是代替servlet程序回传html页面的数据
2. jsp的本质是什么
- jsp页面的本质是一个Servlet程序
- 当我们第一次访问 jsp 页面的时候。Tomcat 服务器会帮我们把 jsp 页面翻译成为一个 java 源文件。并且对它进行编译成
为.class 字节码程序。我们打开 java 源文件不难发现其里面的内容是:
- 我们跟踪原代码发现,HttpJspBase 类。它直接地继承了 HttpServlet 类。也就是说。jsp 翻译出来的 java 类,它间接了继承了 HttpServlet 类。也就是说,翻译出来的是一个 Servlet 程序
- 总结:通过翻译的 java 源代码我们就可以得到结果:jsp 就是 Servlet 程序
3. jsp的三种用法
3.1 指令
3.1.1 jsp头部的page指令
- jsp的page指令可以修改jsp页面中一些重要的属性或行为
+ <%@ page contentType=“text/html,chatset=utf-8” languge=“java” %>-
languge属性:表示jsp翻译后是什么语言文件,暂时只支持java
-
contentType属性:表示jsp返回的数据类型是什么,也就是源码中reponse.setContextType()参数值
-
pageEncoding属性:表示当前jsp页面文件本身的字符集
-
import属性:跟java源代码中一样,用于导包,导类
=========================两个属性是给out输出流使用 -
autoFlush属性:设置当out输出缓冲区满了之后,是否自动刷新冲级区,默认值是true
-
buffer属性:设置out缓冲区的大小,默认是8kb
-
eroorPage属性:设置当jsp页面运行时出错,自动跳转去的错误页面路径
- errorPage 表示错误后自动跳转去的路径 这个路径一般都是以斜杠打头,它表示请求地址为 http://ip:port/工程路径/
-
isErrorPage属性:设置当前jsp页面是否是错误信息页面,默认是false,,如果是true可以获取异常信息
-
session属性:设置访问当前jsp页面,是否会创建HttpSessio对象。默认是true
-
extends属性:设置jsp翻译出来的java类默认继承谁
-
3.1.2 include指令
- include:页面包含的,导入页面的资源文件
- <%@ include file=“”%> 就是静态包含
1. 静态包含不会翻译被包含的 jsp 页面
2. 静态包含其实是把被包含的 jsp 页面的代码拷贝到包含的位置执行输出。 - jsp:include page=“”></jsp:include> 这是动态包含
1. 动态包含会把包含的 jsp 页面也翻译成为 java 代码
2. 动态包含底层代码使用如下代码去调用被包含的 jsp 页面执行输出。
3. 动态包含,还可以传递参数
- <%@ include file=“”%> 就是静态包含
<jsp:include page="/include/footer.jsp">
<jsp:param name="username" value="bbj"/>
<jsp:param name="password" value="root"/>
</jsp:include>
3.1.3 tablib指令
- tablib:导入资源
- <%@ taglib prefix=“c” uri=“http://java.sun.com/jsp/jstl/core” %>
- prefix:前缀,自定义的
3.1.3 jsp标签-转发
- <jsp:forward page=“”>&ly;/jsp:forward> 是请求转发标签,它的功能就是请求转发
page 属性设置请求转发的路径
3.2 JSP的常用脚本
3.2.1声明脚本(极少使用)
- 声明脚本的格式是:<%!声明java代码 %>
- 作用:可以给jsp翻译出来的java类定义属性和方法甚至是静态代码块,内部类等
代码实例
<%--1、声明类属性--%>
<%!
private Integer id;
private String name;
private static Map<String,Object> map;
%>
<%--2、声明 static 静态代码块--%>
<%!
static {
map = new HashMap<String,Object>();
map.put("key1", "value1");
map.put("key2", "value2");
map.put("key3", "value3");
}
%>
<%--3、声明类方法--%>
<%!
public int abc(){
return 12;
}
%>
<%--4、声明内部类--%>
<%!
public static class A {
private Integer id = 12;
private String abc = "abc";
}
%
3.2.2 表达式脚本(常用)
- 表达式脚本的格式是:<%=表达式%>
- 表达式脚本的作用是:jsp页面上输出数据
- 表达式脚本的特点:
1. 所有的表达式脚本都会被翻译到_jspService()方法中
2. 表达式脚本都会翻译成为out.print()输出到页面上> 3. 由于表达式脚本翻译的内容都在_jspService()方法中,所以_jspService()方法中的对象都可以直接使用
4. 表达式脚本中的表达式不能以分号结束
实例代码
<%=12 %> <br>
<%=12.12 %> <br>
<%="我是字符串" %> <br>
<%=map%> <br>
<%=request.getParameter("username")%>
翻译对照
3.2.3 代码脚本
- 代码脚本的格式是:<% java语句 % >
- 代码脚本的特点是:
1. 代码脚本翻译之后都在_jspService方法中
2. 代码脚本由于翻译到_jspService()方法中,所以在_jspService()方法中的现有对象都可以直接使用。
3. 还可以由多个代码脚本块组合完成一个完整的 java 语句
4. 代码脚本还可以和表达式脚本一起组合使用,在 jsp 页面上输出数据
代码实例
<%--练习:--%>
<%--1.代码脚本----if 语句--%>
<%
int i = 13 ;
if (i == 12) {
%>
<h1>国哥好帅</h1>
<%
} else {
%>
<h1>国哥又骗人了!</h1>
<%
}
%>
<br>
<%--2.代码脚本----for 循环语句--%>
<table border="1" cellspacing="0">
<%
for (int j = 0; j < 10; j++) {
%>
<tr>
<td>第 <%=j + 1%>行</td>
</tr>
<%
}
%>
</table>
<%--3.翻译后 java 文件中_jspService 方法内的代码都可以写--%>
<%
String username = request.getParameter("username");
System.out.println("用户名的请求参数值是:" + username);
%>
3.3 jsp的三注释
- html注释:<!-- 这是 html 注释 --> html 注释会被翻译到 java 源代码中。在_jspService 方法里,以 out.writer 输出到客户端。
- java注释:
<%
// 单行 java 注释
/* 多行 java 注释 */
%>
- jsp注释:< %-- 这是 jsp 注释 --%>,可以注释所有jsp页面的所有代码
4. jsp的九大内置对象
- jsp 中的内置对象,是指 Tomcat 在翻译 jsp 页面成为 Servlet 源代码后,内部提供的九大对象,叫内置对象
- 在jsp页面上不需要创建,直接使用的对象
变量名 | 真实类型 | 作用 |
---|---|---|
pageContext | PageContext | 当前页面共享数据,还可以获取其他八个内置对象 |
request | HttpServletRequest | 一次请求访问的多个资源(转发) |
session | HttpSession | 一次会话的多个请求间 |
application | ServletContext | 所有用户间共享数据 |
response | HttpServletResponse | 响应对象 |
page | Object | 当前页面(Servlet)的对象 this |
out | JspWriter | 输出对象,数据输出到页面上 |
config | ServletConfig | Servlet的配置对象 |
exception | Throwable | 异常对象 |
4.1 jsp四大域对象
四大域对象分布式
变量名 | 真实类型 | 范围 |
---|---|---|
pageContext | (PageContextImpl 类) | 当前 jsp 页面范围内有效 |
request | (HttpServletRequest 类) | 一次请求内有效 |
session | (HttpSession 类) | 一个会话范围内有效(打开浏览器访问服务器,直到关闭浏览器) |
application | (ServletContext 类) | 整个 web 工程范围内都有效(只要 web 工程不停止,数据都在) |
- 域对象是可以像 Map 一样存取数据的对象。四个域对象功能一样。不同的是它们对数据的存取范围
- 四个域在使用的时候,优先顺序分别是,他们从小到大的范围的顺序
- pageContext ====>>> request ====>>> session ====>>> application
scope.jsp页面
<body>
<h1>scope.jsp 页面</h1>
<%
// 往四个域中都分别保存了数据
pageContext.setAttribute("key", "pageContext");
request.setAttribute("key", "request");
session.setAttribute("key", "session");
application.setAttribute("key", "application");
%>
pageContext 域是否有值:<%=pageContext.getAttribute("key")%> <br>
request 域是否有值:<%=request.getAttribute("key")%> <br>
session 域是否有值:<%=session.getAttribute("key")%> <br>
application 域是否有值:<%=application.getAttribute("key")%> <br>
<%
request.getRequestDispatcher("/scope2.jsp").forward(request,response);
%>
</body>
scope2.jsp
<body>
<h1>scope2.jsp 页面</h1>
pageContext 域是否有值:<%=pageContext.getAttribute("key")%> <br>
request 域是否有值:<%=request.getAttribute("key")%> <br>
session 域是否有值:<%=session.getAttribute("key")%> <br>
application 域是否有值:<%=application.getAttribute("key")%> <br>
</body>
5、jsp中的out输出和response.getWriter输出的区别
response中表示响应,我们经常用于设置返回客户端的内容(输出)
out也是给用户做 输出使用的
由于 jsp 翻译之后,底层源代码都是使用 out 来进行输出,所以一般情况下。我们在 jsp 页面中统一使用 out 来进行输出。避
免打乱页面输出内容的顺序。
6. jsp的常用标签
6.1. jsp静态包含
<%--
<%@ include file=""%> 就是静态包含
file 属性指定你要包含的 jsp 页面的路径
地址中第一个斜杠 / 表示为 http://ip:port/工程路径/ 映射到代码的 web 目录
静态包含的特点:
1、静态包含不会翻译被包含的 jsp 页面。
2、静态包含其实是把被包含的 jsp 页面的代码拷贝到包含的位置执行输出
--%>
<%@ include file="/include/footer.jsp"%>
6.2 动态包含
- 动态包含:<jsp:nclude page=“”%></jsp:include%gt;
- page属性:是指定你要包含的jsp页面路径
- 动态属性也可以像静态包含一样,把被包含的内容执行输出去到包含位置
- 动态包含的特点:
- 动态包含会把jsp页面也翻译称为java代码
- 动态包含底部代码使用如下代码去调用被包含的jsp页面执行输出
- JspRuntimeLibrary.include(request, response, “/include/footer.jsp”, out, false);
- 动态包含,还可以传递参数
<jsp:include page="/include/footer.jsp">
<jsp:param name="username" value="bbj"/>
<jsp:param name="password" value="root"/>
</jsp:include>
动态包含的底层原理
6.3 jsp标签-转发
<%--
<jsp:forward page=""></jsp:forward> 是请求转发标签,它的功能就是请求转发
page 属性设置请求转发的路径
--%>
<jsp:forward page="/scope2.jsp"></jsp:forward>
7. 什么是Listener监听器
- Listener 监听器它是 JavaWeb 的三大组件之一。JavaWeb 的三大组件分别是:Servlet 程序、Filter 过滤器、Listener 监听器。
- Listener 它是 JavaEE 的规范,就是接口
- 监听器的作用是,监听某种事物的变化。然后通过回调函数,反馈给客户(程序)去做一些相应的处理。
7.1 ServletContextListener监听器
- ServletContextListener 它可以监听 ServletContext 对象的创建和销毁。
- ServletContext 对象在 web 工程启动的时候创建,在 web 工程停止的时候销毁。
- 监听到创建和销毁之后都会分别调用 ServletContextListener 监听器的方法反馈。
两个方法分别是
public interface ServletContextListener extends EventListener {
/**
* 在 ServletContext 对象创建之后马上调用,做初始化
*/
public void contextInitialized(ServletContextEvent sce);
/**
* 在 ServletContext 对象销毁之后调用
*/
public void contextDestroyed(ServletContextEvent sce);
}
如何使用ServletContextListener监听器监听ServletContext对象
步骤如下:
- 编写一个类去实现 ServletContextListener
- 实现其两个回调方法
- 到 web.xml 中去配置监听器
监听器实现类
public class MyServletContextListenerImpl implements ServletContextListener {
@Override
public void contextInitialized(ServletContextEvent sce) {
System.out.println("ServletContext 对象被创建了");
}
@Override
public void contextDestroyed(ServletContextEvent sce) {
System.out.println("ServletContext 对象被销毁了");
}
}
web.xml中的配置
<!--配置监听器-->
<listener>
<listener-class>com.atguigu.listener.MyServletContextListenerImpl</listener-class>
</listener>