1.JSP 技术
概念:
JSP 全名为 Java Server Pages,中文名叫 java 服务器页面,其根本是一个简化的 Servlet 设计,它 [1] 是由 Sun Microsystems 公司倡导、许多公司参与一起建立的一种动态网页技术标准。
特点:
本质上还是 Servlet
跨平台,一次编写处处运行
组件跨平台
健壮性和安全性
JSP的本质就是一个Servlet.
JSP的执行过程:
1.翻译阶段:将JSP翻译成java源文件(Servlet).
2.编译阶段:将JSP编译成class文件(字节码文件)
3.执行字节码
JSP页面的组成部分:
1.指令元素:page指令,include指令, taglib指令。
语法:<%@ 指令元素的名称 属性1="值1" 属性2="值2"...%>
page指令:设置页面的信息 <%@ page language="脚本语言" import="包名.类名" pageEncoding="页面编码集"%>
eg:<%@ page language="java" import="java.util.*" pageEncoding="UTF-8"%>
include指令: 静态引入(静态包含)<%@include file="url" %>
<%@include file="commons.jsp"%>
第一个jsp页面
<%@ page language="java" import="java.util.*" pageEncoding="ISO-8859-1"%>
2.jsp的访问原理
jsp的访问原理:
浏览器发起请求,请求 JSP,请求被 Tomcat 服务器接收,执行JspServlet 将请求的 JSP 文件转义成为对应的 java 文件(也是Servlet),然后执行转义好的 java 文件。
注意:
jsp中可以书写java代码,但是java代码会被原样转译到其对应的java文件中执行。
3.jsp的page指令
page指令:
设置页面的信息 <%@ page language="脚本语言" import="包名.类名" pageEncoding="页面编码集"%>
page指令的属性:
<%
page指令的作用:
设置jsp转译的时候的一些配置信息。
4.jsp的局部代码块和全局代码块和脚本段语句
局部代码块
声明方式:<% java代码 %>
特点:
使用局部代码块声明的java代码会被原样转译到_jspService方法中。也就是局部代码。
<%
全局代码块
声明方式:<%! 声明全局java代码%>
特点:
全局代码块中声明的java代码,在被转译时,会转译成jsp对应的java文件的全局的代码。
作用:
声明方法和全局量等
注意:
使用全局代码块声明方法,使用局部代码块调用方法。
<%!
java脚本段、表达式
声明方式:<%=变量名或者方法名()%>
作用:
将java代码的运算结果数据或者其他数据响应给浏览器
注意:
在该表达式中不能使用分号结尾
<
局部代码块声明和全局代码块声明的区别
使用局部代码块声明的java代码会被原样转译到_jspService方法中。也就是局部代码。
全局代码块中声明的java代码,在被转译时,会转译成jsp对应的java文件的全局的代码。
5.jsp的注释
jsp的注释:
HTML注释:会被转译也会被响应给浏览器,但是浏览器不会执行。
CSS注释:会被转译也会被响应给浏览器,但是浏览器不会执行。
js注释:会被转译也会被响应给浏览器,但是浏览器不会执行。
java注释:会被转译,但不会执行
jsp注释:注释内容不会被转译,也不会被执行
格式:%-- 注释内容 --%
<%@ page language="java" import="java.util.*" pageEncoding="utf-8"%>
6.jsp的动态引入和静态引入
问题:
发现,不同的jsp页面会使用相同的资源。如果将资源在每个jsp页面都单独声明则会造成代码的冗余量过高,不易于代码的维护和升级。
解决:
使用静态引入和动态引入的方式
使用:
静态引入:
<%@include file="要引入的资源的相对路径"%>
特点:
被引入的jsp文件和原有jsp文件被转译成一个java文件使用。
注意:静态引入的相关jsp文件中不能声明同名变量。
动态引入:
<jsp:include page="static.jsp"></jsp:include>
特点:
被引入的文件会被单独转译,原有jsp文件会调用被引入的jsp文件。
注意:动态引入的相关jsp文件中可以声明同名变量。
作用:
实现了不同jsp之间的资源共享。
<%@ page language="java" import="java.util.*" pageEncoding="utf-8"%>
<html>
<head>
</head>
<body>
<h3>我是静态引入和动态引入学习</h3>
<hr>
<%-- <i>©网站声明,手机号:77889900,网站备案号等</i> --%>
<%int a=3; %>
<!--静态引入 -->
<%-- <%@include file="static.jsp"%> --%>
<!--动态引入 -->
<jsp:include page="static.jsp"></jsp:include>
</body>
</html>
静态引入和动态引入的区别
相同点:都可以实现页面包含(引入)的效果
不同的:
1.语法不同
静态包含:<%@include file="包含的页面"%>
动态包含:<jsp:include page="包含的页面"/>
2.编译的文件个数不同
动态包含最终编译输出的文件为2个(被包含的页面单独编译), 包含页面和被包含的页面的变量名可用相同。
静态包含最终编程输出的文件为1个,不允许包含页面和被包含的页面的变量名相同。
7.jsp的forward标签
jsp之间的资源转发:
问题:
不同的jsp在处理请求时,有可能会将当前的请求转发给另外的jsp进行处理。
解决:
使用forward动作指令
使用:
<jsp:forward page="要转发的jsp的相对路径"></jsp:forward>
特点:
从当前jsp跳转另外一个jsp页面。
注意:
forward标签中除了<jsp:param value="" name=""/>子标签以外不能出现其他内容,否则会报错。
<%@ page language="java" import="java.util.*" pageEncoding="utf-8"%>
<html>
<head></head>
<body>
<h3>forward转发标签学习</h3>
<hr/>
<%
int a=1;
if(a>2){
%>
<b>欢迎访问本网站</b>
<%
}else{
%>
<!--转发其他jsp页面 -->
<jsp:forward page="common.jsp">
<jsp:param value="zhangsan" name="uname"/>
</jsp:forward>
<% }%>
</body>
</html>
<html>
<head>
<base href="<%=basePath%>">
<title>My JSP 'common.jsp' starting page</title>
<meta http-equiv="pragma" content="no-cache">
<meta http-equiv="cache-control" content="no-cache">
<meta http-equiv="expires" content="0">
<meta http-equiv="keywords" content="keyword1,keyword2,keyword3">
<meta http-equiv="description" content="This is my page">
<!--
<link rel="stylesheet" type="text/css" href="styles.css">
-->
</head>
<%
request.setCharacterEncoding("utf-8");
String uname = request.getParameter("uname");
System.out.println(uname);
%>
<body>
<b>这位客官你的请求被屏蔽了,请及时充值</b>
</body>
</html>
8.jsp的内置对象
内置对象:
jsp在转译成其对应的java文件(也就是Servlet)时,会默认在_jspService方法中声明创建几个对象。
特点:
我们可以在jsp页面中声明java局部代码块,在代码块中直接使用内置对象。
JSP的内置对象(九个内置对象/隐式对象)
(1)request对象(HttpServletRequest):封装用户请求数据,通过该对象可以获取用户请求的相关数据。
常用的方法:
request.getParameter(String name)--->String: 根据参数的名称获取参数的值。
request.getParameterValues(String name)--->String[]:根据参数的名称获取参数的值。主要用于复选框。
request.setAttribute(String name,Object value):将指定的值存到request范围中.
request.getAttribute(String name):通过名称从request返回中获取值。
request.getRequestDispatcher(String url).forward(request,response):请求转发
request.setCharacterEncoding(String encoding):设置请求编码集,可以解决post提交的乱码问题。
request.getSession():获取会话对象。
需要了解的方法
request.getScheme():获取协议 --->http
request.getServerName():获取服务器名称或IP地址
request.getServerPort():获取服务器端口号
request.getContextPath():获取上下文路径(默认是项目名)
(2)response对象(HttpServletResponse):封装响应数据。
常用的方法:
response.setContentType(String content);--->response.setContentType("text/html;charset=utf-8");
response.sendRedirect(String url):重定向
response.getWriter()--->JspWriter:获取输出流进行输出
(3)session对象(HttpSession):封装会话信息(浏览器和服务器之间的会话),一个会话中多次请求数据共享。
常用的方法
session.setAttribute(String name,Object value):存值
session.getAttribute(String name):取值
session.invalidate():销毁会话
(4)application对象(ServletContext):封装Servlet上下文信息,整个应用程序共享。
常用的方法
application.setAttribute(String name,Object value):存值
application.getAttribute(String name):取值
(5)out对象(PrintWriter):在页面输出信息
out.print(Object content)/out.println(Object content);
out.write(Object content)
(6)pageContext对象:页面上下文对象,可以通过该对象获取其他8个内置对象
pageContext.setAttribute(String name,Object value):存值
pageContext.getAttribute(String name):取值
(7)page对象(this):当前页面
(8)config对象(ServletConfig):封装配置信息
(9)exception(Exception):封装异常信息
注意:
对象的名字必须是转译好的java文件中声明的对象名。
<%@ page language="java" import="java.util.*" pageEncoding="utf-8"%>
<%
//获取请求数据
String uname = request.getParameter("uname");
System.out.println(uname);
int a=3;
session.setAttribute("str", "我是session");
%>
四大作用域:
page(pageContext)|request|session|application作用域的区别
page:作用域范围仅限于当前页面。
request:作用域范围仅限于一次请求之间(包含当前页面)。注意:如果在A页面存值,在B页面取值,则A页面跳转B页面必须使用请求转发。
session:作用域范围仅限于一次会话之间(包含当前页面和多次用户请求)。
application:作用域范围是整个应用程序(项目)共享。
其范围大小:application>session>request>page
JSP 负责页面展现,Servlet 负责业务逻辑处理。
9.Servlet中请求转发和重定向的绝对路径
问题:
在jsp页面中进行资源之间的跳转时,如果书写的是相对路径
这样会造成如果当前文件的路径发生变更,从当前路径查找资源的相对路径都要重新进行书写。
解决:
将相对路径变成绝对路径
使用:
在jsp中路径中的第一个/表示服务器根目录。
示例:
<a href="/虚拟项目名/资源路径">访问关键字</a>
注意:
在Myeclipse中创建的jsp页面会自动生成路径处理代码basePath
而basePath的值为当前项目根目录,并且在head标签中使用了<base href="<%=basePath%>">
相当于将当前页面的资源全部默认定位为从项目根目录开始查找,我们就不需要写第一个/了
注意:
basePath方式和添加/方法只能二选一。
文件路径
path.jsp
<%@ page language="java" import="java.util.*" pageEncoding="utf-8"%>
<%
String path = request.getContextPath();
String basePath = request.getScheme()+"://"+request.getServerName()+":"+request.getServerPort()+path+"/";
%>
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
<html>
<head>
<base href="<%=basePath%>">
<title>My JSP 'path.jsp' starting page</title>
<meta http-equiv="pragma" content="no-cache">
<meta http-equiv="cache-control" content="no-cache">
<meta http-equiv="expires" content="0">
<meta http-equiv="keywords" content="keyword1,keyword2,keyword3">
<meta http-equiv="description" content="This is my page">
<!--
<link rel="stylesheet" type="text/css" href="styles.css">
-->
</head>
<body>
我是path.jsp
<a href="a/a.jsp">a.jsp</a>
</body>
</html>
a.jsp
<%@ page language="java" import="java.util.*" pageEncoding="utf-8"%>
<%
String path = request.getContextPath();
String basePath = request.getScheme()+"://"+request.getServerName()+":"+request.getServerPort()+path+"/";
%>
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
<html>
<head>
<base href="<%=basePath%>">
<title>My JSP 'a.jsp' starting page</title>
<meta http-equiv="pragma" content="no-cache">
<meta http-equiv="cache-control" content="no-cache">
<meta http-equiv="expires" content="0">
<meta http-equiv="keywords" content="keyword1,keyword2,keyword3">
<meta http-equiv="description" content="This is my page">
<!--
<link rel="stylesheet" type="text/css" href="styles.css">
-->
</head>
<body>
我是a.jsp
<!-- <a href="a/b/b.jsp">b.jsp</a> -->
<a href="./path.jsp">path.jsp</a>
</body>
</html>
b.jsp
<%@ page language="java" import="java.util.*" pageEncoding="utf-8"%>
<%
String path = request.getContextPath();
String basePath = request.getScheme()+"://"+request.getServerName()+":"+request.getServerPort()+path+"/";
%>
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
<html>
<head>
<base href="<%=basePath%>">
<title>My JSP 'b.jsp' starting page</title>
<meta http-equiv="pragma" content="no-cache">
<meta http-equiv="cache-control" content="no-cache">
<meta http-equiv="expires" content="0">
<meta http-equiv="keywords" content="keyword1,keyword2,keyword3">
<meta http-equiv="description" content="This is my page">
<!--
<link rel="stylesheet" type="text/css" href="styles.css">
-->
</head>
<body>
我是b.jsp
<a href="path.jsp">path.jsp</a>
</body>
</html>
路径问题(基础路径:主要解决跳转时目录路径问题,通过基础路径每次从项目的根目录开始查找,可以省去相对路径之间的进退文件夹的问题)。