jsp 的全称是 java server pages。Java 的服务器页面。
jsp 的主要作用是代替 Servlet 程序回传 html 页面的数据。
因为 Servlet 程序回传 html 页面数据是一件非常繁锁的事情。开发成本和维护成本都极高。
Servlet 回传 html 页面数据的代码:
package com.atguigu.servlet;
import javax.servlet.ServletException;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import java.io.IOException;
import java.io.PrintWriter;
public class PringHtml extends HttpServlet {
@Override
protected void doGet(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
// JspWriter
// 通过响应的回传流回传html页面数据
//设置一下,防止响应的乱码
resp.setContentType("text/html; charset=UTF-8");
//得到响应流
PrintWriter writer = resp.getWriter();
writer.write("\r\n");
writer.write(" \r\n");
writer.write(" \r\n");
writer.write(" \r\n");
writer.write(" Title \r\n");
writer.write(" \r\n");
writer.write(" \r\n");
writer.write(" 这是html页面数据 \r\n");
writer.write(" \r\n");
writer.write("\r\n");
writer.write("\r\n");
}
}
总结:
请求转发是一个静态页面,而JSP和servlet response是实现动态页面的
请求转发怎么把想要的信息发送给页面接收?
比如用户登录,如果密码出错需要回传给浏览器,显示在登录界面,请求转发怎么做到?
针对每一个情况写一个html页面吗?
显然不可能!
jsp 回传一个简单 html 页面的代码:
<%@ page contentType="text/html;charset=UTF-8" language="java" %>
<html>
<head>
<title>Titletitle>
head>
<body>
这是 html 页面数据
body>
html>
jsp 的小结:
1、如何创建 jsp 的页面?

输入文件名敲回车即可!!

2、jsp 如何访问:
jsp 页面和 html 页面一样,都是存放在 web 目录下。访问也跟访问 html 页面一样。
比如:
在 web 目录下有如下的文件:
web 目录
a.html 页面访问地址是:http://ip:port/工程路径/a.html
b.jsp 页面访问地址是:http://ip:port/工程路径/b.jsp
jsp 页面本质上是一个 Servlet 程序。
当我们第一次访问 jsp 页面的时候。Tomcat 服务器会帮我们把 jsp 页面翻译成为(新生成)一个 java 源文件。并且对它进行编译成为.class 字节码程序。我们打开 java 源文件不难发现其里面的内容是:

我们跟踪原代码发现,HttpJspBase 类。它直接地继承了 HttpServlet 类。也就是说。jsp 翻译出来的 java 类,它间接了继承了 HttpServlet 类。也就是说,翻译出来的是一个 Servlet 程序

总结:通过翻译的 java 源代码我们就可以得到结果:jsp 就是 Servlet 程序。
大家也可以去观察翻译出来的 Servlet 程序的源代码,不难发现。其底层实现,也是通过输出流。把 html 页面数据回传给客户端。
jsp 的 page 指令可以修改 jsp 页面中一些重要的属性,或者行为。
<%@ page contentType="text/html;charset=UTF-8" language="java" %>
contentType 属性表示 jsp 返回的数据类型是什么。也是源码中 response.setContentType()参数值language 属性表示 jsp 翻译后是什么语言文件。暂时只支持 java。pageEncoding 属性表示当前 jsp 页面文件本身的字符集。import 属性跟 java 源代码中一样。用于导包,导类。两个属性是给 out 输出流使用
autoFlush 属性设置当 out 输出流缓冲区满了之后,是否自动刷新冲级区。默认值是 true。buffer 属性设置 out 缓冲区的大小。默认是 8kberrorPage 属性设置当 jsp 页面运行时出错,自动跳转去的错误页面路径。示例:errorPage=“/error500.jsp”isErrorPage 属性设置当前 jsp 页面是否是错误信息页面。默认是 false。如果是 true 可以获取异常信息。session 属性设置访问当前 jsp 页面,是否会创建 HttpSession 对象。默认是 true。extends 属性设置 jsp 翻译出来的 java 类默认继承谁。不建议改
声明脚本(极少使用)
声明脚本的格式是: <%! 声明 java 代码 %>
作用:可以给 jsp 翻译出来的 java 类定义属性和方法甚至是静态代码块。内部类等。
<%@ page import="java.util.Map" %>
<%@ page import="java.util.HashMap" %>
<%@ page contentType="text/html;charset=UTF-8" language="java" %>
<html>
<head>
<title>Titletitle>
head>
<body>
<%--练习:
--%>
<%--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";
}
%>
body>
html>

表达式脚本的格式是:<%=表达式%>
表达式脚本的作用是:在 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.代码脚本----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);
%>

html 注释
html 注释会被翻译到 java 源代码中。在_jspService 方法里,以 out.writer 输出到客户端。
java 注释
<%
// 单行java 注释
/* 多行java 注释 */
%>
java 注释会被翻译到 java 源代码中。
jsp 注释
<%-- 这是jsp 注释 --%>
jsp 注释可以注掉,jsp 页面中所有代码。
jsp 中的内置对象,是指 Tomcat 在翻译 jsp 页面成为 Servlet 源代码后,内部提供的九大对象,叫内置对象。

pageContext(PageContextImpl 类):当前 jsp 页面范围内有效
request(HttpServletRequest 类):一次请求内有效
session(HttpSession 类):一个会话范围内有效(会话:打开浏览器访问服务器,直到关闭浏览器)
application(ServletContext 类):整个 web 工程范围内都有效(只要 web 工程不停止,数据都在)
域对象是可以像 Map 一样存取数据的对象。四个域对象功能一样。不同的是它们对数据的存取范围。虽然四个域对象都可以存取数据。在使用上它们是有优先顺序的。
四个域在使用的时候,优先顺序分别是,他们从小到大的范围的顺序。 scope.jsp scope2.jsp response 中表示响应,我们经常用于设置返回给客户端的内容(输出) 由于 jsp 翻译之后,底层源代码都是使用 out 来进行输出,所以一般情况下。我们在 jsp 页面中统一使用 out 来进行输出。避免打乱页面输出内容的顺序。 out.write() 输出字符串没有问题 没有经过Servlet程序,实际上没有数据,会出现空指针异常,一定要先访问Servlet 实际的应用场景 Jsp得到数据 ServletContextListener 它可以监听 ServletContext 对象的创建和销毁。 两个方法分别是: 如何使用 ServletContextListener 监听器监听 ServletContext 对象。 监听器实现类: web.xml 中的配置:
pageContext<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>
<%
//请求转发到/scope2.jsp
//单独请求scope2.jsp时request域也无效
//request.getRequestDispatcher("/scope2.jsp").forward(request,response);
%>
<%--
<jsp:forward page="">jsp:forward> 是请求转发标签,它的功能就是请求转发
page 属性设置请求转发的路径
--%>
<jsp:forward page="/scope2.jsp">jsp:forward>
body>
html>
<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>
182.Jsp-out和response输出的区别
out 也是给用户做输出使用的。

<%@ page contentType="text/html;charset=UTF-8" language="java" %>
<html>
<head>
<title>Titletitle>
head>
<body>
<%
out.write(12);
// out.print(12);
%>
body>
html>
out.print() 输出任意数据都没有问题(都转换成为字符串后调用的 write 输出)
在 jsp 页面中,可以统一使用 out.print()来进行输出183.Jsp-常用标签之静态包含

<%--
<%@ include file=""%> 就是静态包含
file 属性指定你要包含的jsp 页面的路径地址中
第一个斜杠 / 表示为http://ip:port/工程路径/ 映射到代码的web 目录
静态包含的特点:
1、静态包含不会翻译被包含的jsp 页面。
2、静态包含其实是把被包含的jsp 页面的代码拷贝到包含的位置执行输出。
--%>
<%@ include file="/include/footer.jsp"%>
184.Jsp-常用标签之动态包含
<%--
<jsp:include page="">jsp:include> 这是动态包含
page 属性是指定你要包含的jsp 页面的路径
动态包含也可以像静态包含一样。把被包含的内容执行输出到包含位置
动态包含的特点:
1、动态包含会把包含的jsp 页面也翻译成为java 代码
2、动态包含底层代码使用如下代码去调用被包含的jsp 页面执行输出。
JspRuntimeLibrary.include(request, response, "/include/footer.jsp", out, false);
3、动态包含,还可以传递参数
--%>
<jsp:include page="/include/footer.jsp">
<jsp:param name="username" value="bbj"/>
<jsp:param name="password" value="root"/>
jsp:include>

185.Jsp-常用标签之请求转发
<%--
<jsp:forward page="">jsp:forward> 是请求转发标签,它的功能就是请求转发
page 属性设置请求转发的路径
--%>
<jsp:forward page="/scope2.jsp">jsp:forward>
186.Jsp-练习一:九九乘法口诀表
<%--
Created by IntelliJ IDEA.
User: Administrator
Date: 2020/2/23
Time: 22:32
To change this template use File | Settings | File Templates.
--%>
<%@ page contentType="text/html;charset=UTF-8" language="java" %>
<html>
<head>
<title>Titletitle>
<style type="text/css">
table{
width: 650px;
}
style>
head>
<body>
<%-- 练习一:在jsp页面中输出九九乘法口诀表 --%>
<h1 align="center">九九乘法口诀表h1>
<table align="center">
<% for (int i = 1; i <= 9; i++) { %>
<tr>
<% for (int j = 1; j <= i ; j++) { %>
<td><%=j + "x" + i + "=" + (i*j)%>td>
<% } %>
tr>
<% } %>
table>
body>
html>
187.Jsp-练习二:便利输出10个学生信息到表格中
<%@ page import="java.util.List" %>
<%@ page import="com.atguigu.pojo.Student" %>
<%@ page import="java.util.ArrayList" %>
<%--
Created by IntelliJ IDEA.
User: Administrator
To change this template use File | Settings | File Templates.
--%>
<%@ page contentType="text/html;charset=UTF-8" language="java" %>
<html>
<head>
<title>Title</title>
<style>
table{
border: 1px blue solid;
width: 600px;
border-collapse: collapse;
}
td,th{
border: 1px blue solid;
}
</style>
</head>
<body>
<%--练习二:jsp输出一个表格,里面有10个学生信息。--%>
<%
List<Student> studentList = (List<Student>) request.getAttribute("stuList");
%>
<table>
<tr>
<td>编号</td>
<td>姓名</td>
<td>年龄</td>
<td>电话</td>
<td>操作</td>
</tr>
<% for (Student student : studentList) { %>
<tr>
<td><%=student.getId()%></td>
<td><%=student.getName()%></td>
<td><%=student.getAge()%></td>
<td><%=student.getPhone()%></td>
<td>删除、修改</td>
</tr>
<% } %>
</table>
</body>
</html>
188.Jsp-请求转发的使用说明
1.前端有个搜索按钮,点击搜索请求Servlet程序
2.Servlet程序获取请求参数、发送sql语句查询信息、保存学生信息到request域中
3.Servlet不太适合回传显示信息、进行请求转发到jsp页面
5.创建jsp专门用来回传显示信息,从request中得到数据
SearchStudentServlet程序package com.atguigu.servlet;
import com.atguigu.pojo.Student;
import javax.servlet.ServletException;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import java.io.IOException;
import java.util.ArrayList;
import java.util.List;
public class SearchStudentServlet extends HttpServlet {
@Override
protected void doGet(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
// 获取请求的参数
// 发sql语句查询学生的信息
// 使用for循环生成查询到的数据做模拟
List<Student> studentList = new ArrayList<Student>();
for (int i = 0; i < 10; i++) {
int t = i + 1;
studentList.add(new Student(t,"name"+t, 18+t,"phone"+t));
}
// 保存查询到的结果(学生信息)到request域中
req.setAttribute("stuList", studentList);
// 请求转发到showStudent.jsp页面
req.getRequestDispatcher("/test/showStudent.jsp").forward(req,resp);
}
}
<%
List<Student> studentList = (List<Student>) request.getAttribute("stuList");
%>
189.Jsp-什么是Listener监听器
190.Jsp-ServletContextListener监听器演示
ServletContext 对象在 web 工程启动的时候创建,在 web 工程停止的时候销毁。
监听到创建和销毁之后都会分别调用 ServletContextListener 监听器的方法反馈。public interface ServletContextListener extends EventListener {
//在ServletContext对象创建之后马上调用,做初始化
public void contextInitialized(ServletContextEvent sce);
//在ServletContext对象销毁之后调用
public void contextDestroyed(ServletContextEvent sce);
}
使用步骤如下:
1.编写一个类去实现 ServletContextListener
2.实现其两个回调方法
3.到 web.xml 中去配置监听器package com.atguigu.listener;
import javax.servlet.ServletContextEvent;
import javax.servlet.ServletContextListener;
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对象被销毁了");
}
}
<listener>
<listener-class>com.atguigu.listener.MyServletContextListenerImpllistener-class>
listener>