JSP(下)
标签(空格分隔): JavaWeb
JSP指令
JSP指令简介
JSP指令(directive)是为JSP引擎而设计的,它们并不直接产生任何可见输出,而只是告诉引擎如何处理JSP页面中的其余部分。
JSP指令的基本语法格式:
<%@ 指令 属性名="值" %>
举例:
<%@ page contentType="text/html;charset=UTF-8" language="java" %>
注意:属性名部分是大小写敏感的
在目前JSP中,定义了page、include和taglib这三种指令,每种指令中又都定义了一些各自的属性。
如果要在一个JSP页面中设置同一条指令的多个属性,可以使用多条指令语句单独设置每个属性,也可以使用同一条指令语句设置该指令的多个属性。
第一种方式:
<%@ page contentType="text/html;charset=gb2312"%>
<%@ page import="java.util.Date"%>
第二种方式:
<%@ page contentType="text/html;charset=gb2312" import="java.util.Date"%>
Page指令
Page指令简述
page指令用于定义JSP页面的各种属性,无论page指令出现在JSP页面中的什么地方,它作用的都是整个JSP页面,为了保持程序的可读性和遵循良好的编程习惯,page指令最好是放在整个JSP页面的起始位置。
JSP 2.0规范中定义的page指令的完整语法:
<%@ page
[ language="java" ]
[ extends="package.class" ]
[ import="{package.class | package.*}, ..." ]
[ session="true | false" ]
[ buffer="none | 8kb | 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" ]
[ isELIgnored="true | false" ]
%>
常用属性说明
- import 属性: 指定当前 JSP 页面对应的 Servlet 需要导入的类。
<%@page import="java.text.DateFormat"%>
- session 属性: 取值为 true 或 false, 指定当前页面的 session 隐藏变量是否可用, 也可以说访问当前页面时是否一定要生成 HttpSession
对象。
<%@ page session="false" %>
- errorPage :
errorPage 指定若当前页面出现错误的实际响应页面时什么. 其中/
表示的是当前 WEB 应用的根目录。在响应 error.jsp 时, JSP 引擎使用的请求转发的方式.。
<%@ page errorPage="/error.jsp" %>
isErrorPage:
isErrorPage 指定当前页面是否为错误处理页面, 可以说明当前页面是否可以使用 exception 隐藏变量. 需要注意的是: 若指定isErrorPage="true"
, 并使用 exception 的方法了,一般不建议能够直接访问该页面。如何使客户不能直接访问某一个页面呢?对于 Tomcat 服务器而言, WEB-INF 下的文件是不能通过在浏览器中直接输入地址的方式来访问的. 但通过请求的转发是可以的!
还可以在 web.xml 文件中配置错误页面:
<error-page>
<!-- 指定出错的代码: 404 没有指定的资源, 500 内部错误. -->
<error-code>404</error-code>
<!-- 指定响应页面的位置 -->
<location>/WEB-INF/error.jsp</location>
</error-page>
<error-page>
<!-- 指定异常的类型 -->
<exception-type>java.lang.ArithmeticException</exception-type>
<location>/WEB-INF/error.jsp</location>
</error-page>
contentType: 指定当前 JSP 页面的响应类型。实际调用的是
response.setContentType("text/html; charset=UTF-8");
通常情况下, 对于 JSP 页面而言其取值均为text/html; charset=UTF-8
。charset
指定返回的页面的字符编码是什么,通常取值为 UTF-8pageEncoding: 指定当前 JSP 页面的字符编码. 通常情况下该值和 contentType 中的 charset 一致.
isELIgnored: 指定当前 JSP 页面是否可以使用 EL 表达式. 通常取值为 false.
include指令
include指令简述
include指令用于通知JSP引擎在翻译当前JSP页面时将其他文件中的内容合并进当前JSP页面转换成的Servlet源文件中,这种在源文件级别进行引入的方式称之为静态引入,当前JSP页面与静态引入的页面紧密结合为一个Servlet。
语法:
<%@ include file="relativeURL"%>
其中的file属性用于指定被引入文件的相对路径。
include指令细节
被引入的文件必须遵循JSP语法,其中的内容可以包含静态HTML、JSP脚本元素、JSP指令和JSP行为元素等普通JSP页面所具有的一切内容。
在将JSP文件翻译成Servlet源文件时,JSP引擎会将当前JSP页面与被引入的文件中的指令元素合并起来(设置pageEncoding属性的page指令除外)。因此page指令的其他属性不能在这两个页面中有不同的设置值。
除了指令元素之外,被引入的文件中的其他元素都被转换成相应的Java源代码,然后插入进当前JSP页面所翻译成的Servlet源文件中,插入位置与include指令在当前JSP页面中的位置保持一致
引入文件与被引入文件是在被JSP引擎翻译成Servlet的过程中进行合并,而不是先合并源文件后再对合并的结果进行翻译。
file属性的设置值必须使用相对路径,如果以
/
开头,表示相对于当前WEB应用程序的根目录(注意不是站点根目录),否则,表示相对于当前文件。
举例
假设myweb应用程序的根目录下有一个a.jsp文件,其一般的访问路径形式为:
http://localhost:8080/myweb/a.jsp
在a.jsp页面中声明了一个字符串str,并使用了如下语句引入b.jspf文件:
<%
String str = "abc";
%>
<%@ include file=“b.jspf”%>
则在b.jsp中可以直接使用:
<%= str %>
JSP标签
概念
JSP还提供了一种称之为Action的元素,在JSP页面中使用Action元素可以完成各种通用的JSP页面功能,也可以实现一些处理复杂业务逻辑的专用功能。
Action元素采用XML元素的语法格式,即每个Action元素在JSP页面中都以XML标签的形式出现。
JSP规范中定义了一些标准的Action元素,这些元素的标签名都以jsp作为前缀,并且全部采用小写,例如,<jsp:include>
、<jsp:forward>
等等。
jsp:include标签
<jsp:include>
标签用于把另外一个资源的输出内容插入进当前JSP页面的输出内容之中,这种在JSP页面执行时的引入方式称之为动态引入。
语法:
<jsp:include page="relativeURL | <%=expression%>" flush="true|false" />
page属性用于指定被引入资源的相对路径,它也可以通过执行一个表达式来获得。
flush属性指定在插入其他资源的输出内容时,是否先将当前JSP页面的已输出的内容刷新到客户端。
jsp:include标签与include指令的比较
- 独立性
<jsp:include>
标签是在当前JSP页面的执行期间插入被引入资源的输出内容,当前JSP页面与被动态引入的资源是两个彼此独立的执行实体,被动态引入的资源必须是一个能独立被WEB容器调用和执行的资源。
而include指令只能引入遵循JSP格式的文件,被引入文件与当前JSP文件共同合被翻译成一个Servlet的源文件。
- 遵循HTML语法结构
最终的输出结果内容应遵循HTML语法结构。
- 执行期和翻译期
<jsp:include>
标签在JSP页面的执行期间才被调用,因此不会影响两个页面的编译。include指令是在JSP引擎翻译JSP页面的过程中被解释处理的,所以它对JSP引擎翻译JSP页面的过程起作用。
假设myweb应用程序的根目录下有一个a.jsp文件,其一般的访问路径形式为:
http://localhost:8080/myweb/a.jsp
在a.jsp页面中使用了如下语句引入b.jsp文件:
<jsp:include page=“b.jsp" />
jsp:forward标签
当使用<jsp:include>
和<jsp:forward>
标签引入或将请求转发给的资源是一个能动态执行的程序时,例如Servlet和JSP页面。还可以使用<jsp:param>
标签向这个程序传递参数信息。这样,在转发的页面中可以通过request.getParameter(String parameterName)
获取到传入的请求参数
语法1:
<jsp:include page="relativeURL | <%=expression%>">
<jsp:param name="parameterName" value="parameterValue|<%= expression %>"/>
</jsp:include>
语法2:
<jsp:forward page="relativeURL | <%=expression%>">
<jsp:param name="parameterName" value="parameterValue|<%= expression %>"/>
</jsp:include>
<jsp:param>
标签的name属性用于指定参数名,value属性用于指定参数值。在<jsp:include>
和<jsp:forward>
标签中可以使用多个<jsp:param>
标签来传递多个参数。
jsp:param标签
就是上面的作用
中文乱码
第一个层次
在JSP页面上输入中文,请求页面后不出现乱码:
要保证三个一致:在page指令中 contentType 中的 charset 和 pageEncoding 的编码一致,都支持中文,建议是 UTF-8 ,并且保证浏览器显式的字符编码也和请求的JSP页面编码一致。
第二个层次
获取中文参数值,请求页面不出现乱码,例如:
username: <%= request.getParameter("username") %>
有时我们会在请求页面中获取中文参数的时候得到乱码。
对于POST请求
我们要通过下面的语句来进行处理:
<%
request.setCharacterEncoding("UTF-8");
%>
username: <%= request.getParameter("username") %>
这样我们就可以接收到中文的的参数。
request.setCharacterEncoding()
:指定从request或获取的参数使用的字符集。这个方法只对POST方法有效,对GET请求无效。并且必须在getParameter()
读取请求参数之前调用,否则无效。因为在执行第一个getParameter()的时候,java将会按照编码分析所有的提交内容,而后续的getParameter()不再进行分析,所以setCharacterEncoding()无效。
对于GET请求
get提交时,如果含有中文,就会出现类似于“???”的乱码问题
这种现象的原因是Tomcat对get和post两种提交方式的处理方法不一样造成的。Tomcat对于GET请求并不会考虑使用request.setCharacterEncoding
方法设置的编码,而会永远使用iso-8859-1
编码。
解决办法如下:
- 配置tomcat的配置文件server.xml里这句:
<Connector URIEncoding="GB2312"
port="8080" maxHttpHeaderSize="8192"
maxThreads="150" minSpareThreads="25" maxSpareThreads="75"
enableLookups="false" redirectPort="8443" acceptCount="100"
connectionTimeout="20000" disableUploadTimeout="true" />
加上URIEncoding="UTF-8"
2. 使用
String name=new String(request.getParameter("name").getBytes("ISO-8859-1"),"UTF-8");
先解码,再编码
3. 设置Tomcat的config文件夹下的server.xml文件中添加useBodyEncodingForURI参数为true
<Connector port="8080" protocol="HTTP/1.1"
connectionTimeout="20000"
redirectPort="8443" useBodyEncodingForURI="true"/>
这样我们就可以通过
<%
request.setCharacterEncoding("UTF-8");
%>
来设置字符集。推荐使用这种方法。