jsp

jsp是什么?有什么用?

jsp 的全称是 java server pages。Java 的服务器页面。
jsp 的主要作用是代替 Servlet 程序回传 html 页面的数据。
因为 Servlet 程序回传 html 页面数据是一件非常繁锁的事情。开发成本和维护成本都极高。

    @Override
    protected void service(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
        // 通过响应的回传流回传 html 页面数据
        resp.setContentType("text/html; charset=UTF-8");
        PrintWriter writer = resp.getWriter();
        writer.write("<!DOCTYPE html>\r\n");
        writer.write(" <html lang=\"en\">\r\n");
        writer.write(" <head>\r\n");
        writer.write(" <meta charset=\"UTF-8\">\r\n");
        writer.write(" <title>Title</title>\r\n");
        writer.write(" </head>\r\n");
        writer.write(" <body>\r\n");
        writer.write(" 这是 html 页面数据 \r\n");
        writer.write(" </body>\r\n");
        writer.write("</html>\r\n");
        writer.write("\r\n");
    }

jsp的本质是什么

jsp 页面本质上是一个 Servlet 程序。
当我们第一次访问 jsp 页面的时候。Tomcat 服务器会帮我们把 jsp 页面翻译成为一个 java 源文件。并且对它进行编译成为.class 字节码程序。我们打开 java 源文件不难发现其里面的内容是继承HttpJspBase 类。然后HttpJspBase 类又是继承HttpServlet 类。也就是说。jsp 翻译出来的 java 类,它间接了继承了 HttpServlet 类。也就是说,翻译出来的是一个 Servlet 程序
在这里插入图片描述
总结:通过翻译的 java 源代码我们就可以得到结果:jsp 就是 Servlet 程序
这个servlet程序就是通过输出流。把 html 页面数据回传给客户端。

jsp的三种语法

语法一:jsp头部的page命令

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
在这里插入图片描述
在这里插入图片描述
vii. errorPage 属性 设置当 jsp 页面运行时出错,自动跳转去的错误页面路径。

<!-
errorPage 表示错误后自动跳转去的路径

这个路径一般都是以斜杠打头,它表示请求地址为 http://ip:port/工程路径/
映射到代码的 Web 目录
->

viii. isErrorPage 属性 设置当前 jsp 页面是否是错误信息页面。默认是 false。如果是 true 可以
获取异常信息。
ix. session 属性 设置访问当前 jsp 页面,是否会创建 HttpSession 对象。默认是 true。
x. extends 属性 设置 jsp 翻译出来的 java 类默认继承谁。

语法二:jsp中常用脚本

①声明脚本(很少使用)

声明脚本的格式是: <%! 声明 java 代码 %>
作用:可以给 jsp 翻译出来的 java 类定义属性和方法甚至是静态代码块。内部类等。

练习:
1、声明类属性
2、声明 static 静态代码块
3、声明类方法
4、声明内部类

<%--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";
}
%>
②表达式脚本(常用)

表达式脚本的格式是:<%=表达式%>
表达式脚本的作用是:的 jsp 页面上输出数据。

表达式脚本的特点:
1、所有的表达式脚本都会被翻译到_jspService() 方法中
2、表达式脚本都会被翻译成为 out.print()输出到页面上
3、由于表达式脚本翻译的内容都在_jspService() 方法中,所以_jspService()方法中的对象都可以直接使用。
4、表达式脚本中的表达式不能以分号结束。

练习:

  1. 输出整型
  2. 输出浮点型
  3. 输出字符串
  4. 输出对象
<%=12 %> <br>
<%=12.12 %> <br>
<%="我是字符串" %> <br>
<%=map%> <br>
<%=request.getParameter("username")%>
③代码脚本

代码脚本的格式是:
<%
java 语句
%>
代码脚本的作用是:可以在 jsp 页面中,编写我们自己需要的功能(写的是 java 语句)。

代码脚本的特点是:
1、代码脚本翻译之后都在_jspService 方法中
2、代码脚本由于翻译到_jspService()方法中,所以在_jspService()方法中的现有对象都可以直接使用。
3、还可以由多个代码脚本块组合完成一个完整的 java 语句。
4、代码脚本还可以和表达式脚本一起组合使用,在 jsp 页面上输出数据

练习:

  1. 代码脚本----if 语句
  2. 代码脚本----for 循环语句
  3. 翻译后 java 文件中_jspService 方法内的代码都可以写
<%--1.代码脚本----if 语句--%>
<%
	int i = 13 ;
	if (i == 12) {
%>
<h1>tyxml</h1>
<%
	} else {
%>
<h1>xhxml!</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);
%>

语法三:jsp中的注释

html注释
<!-- 这是 html 注释 -->

html 注释会被翻译到 java 源代码中。在_jspService 方法里,以 out.writer 输出到客户端。

java注释
<%
// 单行 java 注释
/* 多行 java 注释 */
%>

java 注释会被翻译到 java 源代码中。

jsp注释
<%-- 这是 jsp 注释 --%>

jsp 注释可以注掉,jsp 页面中所有代码。

jsp九大内置对象

jsp 中的内置对象,是指 Tomcat 在翻译 jsp 页面成为 Servlet 源代码后,内部提供的九大对象,叫内置对象

名称作用
request请求对象
response响应对象
pageContextjsp的上下文对象
session会话对象
applicationServletContext对象
configServletConfig对象
outjsp输出流对象
page指向当前jsp对象
exception异常对象

jsp四大域对象

四大域对象分别是:

名称继承类作用范围
pageContext(PageContextImpl 类)当前 jsp 页面范围内有效
request(HttpServletRequest 类)一次请求内有效
session(HttpSession 类)一个会话范围内有效(打开浏览器访问服务器,直到关闭浏览器)
application(ServletContext 类)整个 web 工程范围内都有效(只要 web 工程不停止,数据都在)

域对象是可以像 Map 一样存取数据的对象。四个域对象功能一样。不同的是它们对数据的存取范围。
虽然四个域对象都可以存取数据。在使用上它们是有优先顺序的。
四个域在使用的时候,优先顺序分别是,他们从小到大的范围的顺序。
pageContext ====>>> request ====>>> session ====>>> application

tips: pageContext.setAttribute报错原因是没导包jsp_api.jar

<%
    // 往四个域中都分别保存了数据
    pageContext.setAttribute("key", "pageContext");
    request.setAttribute("key", "request");
    session.setAttribute("key", "session");
    application.setAttribute("key", "application");
%>
pageContext 域是否有值:<%=pageContext.getAttribute%> <br>
request 域是否有值:<%=request.getAttribute("key")%> <br>
session 域是否有值:<%=session.getAttribute("key")%> <br>
application 域是否有值:<%=application.getAttribute("key")%> <br>

jsp中out输出和response.getWriter 输出的区别

response 中表示响应,我们经常用于设置返回给客户端的内容(输出)
out 也是给用户做输出使用的。

jsp中的两种代码:

<%
	//第一种情况:
    out.write("out输出1");
    out.write("out输出2");
    response.getWriter().write("response输出1");
    response.getWriter().write("response输出2");
    //输出结果是response输出1、response输出2、out输出1、out输出2

	//第二种情况:
	response.getWriter().write("response输出1");
    response.getWriter().write("response输出2");
    out.write("out输出1");
    out.write("out输出2");
    //输出结果是response输出1、response输出2、out输出1、out输出2

	//第三种情况:
	out.write("out输出1");
	out.flush();
	response.getWriter().write("response输出1");
    response.getWriter().write("response输出2");
    out.write("out输出2");
    //输出结果是out输出1、response输出1、response输出2、out输出2
%>

当jsp页面中所有代码执行完成后会做以下的两个操作:

  1. 执行out.flush()操作,会把out缓冲区的数据追加到response缓冲区末尾
  2. 会执行response的刷新操作。把全部数据写给客户端

由于jsp翻译后,底层源代码都是使用out来进行输出,所有在一般情况下:我们在 jsp 页面中统一使用 out 来进行输出。避免打乱页面输出内容的顺序。

out.write() 输出字符串没有问题
out.print() 输出任意数据都没有问题(都转换成为字符串后调用的 write 输出)
深入源码,浅出结论:在 jsp 页面中,可以统一使用 out.print()来进行输出

jsp常用标签

①jsp静态包含(include file)

<%@ include file="/include/footer.jsp"%>

<%@ include file=" "%> 就是静态包含
file 属性指定你要包含的 jsp 页面的路径
地址中第一个斜杠 / 表示为 http://ip:port/工程路径/ 映射到代码的 web 目录

静态包含的特点:
1、静态包含不会翻译被包含的 jsp 页面。
2、静态包含其实是把被包含的 jsp 页面的代码拷贝到包含的位置执行输出。

②jsp动态包含(jsp:include page)

<jsp:include page="/include/footer.jsp">
	<jsp:param name="username" value="bbj"/>
	<jsp:param name="password" value="root"/>
</jsp:include>

<jsp:include page=" "></jsp:include> 这是动态包含
page 属性是指定你要包含的 jsp 页面的路径
动态包含也可以像静态包含一样。把被包含的内容执行输出到包含位置
注:主页面把自己的request、response、out等对象都传递给了子jsp页面去用,也就是同一个对象

动态包含的特点:
1、动态包含会把包含的 jsp 页面也翻译成为 java 代码
2、动态包含底层代码使用如下代码去调用被包含的 jsp 页面执行输出。
JspRuntimeLibrary.include(request, response, “/include/footer.jsp”, out, false);
3、动态包含,还可以传递参数(可以用request.getParameter()获取)

③jsp 标签转发(jsp:forward page)

<jsp:forward page="/scope2.jsp"></jsp:forward>

<jsp:forward page=" “></jsp:forward> 是请求转发标签,它的功能就是请求转发
page 属性设置请求转发的路径
和request.getRequestDispatcher(”").forward(request,response);一个作用

Listener监听器

什么是listener监听器?

1、Listener 监听器它是 JavaWeb 的三大组件之一。JavaWeb 的三大组件分别是:Servlet 程序、Filter 过滤器、Listener 监听器。
2、Listener 它是 JavaEE 的规范,就是接口
3、监听器的作用是,监听某种事物的变化。然后通过回调函数,反馈给客户(程序)去做一些相应的处理。

ServletContextListener 监听器

ServletContextListener 它可以监听 ServletContext 对象的创建和销毁。
ServletContext 对象在 web 工程启动的时候创建,在 web 工程停止的时候销毁。
监听到创建和销毁之后都会分别调用 ServletContextListener 监听器的方法反馈。

如何使用 ServletContextListener 监听器监听 ServletContext 对象。
使用步骤如下:
1、编写一个类去实现 ServletContextListener
2、实现其两个回调方法
3、到 web.xml 中去配置监听器

java代码:

public class ServletListenerImpl implements ServletContextListener {
	//初始化时servletcontext时调用
    @Override
    public void contextInitialized(ServletContextEvent servletContextEvent) {
        System.out.println("servletContext对象开始被创建啦");
    }
	//摧毁时调用
    @Override
    public void contextDestroyed(ServletContextEvent servletContextEvent) {
        System.out.println("servletContext对象被销毁啦");
    }
}

xml文件配置:

  <listener>
    <listener-class>Test.ServletListenerImpl</listener-class>
  </listener>

ServletRequestListener 监听器

监测request的创建和销毁

java代码:

public class ServletListenerImp2 implements ServletRequestListener {
    @Override
    public void requestDestroyed(ServletRequestEvent servletRequestEvent) {
        System.out.println("request请求监听器被销毁啦");
    }

    @Override
    public void requestInitialized(ServletRequestEvent servletRequestEvent) {
        System.out.println("request请求监听器被创建啦");
    }
}

xml文件配置:

  <listener>
    <listener-class>Test.ServletListenerImp2 </listener-class>
  </listener>
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值