Jsp3大指令:
格式:<%@指令名 属性名1=”属性值1” 属性名2=”属性值2” %>
page指令:主要是告诉jsp引擎如何解析jsp文件
常用属性:
import 用来导包
language指定jsp文件被翻译为哪种语言,该属性只有一个值就是 java
contentType指定当前网页的编码
response.setContentType(“text/html;charset=utf-8”),主要是给浏览器看的
pageEncoding 指定当前页面的编码,jsp引擎会根据该编码解析jsp文件,这个是给服务器看的
errorPage 指定页面出现错误以后转发到的页面,这个属性的地址不加项目名。
isErrorPage 当前页面是否为一个错误页面,如果为true则可以在页面中使用exception对象。
基本不使用的属性
autoFlush 是否自动刷新缓存,默认值是true,一般不去修改这个属性
buffer 缓存的大小 默认8kb 一般不修改
extends 指定jsp对应的java类所要基础的父类。根本不用
info 设置当前jsp的信息,没用
isELIgnored 是否自动忽略EL表达式,默认为false,不忽略,一般不修改
session 是否可以直接使用session对象,默认值为true,一般不修改tentType 指定当前网页的编码:
=================================
测试page指令之异常页面跳转:
没有指定errorPage属性时:
访问:http://localhost:8080/servlet002/1.jsp
结果:
指定errorPage属性时:
访问:http://localhost:8080/servlet002/1.jsp
结果:
========================================
测试page指令info属性:
访问:http://localhost:8080/servlet002/1.jsp
结果:
======================
include静态包含指令
<%@ include file=”” %>
include指令主要用来将其他网页包含进当前JSP页面,他会将被包含页面原封不动复制到目标页面的指定位置。它只会翻译目标页面,而不会翻译被包含页面,比如 1.jsp include 2.jsp,相当于将2.jsp复制进1.jsp的指定位置,只会翻译1.jsp,而不会翻译2.jsp
测试:
访问:http://localhost:8080/servlet002/include/1.jsp
结果:
右键—查看网页源代码:
右键—服务器—browse deployment location:
只有1.jsp被翻译成Java文件
public void _jspService(final javax.servlet.http.HttpServletRequest request, final javax.servlet.http.HttpServletResponse response)
throws java.io.IOException, javax.servlet.ServletException {
final javax.servlet.jsp.PageContext pageContext;
javax.servlet.http.HttpSession session = null;
final javax.servlet.ServletContext application;
final javax.servlet.ServletConfig config;
javax.servlet.jsp.JspWriter out = null;
final java.lang.Object page = this;
javax.servlet.jsp.JspWriter _jspx_out = null;
javax.servlet.jsp.PageContext _jspx_page_context = null;
try {
response.setContentType("text/html; charset=UTF-8");
pageContext = _jspxFactory.getPageContext(this, request, response,
null, true, 8192, true);
_jspx_page_context = pageContext;
application = pageContext.getServletContext();
config = pageContext.getServletConfig();
session = pageContext.getSession();
out = pageContext.getOut();
_jspx_out = out;
out.write('\r');
out.write('\n');
out.write("\r\n");
out.write("\r\n");
out.write("\r\n");
out.write("\r\n");
out.write("\r\n");
out.write("\r\n");
out.write("Insert title here \r\n");
out.write("\r\n");
out.write("\r\n");
out.write("\tinclude指令:我是2.jsp页面!
\r\n");
out.write("\r\n");
out.write("");
out.write("\r\n");
out.write("\r\n");
out.write("\r\n");
out.write("\r\n");
out.write("\r\n");
out.write("include指令 \r\n");
out.write("\r\n");
out.write("\r\n");
out.write("\tinclude指令:我是1.jsp页面!
\r\n");
out.write("\r\n");
out.write("\r\n");
out.write("");
============================
Jsp动作标签:
JSP动作标签最终都会被翻译为一套java代码,在程序中执行。
"属性值">
"target.jsp">
"paramValue" name="paramName"/>
jsp:forward标签作用就是转发请求!如果标签中没有子标签,那么标签体不能出现任何内容,否则会报错。可以标签中使用jsp:param标签向目标页面传递请求参数。
"target.jsp">
jsp:include 动态包含,动态包含会为所有网页都生成一个java文件,动态包含并不是直接将被包含页面直接复制进目标页面,而是通过如下代码,将页面包含进当前页
org.apache.jasper.runtime.JspRuntimeLibrary.include(request, response, "/include/2.jsp", out, false);
==========================
访问:http://localhost:8080/servlet002/include2/1.jsp
结果:
jsp翻译成_1_jsp.java
out.write("我是jsp动作标签
\r\n");
out.write("\r\n");
if (true) {
_jspx_page_context.forward("/include2/2.jsp" + "?" + org.apache.jasper.runtime.JspRuntimeLibrary.URLEncode("username", request.getCharacterEncoding())+ "=" + org.apache.jasper.runtime.JspRuntimeLibrary.URLEncode("小兵兵", request.getCharacterEncoding()) + "&" + org.apache.jasper.runtime.JspRuntimeLibrary.URLEncode("password", request.getCharacterEncoding())+ "=" + org.apache.jasper.runtime.JspRuntimeLibrary.URLEncode("123456", request.getCharacterEncoding()));
return;
}
out.write("\r\n");
out.write("\r\n");
_2_jsp.java:
out.write("jsp动作标签转发页面!
\r\n");
out.write("username: ");
out.print(request.getParameter("username") );
out.write("
\r\n");
out.write("password: ");
out.print(request.getParameter("password") );
out.write("\r\n");
=================================
访问:http://localhost:8080/servlet002/include2/3.jsp
结果:
翻译后有2个Java文件,注意与jsp的include指令区分开:
_3_jsp.java:
out.write("\r\n");
out.write("\r\n");
out.write("\r\n");
out.write("jsp动态包含标签 \r\n");
out.write("\r\n");
out.write("\r\n");
out.write("我是jsp动态包含标签1
\r\n");
org.apache.jasper.runtime.JspRuntimeLibrary.include(request, response, "/include2/4.jsp", out, false);
out.write("\r\n");
out.write("\r\n");
out.write("");
_4_jsp.java:
out.write("\r\n");
out.write("\r\n");
out.write("\r\n");
out.write("Insert title here \r\n");
out.write("\r\n");
out.write("\r\n");
out.write("我是jsp动态包含标签1
\r\n");
out.write("\r\n");
out.write("");
注意如果标签中没有子标签,那么标签体不能出现任何内容,否则会报错。
===========================
9大内置对象:也称为隐含对象
在JSP中一共有9个隐含对象,这个9个对象我可以在JSP中直接使用。 因为在service方法已经对这个九个隐含对象进行声明及赋值,所以可以在JSP中直接使用。
pageContext
类型:PageContext
代表:当前页面的上下文
作用:可以获取到页面中的其他隐含对象,同时它还是一个域对象。
request
类型:HttpServletRequest
代表:请求
作用:可以获取用户发送的请求信息,它也是一个域对象。
session
类型:HttpSession
代表:当前会话
作用:可以作为域对象,用来共享数据。
application
类型:ServletContext
代表:代表整个WEB应用
作用:是JavaWeb中最大的域对象。
response
类型:HttpServletResponse
代表:响应
作用:向浏览器发送响应信息
out
类型:JspWriter
代表:输出流
作用:可以向页面输出内容
config
类型:ServletConfig
代表:当前JSP的配置信息
作用:可以获取到Servlet标签中初始化参数
page
类型:Object 在service方法中有如下代码 Object page = this;
代表:代表当前JSP的对象
作用:
exception
类型:Throwable
代表:异常信息
作用:获取页面中的异常
================================
Jsp之4大域对象:
在JavaWeb中一共有四个域对象pageContext 、request、session、application。通俗点,域就是不同的两个地方,域对象就是快递员,实现数据传递。
在JSP中可以获取全部四个域对象,而在Servlet中只能获取到三个,使用域对象有一个原则,能用小的就不用大的。域对象就是在不同的WEB资源之间共享数据的。这些不同的web资源主要指JSP和Servlet
域对象都有的方法:
void setAttribute(String name , Object value) 向域中添加属性
Object getAttribute(String name) 根据属性名从域中获取属性
void removeAttribute(String name) 根据属性名从域中移除属性
我们四个域对象分别有其不同的范围:
pageContext
类型:PageContext
范围:当前页面,一旦切换页面则域中的属性丢失。
应用:用来向标签中传递数据。
request
类型:HttpServletRequest
范围:当前请求,一但发送多次请求则域中的属性丢失。
应用:需要在一次请求中共享数据时。
区分:转发时可以在request域中共享属性,而重定向时不可以
session
类型:HttpSession
范围:在一次会话中有效,会话就是一次打开浏览器到关闭浏览器的过程。
应用:主要是登录这种操作,可以保存网站用户信息状态,但是关闭浏览器、不同浏览器之间确实不能保留数据信息的,因为其仅仅在一次会话有效。
注意:不同的浏览器之间不共享会话。
application
类型:ServletContext
范围:只要项目不卸载application中属性就不丢失
应用:在线用户数量统计,只要服务器不关闭,让数据存在application域当中,不管是关闭浏览器、还是用不同的浏览器打开,数据会一直存在,所有人都可以通过application对象获取到存在该域的数据。
测试4大域对象1:
访问:http://localhost:8080/servlet002/scope/1.jsp
结果:
转发测试4大域对象2:
访问:http://localhost:8080/servlet002/scope/1.jsp
结果:
=========================
重定向测试4大域对象3:
访问:http://localhost:8080/servlet002/scope/1.jsp
结果:
不同浏览器访问
session域对象失效,访问:http://localhost:8080/servlet002/scope/2.jsp
结果:
重启服务器application域失效
访问:http://localhost:8080/servlet002/scope/2.jsp
结果:
======================
JSP与Servlet分工
JSP本质就是一个Servlet!!!曾经在Model1这个年代,在我们的项目中已经看不见Servlet,JSP已经完全代替了Servlet。JSP擅长显示一个页面,不擅长编写Java代码,不可以打断点进行调试。Servlet擅长编写java代码,而不擅长显示页面,我们使用Servlet处理程序,而使用JSP显示页面。
将servlet处理后的结果放入进域中,由域对象进行传输,然后交给JSP显示。
===========================
练习:通过Servlet去数据库中查询一组学生列表,然后交给JSP显示列表。
1.用户先要访问ListServlet
2.ListServlet去数据库查询学生列表, 直接在Servlet创建一个List
3.将列表放入域对象中
4.通过JSP显示列表
测试代码:
ListServlet
protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
//创建学生列表
List<Student> list = new ArrayList<Student>();
//向列表中添加学生
list.add(new Student("孙悟空", "男", "花果山"));
list.add(new Student("猪八戒", "男", "高老庄"));
list.add(new Student("沙和尚", "男", "流沙河"));
list.add(new Student("白骨精", "女", "白骨洞"));
list.add(new Student("蜘蛛精", "女", "盘丝洞"));
list.add(new Student("奔波霸", "男", "通天河"));
//把list放入进域中
//request
//request.getSession();
//getServletContext();
request.setAttribute("list", list);
//转发请求到list.jsp
//WEB-INF目录下的资源不能直接被访问,但是通过转发可以访问
request.getRequestDispatcher("/WEB-INF/list.jsp").forward(request, response);
//response.sendRedirect(request.getContextPath()+"/list.jsp");
}
<body>
<h1 align="center">学生列表h1>
<%
List list = (List)request.getAttribute("list");
%>
<%
if(list != null){
%>
<table border="1" align="center" width="50%">
<tr>
<td>姓名td>
<td>性别td>
<td>住址td>
<td colspan="2">操作td>
tr>
<%
for(Student stu : list){
%>
<tr>
<td><%=stu.getName() %>td>
<td><%=stu.getGender() %>td>
<td><%=stu.getAddress() %>td>
<td><a href=#>删除a>td>
<td><a href=#>修改a>td>
tr>
<%
}
}
%>
table>
body>
访问:http://localhost:8080/servlet002/ListServlet
结果:
=======================
未完待续!