1.jsp的访问原理
浏览器发起请求,请求JSP,请求被Tomcat服务器接收,执行JspServlet将请求的JSP文件转义成为对应的java文件(也是Servlet),然后执行转义好的java文件
2.JSP的语法和指令
- JSP的page指令
<%@page 属性名="属性值" 属性名="属性值"...%>
lanuage:声明jsp要被转译的语言
import:声明转译的java文件要导入的包,不同的包要使用逗号隔开
pageEncoding:设置jsp文件的数据编码格式
contentType="text/html"; charset="utf-8":设置jsp数据响应浏览器时,浏览器的解析和编码格式
session:设置转译的servlet中是否开启session支持支持,默认开启,true表示开启,false表示关闭
errorPage:设置jsp运行错误跳转的页面
extends:设置jjsp转译的java文件要继承的父类(包名+类名)
- JSP的taglib指令(外部资源引用JSTL)
- JSP的局部代码块
特点:
局部代码块中声明的java代码会被原样转译到jsp对应的servlet文件的_JspService方法中
代码块中声明的变量都是局部变量
使用:
<%java代码%>
缺点:
使用局部代码块在jsp中进行逻辑判断,书写麻烦,阅读困难
开发:
servlet进行请求逻辑处理,使用jsp进行页面展现
- JSP的全局代码块
特点:
声明的java代码作为全局代码转译到对应的servlet类中
使用:
<%! 全局代码 %>
注意:
全局代码块声明的代码,需要使用局部代码块调用
- JSP的脚本段语句
特点:
帮助我们快速的获取变量或者方法的返回值作为数据响应给浏览器
使用:
<%=变量名或者方法%>
注意:
不要在变量名或者方法后使用分号
位置:
除jsp语法要求以外的任意位置
- JSP的3种注释
(1)前端语言注释
会被转译,也会被发送,但是不会被浏览器执行
(2)java语言注释
会被转译,但是不会被servlet执行
(3)jsp注释
<%----%>不会被转译
- JSP的静态引入(JSP的include指令)
使用:
<%@include file="要引入的jsp文件的相对路径" %>
特点:
会将引入的jsp文件和当前jsp转译成一个java文件使用
在网页中也就显示了合并后的显示效果
注意:
静态引入的jsp文件不会单独转译成java(servlet)文件
当前文件和静态引入的jsp文件中不能使用java代码块声明同名变量
优点:
降低jsp代码的冗余,便于维护升级
- JSP的动态引入
使用:
<jsp:include page="要引入的jsp文件的相对路径"></jsp:include>
特点:
会将引入的jsp文件单独转译,在当前文件转译好的java文件中调用引入的jsp文件的转译文件
在网页中显示合并后的显示效果
注意:
动态引入允许文件中声明同名变量
优点:
降低jsp代码的冗余,便于维护升级
- 页面转发(forword标签)
使用:
<jsp:forward page="要转发的jsp文件的相对路径"></jsp:forward>
特点:
一次请求
地址栏信息不改变
注意:
在转发标签的两个标签中间除了写<jsp:param name="str" value="aaa"/>子标签不会报错,其他任意字符都会报错
<jsp:param name="str" value="aaa"/>
name属性为附带的数据的键名
value为附带的数据内容
注意:会将数据以?的形式拼接在转发路径的后面
<%@ page language="java" pageEncoding="utf-8"%> <html> <head> <title>jsp基本语法学习</title> <meta charset="utf-8"> </head> <body> <h3>jsp基本语法学习</h3> <hr/> <!-- 局部代码块 --> <% //声明java代码域--局部代码块声明 String str="jsp中使用逻辑校验"; int a=2; if(a>3){ %> <b>jsp学习很简单</b> <%} else{%> <i><%=str %></i> <%test();} %> <!-- 全局代码块 --> <%! int b=5; public void test(){ System.out.println("我是全局代码块声明"); } %> <!-- jsp的静态引入 --> <%@include file="includeStatic.jsp" %> <!-- jsp的动态引入 --> <jsp:include page="includeActive.jsp"></jsp:include> <!-- jsp的转发forwad标签 --> <jsp:forward page="forward.jsp"> <jsp:param value="aaa" name="str"/> </jsp:forward> </body> </html>
3.jsp的内置对象
内置对象:
jsp文件在转译成其对应的Servlet文件的时候自动生成的并声明的对象。我们在jsp页面中直接使用即可。
注意:
内置对象在jsp页面中使用,使用局部代码块或者脚本段语句来使用,不能够在全局代码块中使用。
内容:
(1)PageContext:页面上下文对象,封存了其他内置对象。封存了当前jsp的运行信息
注意:每个jsp文件单独拥有一个pageContext对象
作用域:当前页面
(2)request:封存当前请求数据的对象,由tomcat服务器创建
(3)session:此对象用来存储用户的不同请求的共享数据
(4)application:也就是ServletContext,一个项目只有一个,存储用户共享数据的对象,以及完成其他操作
(5)response:响应对象,用来响应请求处理结果给浏览器的对象。设置响应头,重定向
(6)out:响应对象,jsp内部使用。带有缓冲区的响应对象,效率高于response对象
(7)page:代表当前jsp的对象,相当于java中的this
(8)exception:异常对象,存储了当前运行的异常信息
注意:使用此对象需要在page指定中使用属性isErrorPage="true"开启
(9)config:也就是ServletConfig,主要是用来获取web.xml中配置数据,完成一些初始化数据的读取
4.四个作用域对象
pageContext:当前页面。解决了在当前页面内的数据共享问题
request:一次请求。一次请求的servlet的数据共享
session:一次会话。一个用户的不同请求的数据共享
application:项目内。不同用户的数据共享问题
5.jsp的路径
在jsp中资源路径可以使用相对路径完成跳转,但是:
问题一:资源位置不可随意更改
问题二:需要使用../进行文件夹的跳出,使用比较麻烦
使用绝对路径:
/虚拟项目名/资源名或者资源路径
注意:在jsp中资源的第一个"/"表示的是服务器根目录,相当于:localhost:8080
使用jsp中自带的全局路径声明:
<%
String path = request.getContextPath();
String basePath = request.getScheme()+"://"+request.getServerName()+":"+request.getServerPort()+path+"/";
%>
<base href="<%=basePath%>">
作用:
给资源前面添加项目路径: http://127.0.0.1:8080/虚拟项目名/