JSTL EL详解JSTL部分之xml、fmt、sql、fn标签库

9.4 JSTL XML processing标签库JavaWind.net Document
在企业级应用越来越依赖 XML 的今天, XML 格式的数据被作为信息交换的优先选择。 XML processing 标签库为程序设计者提供了基本的对 XML 格式文件的操作。在该标签库中的标签一共有 10 个,被分为了三类,分别是:
XML核心标签:<x:parse>、<x:out>、<x:set>。
XML流控制标签:<x:if>、<x:choose>、<x:when>、<x:otherwise>、<x:forEach>。
XML转换标签:<x:transform>、<x:param>。
由于该组标签库专注于对某一特定领域的实现,因此本书将只选择其中常见的一些标签和属性进行介绍。
9.4.1 用于解析XML文件的<x:parse>标签
<x:parse> 标签是该组标签库的核心,从其标签名就可以知道,它是作为解析 XML 文件而存在的。它的属性和描述如表 9.12 所示:
表9.12 <x:parse>标签属性和说明
属性
描述
doc
源XML的内容,该属性的内容应该为String类型或者java.io.Reader的实例,可以用xml属性来替代,但是不被推荐
var
将解析后的XML保存在该属性所指定的变量中,之后XML processing标签库中的其他标签若要取XML中的内容就可以从该变量中得到(可选)
scope
变量的作用范围(可选)
varDom
指定保存的变量为org.w3c.dom.Document接口类型(可选)
scopeDom
org.w3c.dom.Document的接口类型变量作用范围(可选)
systemId
定义一个URI,该URI将被使用到XML文件中以接入其他资源文件(可选)
filter
该属性必须为org.xml.sax.XMLFilter类的一个实例,可以使用EL表达式传入,将对XML文件做过滤得到自身需要的部分(可选)
其中, var 、 scope 和 varDom 、 scopeDom 不应该同时出现,而应该被视为两个版本来使用,二者的变量都可以被 XML processing 标签库的其他标签来使用。
<x:parse> 标签单独使用的情况很少,一般会结合 XML processing 标签库中的其他标签来一起工作。下面看一个示例。
首先给出一个简单的 XML 文件,将对该 XML 文件做解析,该 XML 文件名为 SampleXml.xml 。
<?xml version=”1.0″ encoding=”UTF-8″?>
<xml-body>
<name>RW</name>
<passWord>123456</passWord>
<age>28</age>
<books>
<book>book1</book>
<book>book2</book>
<book>book3</book>
</books>
</xml-body>
标签库的工作:
<c:import var=”xmlFile” url=”http://localhost:8080/booksamplejstl/SampleXml.xml”/>
<x:parse var=”xmlFileValue” doc=”${xmlFile}”/>
<fmt: > 标签 JavaWind.net Document
看到I18N就应该想到知识“国际化”,I18N formatting标签库就是用于在JSP页面中做国际化的动作。在该标签库中的标签一共有12个,被分为了两类,分别是:
国际化核心标签:<fmt:setLocale>、<fmt:bundle>、<fmt:setBundle>、<fmt:message>、<fmt:param>、<fmt:requestEncoding>。
格式化标签:<fmt:timeZone>、<fmt:setTimeZone>、<fmt:formatNumber>、<fmt:parseNumber>、<fmt:formatDate>、<fmt:parseDate>。
下面只选择其中常见的一些标签和属性进行介绍。
9.5.1 用于设置本地化环境的<fmt:setLocale>标签
<fmt:setLocale>标签用于设置Locale环境。它的属性和描述如表9.17所示:
表9.17 <fmt:setLocale>标签属性和说明
属性
描述
value
Locale环境的指定,可以是java.util.Locale或String类型的实例
scope
Locale环境变量的作用范围(可选)
下面看一个示例:
<fmt:setLocale value=”zh_TW”/>
表示设置本地环境为繁体中文。
9.5.2 用于资源文件绑定的<fmt:bundle>、<fmt:setBundle>标签
这两组标签用于资源配置文件的绑定,唯一不同的是<fmt:bundle>标签将资源配置文件绑定于它标签体中的显示,<fmt:setBundle>标签则允许将资源配置文件保存为一个变量,在之后的工作可以根据该变量来进行。
根据Locale环境的不同将查找不同后缀的资源配置文件,这点在国际化的任何技术上都是一致的,通常来说,这两种标签单独使用是没有意义的,它们都会与I18N formatting标签库中的其他标签配合使用。它们的属性和描述如表9.18所示:
表9.18 <fmt:bundle>、<fmt:setBundle>标签属性和说明
属性
描述
basename
资源配置文件的指定,只需要指定文件名而无须扩展名,二组标签共有的属性
var
<fmt:setBundle>独有的属性,用于保存资源配置文件为一个变量
scope
变量的作用范围
下面看一个示例
<fmt:setLocale value=”zh_CN”/>
<fmt:setBundle basename=”applicationMessage” var=”applicationBundle”/>
该示例将会查找一个名为applicationMessage_zh_CN.properties的资源配置文件,来作为显示的Resource绑定。
9.5.3 用于显示资源配置文件信息的<fmt:message>标签
用于信息显示的标签,将显示资源配置文件中定义的信息。它的属性和描述如表9.19所示:
表9.19 <fmt:message>标签属性和说明
属性
描述
key
资源配置文件的“键”指定
bundle
若使用<fmt:setBundle>保存了资源配置文件,该属性就可以从保存的资源配置文件中进行查找
var
将显示信息保存为一个变量
scope
变量的作用范围
下面看一个示例:
<fmt:setBundle basename=”applicationMessage” var=”applicationBundle”/>
<fmt:bundle basename=”applicationAllMessage”>
<fmt:message key=”userName” />
<p>
<fmt:message key=”passWord” bundle=”${applicationBundle}” />
</fmt:bundle>
该示例使用了两种资源配置文件的绑定的做法,“ applicationMessage ”资源配置文件利用<fmt:setBundle>标签被赋于了变量“ applicationBundle ”,而作为<fmt:bundle>标签定义的“ applicationAllMessage ”资源配置文件作用于其标签体内的显示。
第一个<fmt:message>标签将使用“ applicationAllMessage ”资源配置文件中“键”为“ userName ”的信息显示。
第二个<fmt:message>标签虽然被定义在<fmt:bundle>标签体内,但是它使用了bundle属性,因此将指定之前由<fmt:setBundle>标签保存的“ applicationMessage ”资源配置文件,该“键”为“ passWord ”的信息显示。
9.5.4 用于参数传递的<fmt:param>标签
<fmt:param>标签应该位于<fmt:message>标签内,将为该消息标签提供参数值。它只有一个属性value。
<fmt:param>标签有两种使用版本,一种是直接将参数值写在value属性中,另一种是将参数值写在标签体内。
9.5.6 用于为请求设置字符编码的<fmt:requestEncoding>标签
<fmt:requestEncoding>标签用于为请求设置字符编码。它只有一个属性value,在该属性中可以定义字符编码。
9.5.7 用于设定时区的<fmt:timeZone>、<fmt:setTimeZone>标签
这两组标签都用于设定一个时区。唯一不同的是<fmt:timeZone>标签将使得在其标签体内的工作可以使用该时区设置,<fmt:setBundle>标签则允许将时区设置保存为一个变量,在之后的工作可以根据该变量来进行。它们的属性和描述如表9.20所示:
表9.20 <fmt:timeZone>、<fmt:setTimeZone>标签属性和说明
属性
描述
value
时区的设置
var
<fmt:setTimeZone>独有的属性,用于保存时区为一个变量
scope
变量的作用范围
9.5.8 用于格式化数字的<fmt:formatNumber>标签
<fmt: formatNumber > 标签用于格式化数字。它的属性和描述如表9.21所示:
表9.21 <fmt:formatNumber>标签属性和说明
属性
描述
value
格式化的数字,该数值可以是String类型或java.lang.Number类型的实例
type
格式化的类型
pattern
格式化模式
var
结果保存变量
scope
变量的作用范围
maxIntegerDigits
指定格式化结果的最大值
minIntegerDigits
指定格式化结果的最小值
maxFractionDigits
指定格式化结果的最大值,带小数
minFractionDigits
指定格式化结果的最小值,带小数
<fmt:formatNumber>标签实际是对应java.util.NumberFormat类,type属性的可能值包括currency(货币)、number(数字)和percent(百分比)。
下面看一个示例。
<fmt:formatNumber value=”1000.888″ type=”currency” var=”money”/>
该结果将被保存在“ money ”变量中,将根据Locale环境显示当地的货币格式。
9.5.9 用于解析数字的<fmt:parseNumber>标签
<fmt:parseNumber>标签用于解析一个数字,并将结果作为java.lang.Number类的实例返回。<fmt:parseNumber>标签看起来和<fmt:formatNumber>标签的作用正好相反。它的属性和描述如表9.22所示:
表9.22 <fmt:parseNumber>标签属性和说明
属性
描述
value
将被解析的字符串
type
解析格式化的类型
pattern
解析格式化模式
var
结果保存变量,类型为java.lang.Number
scope
变量的作用范围
parseLocale
以本地化的形式来解析字符串,该属性的内容应为String或java.util.Locale类型的实例
下面看一个示例。
<fmt:parseNumber value=”15%” type=”percent” var=”num”/>
解析之后的结果为“ 0.15 ”。
9.5.10 用于格式化日期的<fmt:formatDate>标签
<fmt:formatDate>标签用于格式化日期。它的属性和描述如表9.23所示:
表9.23 <fmt:formatDate>标签属性和说明
属性
描述
value
格式化的日期,该属性的内容应该是java.util.Date类型的实例
type
格式化的类型
pattern
格式化模式
var
结果保存变量
scope
变量的作用范围
timeZone
指定格式化日期的时区
<fmt:formatDate>标签与<fmt:timeZone>、<fmt:setTimeZone>两组标签的关系密切。若没有指定 timeZone属性,也可以通过<fmt:timeZone>、<fmt:setTimeZone>两组标签设定的时区来格式化最后的结果。
9.5.11 用于解析日期的<fmt:parseDate>标签
<fmt:parseDate>标签用于解析一个日期,并将结果作为java.lang.Date类型的实例返回。<fmt:parseDate>标签看起来和<fmt:formatDate>标签的作用正好相反。它的属性和描述如表9.24所示:
表9.24 <fmt:parseDate>标签属性和说明
属性
描述
value
将被解析的字符串
type
解析格式化的类型
pattern
解析格式化模式
var
结果保存变量,类型为java.lang.Date
scope
变量的作用范围
parseLocale
以本地化的形式来解析字符串,该属性的内容为String或java.util.Locale类型的实例
timeZone
指定解析格式化日期的时区
<fmt:parseNumber>和<fmt:parseDate>两组标签都实现解析字符串为一个具体对象实例的工作,因此,这两组解析标签对var属性的字符串参数要求非常严格。就JSP页面的表示层前段来说,处理这种解析本不属于份内之事,因此<fmt:parseNumber>和<fmt:parseDate>两组标签应该尽量少用,替代工作的地方应该在服务器端表示层的后段,比如在Servlet中。
<sql:> 标签 JavaWind.net Document
9.6 Database access 标签库
Database access标签库中的标签用来提供在JSP页面中可以与数据库进行交互的功能,虽然它的存在对于早期纯JSP开发的应用以及小型的开发有着意义重大的贡献,但是对于MVC模型来说,它却是违反规范的。因为与数据库交互的工作本身就属于业务逻辑层的工作,所以不应该在JSP页面中出现,而是应该在模型层中进行。
对于Database access标签库本书不作重点介绍,只给出几个简单示例让读者略微了解它们的功能。
Database access标签库有以下6组标签来进行工作:<sql:setDataSource>、<sql:query>、<sql:update>、<sql:transaction>、<sql:setDataSource>、<sql:param>、<sql:dateParam>。
9.6.1 用于设置数据源的 <sql:setDataSource> 标签
<sql:setDataSource>标签用于设置数据源,下面看一个示例:
<sql:setDataSource
var=”dataSrc”
url=”jdbc:postgresql://localhost:5432/myDB”
driver=”org.postgresql.Driver”
user=”admin”
password=”1111″/>
该示例定义一个数据源并保存在“ dataSrc ”变量内。
9.6.2 用于查询的 <sql:query> 标签
<sql:query>标签用于查询数据库,它标签体内可以是一句查询SQL。下面看一个示例:
<sql:query var=”queryResults” dataSource=”${dataSrc}”>
select * from table1
</sql:query>
该示例将返回查询的结果到变量“ queryResults ”中,保存的结果是javax.servlet.jsp.jstl.sql.Result类型的实例。要取得结果集中的数据可以使用<c:forEach>循环来进行。下面看一个示例。
<c:forEach var=”row” items=”${queryResults.rows}”>
<tr>
<td>${row.userName}</td>
<td>${row.passWord}</td>
</tr>
</c:forEach>
“ rows ”是javax.servlet.jsp.jstl.sql.Result实例的变量属性之一,用来表示数据库表中的“列”集合,循环时,通过“ ${row.XXX} ”表达式可以取得每一列的数据,“ XXX ”是表中的列名。
9.6.3 用于更新的 <sql:update> 标签
<sql:update>标签用于更新数据库,它的标签体内可以是一句更新的SQL语句。其使用和<sql:query>标签没有什么不同。
9.6.4 用于事务处理的 <sql:transaction> 标签
<sql:transaction>标签用于数据库的事务处理,在该标签体内可以使用<sql:update>标签和<sql:query>标签,而<sql:transaction>标签的事务管理将作用于它们之上。
<sql:transaction>标签对于事务处理定义了read_committed、read_uncommitted、repeatable_read、serializable4个隔离级别。
9.6.5 用于事务处理的 <sql:param> 、 <sql:dateParam> 标签
这两个标签用于向SQL语句提供参数,就好像程序中预处理SQL的“ ? ”一样。<sql:param>标签传递除java.util.Date类型以外的所有相融参数,<sql:dateParam>标签则指定必须传递java.util.Date类型的参数。
<fn:> 标签 JavaWind.net Document
9.7 Functions 标签库
称呼Functions标签库为标签库,倒不如称呼其为函数库来得更容易理解些。因为Functions标签库并没有提供传统的标签来为JSP页面的工作服务,而是被用于EL表达式语句中。在JSP2.0规范下出现的Functions标签库为EL表达式语句提供了许多更为有用的功能。Functions标签库分为两大类,共16个函数。
长度函数:fn:length
字符串处理函数:fn:contains、fn:containsIgnoreCase、fn:endsWith、fn:escapeXml、fn:indexOf、fn:join、fn:replace、fn:split、fn:startsWith、fn:substring、fn:substringAfter、fn:substringBefore、fn:toLowerCase、fn:toUpperCase、fn:trim
以下是各个函数的用途和属性以及简单示例。
9.7.1 长度函数 fn:length 函数
长度函数fn:length的出现有重要的意义。在JSTL1.0中,有一个功能被忽略了,那就是对集合的长度取值。虽然java.util.Collection接口定义了size方法,但是该方法不是一个标准的JavaBean属性方法(没有get,set方法),因此,无法通过EL表达式“ ${collection.size} ”来轻松取得。
fn:length函数正是为了解决这个问题而被设计出来的。它的参数为input,将计算通过该属性传入的对象长度。该对象应该为集合类型或String类型。其返回结果是一个int类型的值。下面看一个示例。
<%ArrayList arrayList1 = new ArrayList();
arrayList1.add(“aa”);
arrayList1.add(“bb”);
arrayList1.add(“cc”);
%>
<%request.getSession().setAttribute(“arrayList1″, arrayList1);%>
${fn:length(sessionScope.arrayList1)}
假设一个ArrayList类型的实例“ arrayList1 ”,并为其添加三个字符串对象,使用fn:length函数后就可以取得返回结果为“ 3 ”。
9.7.2 判断函数 fn:contains 函数
fn:contains函数用来判断源字符串是否包含子字符串。它包括string和substring两个参数,它们都是String类型,分布表示源字符串和子字符串。其返回结果为一个boolean类型的值。下面看一个示例。
${fn:contains(“ABC”, “a”)}<br>
${fn:contains(“ABC”, “A”)}<br>
前者返回“ false ”,后者返回“ true ”。
9.7.3 fn:containsIgnoreCase函数
fn:containsIgnoreCase函数与fn:contains函数的功能差不多,唯一的区别是fn:containsIgnoreCase函数对于子字符串的包含比较将忽略大小写。它与fn:contains函数相同,包括string和substring两个参数,并返回一个boolean类型的值。下面看一个示例。
${fn:containsIgnoreCase(“ABC”, “a”)}<br>
${fn:containsIgnoreCase(“ABC”, “A”)}<br>
前者和后者都会返回“ true ”。

9.7.4 词头判断函数 fn:startsWith 函数
fn:startsWith函数用来判断源字符串是否符合一连串的特定词头。它除了包含一个string参数外,还包含一个subffx参数,表示词头字符串,同样是String类型。该函数返回一个boolean类型的值。下面看一个示例。
${fn:startsWith (“ABC”, “ab”)}<br>
${fn:startsWith (“ABC”, “AB”)}<br>
前者返回“ false ”,后者返回“ true ”。

9.7.5 词尾判断函数 fn:endsWith 函数
fn:endsWith函数用来判断源字符串是否符合一连串的特定词尾。它与fn:startsWith函数相同,包括string和subffx两个参数,并返回一个boolean类型的值。下面看一个示例。
${fn:endsWith(“ABC”, “bc”)}<br>
${fn:endsWith(“ABC”, “BC”)}<br>
前者返回“ false ”,后者返回“ true ”。

9.7.6 字符实体转换函数 fn:escapeXml 函数
fn:escapeXml函数用于将所有特殊字符转化为字符实体码。它只包含一个string参数,返回一个String类型的值。

9.7.8 字符匹配函数 fn:indexOf 函数
fn:indexOf函数用于取得子字符串与源字符串匹配的开始位置,若子字符串与源字符串中的内容没有匹配成功将返回“ -1 ”。它包括string和substring两个参数,返回结果为int类型。下面看一个示例。
${fn:indexOf(“ABCD”,”aBC”)}<br>
${fn:indexOf(“ABCD”,”BC”)}<br>
前者由于没有匹配成功,所以返回-1,后者匹配成功将返回位置的下标,为1。
9.7.9 分隔符函数 fn:join 函数
fn:join函数允许为一个字符串数组中的每一个字符串加上分隔符,并连接起来。它的参数、返回结果和描述如表9.25所示:
表9.25 fn:join函数
参数
描述
array
字符串数组。其类型必须为String[]类型
separator
分隔符。其类型必须为String类型
返回结果
返回一个String类型的值
下面看一个示例。
<% String[] stringArray = {“a”,”b”,”c”}; %>
<%request.getSession().setAttribute(“stringArray”, stringArray);%>
${fn:join(sessionScope.stringArray,”;”)}<br>
定义数组并放置到Session中,然后通过Session得到该字符串数组,使用fn:join函数并传入分隔符“ ; ”,得到的结果为“ a;b;c ”。

9.7.10 替换函数 fn:replace 函数
fn:replace函数允许为源字符串做替换的工作。它的参数、返回结果和描述如表9.26所示:
表9.26 fn:replace函数
参数
描述
inputString
源字符串。其类型必须为String类型
beforeSubstring
指定被替换字符串。其类型必须为String类型
afterSubstring
指定替换字符串。其类型必须为String类型
返回结果
返回一个String类型的值
下面看一个示例。
${fn:replace(“ABC”,”A”,”B”)}<br>
将“ ABC ”字符串替换为“ BBC ”,在“ ABC ”字符串中用“ B ”替换了“ A ”。

9.7.11 分隔符转换数组函数 fn:split 函数
fn:split函数用于将一组由分隔符分隔的字符串转换成字符串数组。它的参数、返回结果和描述如表9.27所示:
表9.27 fn:split函数
参数
描述
string
源字符串。其类型必须为String类型
delimiters
指定分隔符。其类型必须为String类型
返回结果
返回一个String[]类型的值
下面看一个示例。
${fn:split(“A,B,C”,”,”)}<br>
将“ A,B,C ”字符串转换为数组{A,B,C}。

9.7.12 字符串截取函数 fn:substring 函数
fn:substring函数用于截取字符串。它的参数、返回结果和描述如表9.28所示:
表9.28 fn:substring函数
参数
描述
string
源字符串。其类型必须为String类型
beginIndex
指定起始下标(值从0开始)。其类型必须为int类型
endIndex
指定结束下标(值从0开始)。其类型必须为int类型
返回结果
返回一个String类型的值
下面看一个示例。
${fn:substring(“ABC”,”1″,”2″)}<br>
截取结果为“ B ”。

9.7.14 起始到定位截取字符串函数 fn:substringBefore 函数
fn:substringBefore函数允许截取源字符从开始到某个字符串。它的参数和fn:substringAfter函数相同,不同的是substring表示的是结束字符串。下面看一个示例。
${fn:substringBefore(“ABCD”,”BC”)}<br>
截取的结果为“ A ”。

9.7.15 小写转换函数 fn:toLowerCase 函数
fn:toLowerCase函数允许将源字符串中的字符全部转换成小写字符。它只有一个表示源字符串的参数string,函数返回一个String类型的值。下面看一个示例。
${fn:toLowerCase(“ABCD”)}<br>
转换的结果为“ abcd ”。

9.7.16大写转换函数 fn:toUpperCase 函数
fn:toUpperCase函数允许将源字符串中的字符全部转换成大写字符。它与fn:toLowerCase函数相同,也只有一个String参数,并返回一个String类型的值。下面看一个示例。
${fn:toUpperCase(“abcd”)}<br>
转换的结果为“ ABCD ”。

9.7.17空格删除函数 fn:trim 函数
fn:trim函数将删除源字符串中结尾部分的“空格”以产生一个新的字符串。它与fn:toLowerCase函数相同,只有一个String参数,并返回一个String类型的值。下面看一个示例。
${fn:trim(“AB C “)}D<br>
转换的结果为“ AB CD ”,注意,它将只删除词尾的空格而不是全部,因此“ B ”和“ C ”之间仍然留有一个空格。本文原始URL:http://www.javawind.net/help/html/jstl_el.htm 本文链接地址: JSTL EL详解JSTL部分之xml、fmt、sql、fn标签库