问题:
使用Servlet进行页面的展现,代码书写过于麻烦。极大的影响了开发效率,那么有没有一种方式可以像以前写网页那样来进行网页的编程工作?
解决:JSP技术
概念:
JSP全称为Java Server Pages,中文名叫Java服务器页面,其根本是一个简化的Servlet设计,它是由Sun Microsystems公司倡导、许多公司参与一起建立的一种动态网页技术标准。
特点:
本质上还是Servlet
跨平台,一次编写处处运行
组件跨平台
健壮性和安全性
JSP的访问原理:
在Tomcat服务器的web.xml文件里有如下配置:
浏览器发起请求后,由于URL结尾是.jsp结尾请求JSP,请求被Tomcat服务器接收,在项目的web.xml找不到对应的servlet后,然后去服务器的web.xml文件找到JspServlet,JspServlet在指定的路径找到.jsp文件后,将请求的JSP文件通过IO流转译成为对应的.java文件然后编译成新的.class文件加载进内存,创建一个新的servlet,这个servlet里面有JSP文件里要执行的Java代码即响应结果,通过这个servlet即可响应给用户JSP页面。(也就是服务器来通过翻译器,将.jsp文件翻译成了.class文件,创建了一个新的Servlet)
注意:服务器转译后的.java文件和.class文件在:
apache-tomcat-9/work/Catalina/localhost/项目名/org/apache/jsp/.java
apache-tomcat-9/work/Catalina/localhost/项目名/org/apache/jsp/.class
JSP的语法和指令:
JSP的三种注释:
1.前端语言注释:
会被转译,也会被发送,但是不会被浏览器执行。
2.Java语言注释:
会被转译,但是不会被servlet执行。
3.JSP注释:
格式:<%–被注释的内容–>
不会被转译。
JSP的page指令:
格式:
<%@page 属性名=”属性值” 属性名=”属性值” …… %>
常用:
1.language:声明JSP要被转译的语言,写java,因为现在只有java用了。
2.import:声明转译的java文件要导入的包,不同的包使用逗号隔开。
3.pageEncoding:设置JSP文件的数据编码格式。(高版本还同时设置了浏览器的解析和编码格式)填UTF-8。
4.contentType=”text/html;charset=UTF-8”,设置JSP数据响应给浏览器时,浏览器的解析和编码格式。(现在高版本可以不写,因为pagrEncoding一句即可同时设置)
5.session:设置转译的servlet中是否开启session支持,true表示开启,false表示关闭。默认为true
6.errorPage:设置JSP运行错误跳转的页面。
7.extends:设置JSP转译的java文件要继承的父类(包名+类名)
作用总结:配置JSP文件的转译相关的参数。
JSP的taglib指令:
在使用JSTL标签应用中比较大
JSP的局部代码块:
特点:局部代码块中声明的java代码会被转译到JSP对应的servlet文件的_JspService方法中。代码块中声明的变量都是局部变量。
使用:<% java代码 %>
缺点:使用局部代码块在JSP中进行逻辑判断,书写麻烦,阅读困难。
开发:servlet进行逻辑处理,使用JSP进行页面展现。
JSP的全局代码块:
特点:声明的java代码作为全局代码转译到对应的servlet类中。
使用:<%! java代码 %>
注意:全局代码块声明的代码,需要使用局部代码块调用。
JSP的脚本段语句:
特点:帮助我们快速的获取变量或者方法的返回值作为数据响应给浏览器。
使用:<%=变量名或者方法%>
注意:不要在变量名或者方法名后使用分号。
位置:除JSP语法要求以外的任意位置。
JSP的静态引入(JSP的include指令):
使用:
<%@include file=”要引入的JSP文件的相对路径” %>
特点:
会将引入的JSP文件和当前JSP文件转译成一个Java文件使用。
在网页中也就显示了合并后的显示效果。
注意:
静态引入的JSP文件不会单独转译成Java文件。
当前文件和静态引入的JSP文件中使用Java代码块不能够声明同名变量。
JSP的动态引入:
使用:
<jsp:include page=”要引入的JSP文件的相对路径”></jsp:include>
特点:
会将引入的jsp文件单独转译,在当前文件转译好的java文件中调用引入的JSP文件的转译文件。
在网页中显示合并后的显示效果。
注意:
动态引入允许文件中声明同名变量。
静态引入和动态引入的优点:降低JSP代码的冗余,便于维护升级。
页面转发(forward标签)
使用:
<jsp:forward page=”要转发的文件的相对路径”></jsp:forward>
特点:
一次请求
地址栏信息不改变
注意:
在转发标签的两个标签中间除了写<jsp:param name=”键名” value=”值”>,其它任意字符都会报500错,尤其是不小心加了空格。
在子标签,name属性为附带的数据的键名,value为附带的数据内容。
注意:会将数据以?的形式拼接在转发路径的后面。
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指定中使用属性isError=”true”开启。
9.config对象:也就是ServletConfig,主要是用来获取web.xml中的配置数据,完成一些初始化数据的读取。
ServletContext 与application的异同:
相同:其实servletContext和application 是一样的,就相当于一个类创建了两个不同名称的变量。在servlet中ServletContext就是application对象。大家只要打开jsp编译过后生成的Servlet中的_jspService()方法就可以看到如下的声明:
ServletContext application = null;
application = pageContext.getServletContext();
不同:两者的区别就是application用在jsp中,servletContext用在servlet中。application和page request session 都是JSP中的内置对象,在后台用ServletContext存储的属性数据可以用application对象获得。
而且application的作用域是整个Tomcat启动的过程。
例如:
ServletContext.setAttribute(“username”,username);
则在JSP网页中可以使用
application.getAttribute(“username”);来得到这个用户名。
四个作用域对象:
pageContext:当前页面。解决了在当前页面内的数据共享问题。获取其它内置对象。
request:一次请求。一次请求的servlet的数据共享。通过请求转发,将数据流转给下一个servlet。
session:一次会话。一个用户的不同请求的数据共享。将数据从一次请求流转给其他请求。
application:项目内。不同用户的数据共享问题。将数据从一个用户流转给其他用户。
作用:数据流转
JSP的路径问题:
在JSP中资源路径可以使用相对路径完成跳转,但是:
问题一:资源的位置不可随意改变。
问题二:需要使用…/进行文件夹的跳出,使用比较麻烦。
解决:使用绝对路径:
/虚拟项目名/项目资源路径
例如:
<a href=”/jsp/jspPro.jsp”>jspPro.jsp</a>
<a href=”/jsp/a/a.jsp”>a.jsp</a>
注意:在JSP中资源的第一个/表示的是服务器根目录,相当于:localhost:8080
使用JSP中自带的全局路径声明:
上面三行代码作用:
给资源前面添加项目路径:http://IP地址:端口号/虚拟项目名/
注意:
使用Myeclipse开发会自动生成。而Eclipse不会自动生成,需要自己添加。