JSP指令(directive)
是为JSP引擎而设计的,它们并不直接产生任何可见输出,而是只告诉引擎如何处理JSP页面中的其余部分
基本语法格式
<%@指令 属性名="值"%>
举例:<%@ pagecontentType="text/html;charset=gb2312"%>
注意:属性名部分是大小写敏感的
在目前的JSP 2.0中,定义了page、include和tagelib这三种指令,每种指令中又都定义了一些各自的属性
如果要在一个JSP页面中设置同一条指令的多个属性,可以使用多条指令语句单独设置每个属性,也可以使用同一条语句设置该指令的多个属性。
- 第一种方式:
<%@ pagecontentType="text/html;charset=gb2312"%>
<%@ page import="java.util.Date"%>
- 第二种方式:
<%@page contentType="text/html;charset=gb2312" import="java.util.Date"%>
Page指令
用于定义JSP页面的各种属性,无论page指令出现在JSP页面中的什么地方,它作用的都是整个JSP页面,为了保持程序的可读性和遵循良好的编程习惯,page指令最好是放在整个JSP页面的起始位置
JSP 2.0规范中定义的page指令的完整语法:
<%@ page
[language="java"]
[extends="package.class"]
[import="{package.clsaa | package}, ..."]
[session="true | false"]
[buffer="none | &kb | sizekb"]
[autoFlush="true | false"]
[isThreadSafe="true | false"]
[info="text"]
[errorPage="relative_url"]
[isErrorPage="true | false"]
[contentType="mimeType【;charset=characterSet】" | "text/html;charset=ISO-8859-1"]
[pageEncoding="characterSet | ISO-8859-1"]
[isEllgnored="true | false"]
%>
注:标红色为常用语法
errorPage属性的设置值必须使用相对路径,如果以“/”开头,表示相对于当前web应用程序的根目录,否则,表示相对于当前页面。
可以在web.xml文件中使用<error-page>元素为整个web应用程序设置错误处理页面,其中<excaption-type>子元素指定异常类的完全限定名,<location>元素指定以“/”开头的错误处理页面的路径
如果设置了某个JSP页面的errorPage属性,那么在web.xml文件中的错误处理将不对该页面起作用。
JSP引擎会根据page指令的contentType属性生成相应的调用SeryletResponse.setContentType方法的语句。page指令的contentType属性还具有说明JSP源文件的字符编码的作用。
page指令的常用的属性
1、import:指定当前jsp页面对应的servlet需要导入的类
<%@ page impot="java.util.Date"%>
2、session:取值为true或false,指定当前页面的session隐藏对象是否可用,或者说是在访问当前页面时,是否生成HttpSession对象
3、errorPage和isErrorPage:errorPage指定当前页面出现错误的实际响应页面是哪个,其中/表示当前web应用的根目录
<%@ page errorPage="/error.jsp"%>
响应errorPage时,JSP引擎使用的是请求转发的方式;isErrorPage指定当前页面是否为错误处理页面,可以说明当前页面是否可以使用exception隐含变量,若指定是isErrorPage=“true”,并且使用exception的方法,一般不建议能够直接访问该页面,所以该页面一般应位于WEB-INF目录下。
4、contentType:指定当前jsp页面的响应类型,实际调用的是response.setContentType("text/html;charset=UTF-8")
5、pageEncoding:指定当前JSP页面的字符编码,通常和charset保持一致
6、isELlgnored:指定当前JSP页面是否可以使用EL表达式
include指令
用于通知JSP引擎在翻译当前JSP页面时将其他文件中的内容合并进当前JSP页面转换成的Servlet源文件中,这种在源文件级别进行引入的方式称之为静态引入,当前JSP页面与静态引入的页面紧密结合为一个Servlet。
语法
<%@ include file="relativeURL"%>
其中file属性用于指定被引入文件的相对路径
细节
- 被引入的文件必须遵循JSP语法,其中的内容可以包含静态HTML、JSP脚本元素、JSP指令和JSP行为元素等普通JSP页面所具有的一切内容
- 被引入的文件可以使用任意的扩展名,即使其扩展名是html,JSP引擎也会按照处理jsp页面的方式处理它里面的内容,为了见名知意,JSP规范建议使用 .jspf(JSP fragments)作为静态引入文件的扩展名。
- 在将JSP文件翻译程Servlet源文件时,JSP引擎将合并被引入的文件与当前JSP页面中的指令元素(设置pageEncoding属性的page指令除外),所以,处理import和pageEncoding属性之外,page指令的其他属性不能在这两个页面中有不同的设置值。
- 除了指令元素之外,被引入的文件中的其他元素都被转换成相应的Java源代码,然后插入进当前JSP页面所翻译成的Servlet源文件中,插入位置与include指令在当前JSP页面中的位置保持一致
- 引入文件与被引入文件是在被JSP引擎翻译成Servlet的过程中合并的,而不是光合并源文件后再对合并的结果进行翻译。
- file属性的设置值必须使用相对路径,如果以“/”开头,表示相对于当前web应用程序的根目录(注意不是站点根目录),否则,表示相对于当前文件。
JSP标签
JSP还提供了一种称之为Action的元素,在JSP页面中使用Action元素可以完成各种通用的JSP页面功能,也可以实现一些处理复杂业务逻辑的专用功能。
Action元素采用XML元素的语法格式,即每个Action元素在JSP页面中都以XML标签的形式出现。JSP规范中定义了一些标准的Action元素,这些元素的标签吗都以jsp作为前缀,并且全部采用小号,例如,<jsp:include>、<jsp:forward>等待
- <jsp:include>标签
- <jsp:forward>标签
- <jsp:param>标签
<jsp:include>标签
用于把另一个资源的输出内容插入进当前JSP页面的输出内容之中,这种在JSP页面执行时的引入方式称之为动态引用
语法:<jsp:include page="relativeURL | <%=expression%>" flush="true|false" />
page属性用于指定被引入资源的相对路径,它也可以通过执行一个表达式来获得。
flush属性指定在插入其他资源的输出内容时,是否先将当前JSP页面的已输出的内容刷新到客户端。
<jsp:include>标签和include指令的比较
1、<%@ include file=""%>是指令元素。<jsp:include page=""/>是行为元素。
2、最终编译程Java文件的数目不同:
- 静态包含在转换成Java文件的时候将包含文件的内容“复制”到主体文件,然后作为一个整体编译,最终编译为一个Java文件。
- 动态包含是各个jsp文件分别转换,分别编译。最终编译成多个Java文件。
3、执行时间不同
静态包含发生在:JSP----->Java文件阶段
动态包含发生在:执行class文件阶段进行动态加入。
4、静态包含在两个文件中不能有相同的变量,动态包含允许。由于静态包含相当于将包含文件内容直接复制到主体文件中,如果出现相同的变量,就会出现覆盖等问题,导致文件出错。而动态包含相当于调用不同的jsp,变量所在的空间不同,自然不会出现覆盖等现象。
5、无论是动态包含还是静态包含,其request对象都是相同的,也就是同一个request对象静态包含最终编译程一个Java文件,有一个request对象;而动态包含最终编译成多个jsp文件,为何会使用一个request对象呢?其实这些jsp组合的过程是一个请求转发的过程,自然也使用同一个request对象了。
静态包含和动态包含的使用:简单总结一下,就是被包含的页面是静态页面就用静态包含,是动态页面就用动态包含。(不是很绝对,但这样用没有错)。
<jsp:forward>标签
<jsp:forward>标签用于把请求转发给另外一个资源。
语法: <jsp:forward page="relativeURL | <%=expression%>" />
page属性用于指定请求转发到的资源的相对路径,它可以通过执行一个表达式来获得。
<jsp:forward page="/include/b.jsp"></jsp:forward>
相当于:
<%
request.getRequestDispatcher("/include2/b.jsp").forward(request,response);
%>
<jsp:param>标签
当使用<jsp:include>和<jsp:forward>标签引入或将请求转发给的资源是一个能动态执行的程序时,例如Servlet和JSP页面,那么,还可以使用<jsp:param>标签向这个程序传递参数信息。
语法1:
<jsp:include page = "relativeURL | <%=expression%>">
<jsp:param name = "parameteName" value = "parameterValue | <%=expression%>">
</jsp:include>
语法2:
<jsp:forward page = "relativeURL | <%=expression%>">
<jsp:param name = "parameteName"value = "parameterValue | <%=expression%>">
</jsp:include>
<jsp:param>标签的name属性用于指定参数名,value属性用于指定参数值。在<jsp:include>和<jsp:forward>标签中可以使用多个<jsp:param>标签来传递多个参数。
<%--
Created by IntelliJ IDEA.
User: huwei
Date: 2018/7/11
Time: 17:46
To change this template use File | Settings | File Templates.
--%>
<%@ page contentType="text/html;charset=UTF-8" language="java" %>
<html>
<head>
<title>Title</title>
</head>
<body>
cccccccccccccccccccccccc
<%--<jsp:include page="d.jsp"/>--%>
<jsp:forward page="d.jsp">
<jsp:param name="username" value="lanqiao"/>
</jsp:forward>
</body>
</html>
<%--
Created by IntelliJ IDEA.
User: huwei
Date: 2018/7/11
Time: 17:46
To change this template use File | Settings | File Templates.
--%>
<%@ page contentType="text/html;charset=UTF-8" language="java" %>
<html>
<head>
<title>Title</title>
</head>
<body>
dddddddddddddddddddddddddddd
<%=request.getParameter("username")%>
</body>
</html>
中文乱码
第一种情况:调用jsp页面中文显示乱码
问题描述:通过浏览器调用jsp页面,在浏览器中显示的中文内容出现乱码。
解决方法:保证contentType="text/html;charset=UTF-8",pageEncoding="UTF-8" charset和pageEncoding的编码一致,且都支持中文,通常建议取值UTF-8,还需保证浏览器的显示的字符编码和请求的JSP页面的编码一致
第二种情况:获取中文参数值
默认情况下参数在传输过程中使用的编码为ISO-8859-1
① 对于POST请求,只要在获取请求信息之前,调用request.setCharacterEncoding("UTF-8"),即可。
②:对于GET请求:
先解码再重新编码:
String username = request.getParameter("username");
username = new String(username.getBytes("ISO-8859-1"),"utf-8");
不让Tomcat以缺省字符集对中文字符进行编码,而采用请求的编码方式进行编码
<Connector connectionTimeout="20000" port="8080" protocol="HTTP/1.1" redirectPort="8443" URIEncoding= "UTF-8"/>
一句话:在任何时候我们都要保证编码和解码的字符集保持一致。