JSTL
JSTL標籤庫(Java Server Pages Standard Tag Library)
JSTL是由Apache的Jakarta小組負責維護的,它是一個不斷完善的開放源代碼的JSP標準標籤庫,JSTL包含標籤庫和EL表達式語言兩部分。
- EL表達式
- EL禁/啓用
<%@ page isELIgnored="true"%> 表示是否禁用EL語言,TRUE表示禁止.FALSE表示不禁止
- EL中的隱式對象
- ${param.name}
- ${paramVales.name}
- cookie
JSTL並沒有提供設定cookie的動作,
例:要取得cookie中有一個設定名稱爲userCountry的值,可以使用${cookie.userCountry}來取得它。
- header和headerVales
header 儲存用戶瀏覽器和服務端用來溝通的數據
例:要取得用戶瀏覽器的版本,可以使用${header["User-Agent"]}。
另外在鮮少機會下,有可能同一標頭名稱擁有不同的值,此時必須改爲使用headerValues 來取得這些值。
- initParam
initParam取得設定web站點的環境參數(Context)
例:一般的方法String userid = (String)application.getInitParameter("userid");
可以使用 ${initParam.userid}來取得名稱爲userid
- pageContext
pageContext 取得其他有關用戶要求或頁面的詳細信息。 ${pageContext.request.queryString} 取得請求的參數字符串${pageContext.request.requestURL} 取得請求的URL,但不包括請求之參數字符串
${pageContext.request.contextPath} 服務的web application 的名稱
${pageContext.request.method} 取得HTTP 的方法(GET、POST)
${pageContext.request.protocol} 取得使用的協議(HTTP/1.1、HTTP/1.0)
${pageContext.request.remoteUser} 取得用戶名稱${pageContext.request.remoteAddr } 取得用戶的IP 地址${pageContext.session.new} 判斷session 是否爲新的${pageContext.session.id} 取得session 的ID${pageContext.servletContext.serverInfo} 取得主機端的服務信息
- JSTL核心標籤庫包括表達式標籤、流程控制標籤、循環標籤和URL操作標籤4種標籤
- JSTL標籤簡介
JSTL標籤主要包含核心標籤庫、格式標籤庫、SQL標籤庫、XML標籤庫和函數標籤庫共5種標籤庫。
在使用JSTL標籤之前必須在JSP頁面的首行使用<%@ talib%>指令定義標籤庫的位置和訪問前綴,(jstl 1.1)各個標籤庫的定義如下:
核心標籤庫 支持JSP中的一些基本的操作;
<%@taglib prefix="c" uri="http://java.sun.com/jsp/jstl/core"%>
格式標籤庫 I18N capable formatting支持對JSP頁面的國際化
<%@taglib prefix="fmt" uri="http://java.sun.com/jsp/jstl/fmt"%>
SQL標籤庫 Database access (SQL)支持JSP對數據庫的操作
<%@taglib prefix="sql" uri="http://java.sun.com/jsp/jstl/sql"%>
XML標籤庫 XML processing支持XML文檔的處理
<%@taglib prefix="xml" uri="http://java.sun.com/jsp/jstl/xml"%>
函數標籤庫
<%@taglib prefix="fn" uri="http://java.sun.com/jsp/jstl/functions"%>
(J2EE1.4)也可寫成:
<%@ taglib uri="/WEB-INF/c.tld" prefix="c" %>
<%@ taglib uri="/WEB-INF/fmt.tld" prefix="fmt" %>
<%@ taglib uri="/WEB-INF/fn.tld" prefix="fn" %>
<%@ taglib uri="/WEB-INF/x.tld" prefix="x" %>
<%@ taglib uri="/WEB-INF/sql.tld" prefix="sql" %>
JSTL是一個不斷完善的開放源代碼的JSP標籤庫,是由apache的jakarta小組來維護的。JSTL只能運行在支持JSP1.2和Servlet2.3規範的容器上,如tomcat 4.x。但是在即將推出的JSP 2.0中是作爲標準支持的。
- JSTL的優點
在應用程序服務器之間提供了一致的接口,最大程序地提高了WEB應用在各應用服務器之間的移植。
2、 簡化了JSP和WEB應用程序的開發。
3、以一種統一的方式減少了JSP中的scriptlet代碼數量,可以達到沒有任何scriptlet代碼的程序。在公司的項目中是不允許有任何的scriptlet代碼出現在JSP中。
- JSTL標籤使用
- Core標籤庫
- 通用標籤
<c:out>
<c:out>標籤用於在JSP中顯示數據,它有如下屬性 屬 性 描 述是否必須 缺省值
value 輸出的信息,可以是EL表達式或常量 是 無
default value爲空時顯示信息 否 無
escapeXml 爲true則避開特殊的xml字符集 否 true
例子: 您的用戶名是: <c:out value=”${user.username}” default=”guest”/>
顯示用戶的用戶名,如爲空則顯示guest
<c:out value="${sessionScope.username}"/>
指定從session中獲取username的值顯示;
<c:out value="${username}" />
顯示username的值,默認是從request(page)中取,如果request中沒有名爲username的對象則從session中取,session中沒有則從application(servletContext)中取,如果沒有取到任何值則不顯示。
<c:set>
<c:set>標籤用於保存數據,它有如下屬性 屬 性 描 述 是否必須缺省值
value 要保存的信息,可以是EL表達式或常量 否
target 需要修改屬性的變量名,一般爲javabean的實例 否 無
property 需要修改的javabean屬性 否 無
var 需要保存信息的變量 否 無
scope 保存信息的變量的範圍 否 page
如果指定了target屬性, 那麼property屬性也必須指定。
例子: <c:set value="${test.testinfo}" var="test2" scope=”session” />
將test.testinfo的值保存到session的test2中,其中test是一個javabean的實例,testinfo是test對象的屬性。
<c:set target="${cust.address}" property="city" value="${city}"/>
將對象cust.address的city屬性值保存到變量city中
<c:remove>
<c:remove>標籤用於刪除數據,它有如下屬性 屬 性 描 述 是否必須缺省值
var 要刪除的變量 是 無
scope 被刪除變量的範圍 否所有範圍,包括page、request、session、application等
例子: <c:remove var="test2" scope="session"/>
從session中刪除test2變量。
2、 流控制標籤
<c:if>
<c:if>標籤有如下屬性 屬 性 描 述 是否必須 缺省值
test 需要評價的條件,相當於if (...){}語句中的條件 是 無
var 要求保存條件結果的變量名 否 無
scope 保存條件結果的變量範圍 否 page
算術運算符 + 、 - 、 * 、 / (或 div )和 % (或 mod )
關係運算符 == (或 eq )、 != (或 ne )、 < (或 lt )、 > (或 gt )、 <= (或 le )和 >= (或 ge )
邏輯運算符 && (或 and )、 || (或 or )和 ! (或 not )
驗證運算符 empty
s
<c:choose>
這個標籤不接受任何屬性
<c:when>
<c:when>標籤有以下屬性 屬 性 描 述 是否必須 缺省值
test 需要評價的條件 是 無
<c:otherwise>
這個標籤同樣不接受任何屬性
例子: <c:if test="${user.wealthy}">
user.wealthy is true.
</c:if>
如果user.wealthy值true,則顯示user.wealthy is true.
<c:choose>
<c:when test="${user.generous}">
user.generous is true.
</c:when>
<c:when test="${user.stingy}">
user.stingy is true.
</c:when>
<c:otherwise>
user.generous and user.stingy are false.
</c:otherwise>
</c:choose>
只有當條件user.generous返回值是true時,才顯示user.generous is true.
只有當條件user.stingy返回值是true時,才顯示user.stingy is true.
其它所有的情況(即user.generous和user.stingy的值都不爲true)全部顯示user.generous and user.stingy are false.
由於JSTL沒有形如if (){…} else {…}的條件語句,所以這種形式的語句只能用<c:choose>、<c:when>和<c:otherwise>標籤共同來完成了。
3、 循環控制標籤
<c:forEach>
<c:forEach>標籤用於通用數據,它有以下屬性 屬 性 描 述 是否必須 缺省值
items 進行循環的項目 否 無
begin 開始條件 否 0
end 結束條件 否 集合中的最後一個項目
step 步長 否 1
var 代表當前項目的變量名 否 無
varStatus 顯示循環狀態的變量 否 無
current getCurrent() 當前這次迭代的(集合中的)項
index getIndex() 當前這次迭代從 0 開始的迭代索引
count getCount() 當前這次迭代從 1 開始的迭代計數
first isFirst() 用來表明當前這輪迭代是否爲第一次迭代的標誌
last isLast() 用來表明當前這輪迭代是否爲最後一次迭代的標誌
begin getBegin() begin 屬性值
end getEnd() end 屬性值
step getStep() step 屬性值
例子: <c:forEach items="${vectors}" var="vector">
<c:out value="${vector}"/>
</c:forEach>
相當於java語句 for (int i=0;i<vectors.size();i++) {
out.println(vectors.get(i));
}
在這裏vectors是一個java.util.Vector對象,裏面存放的是String數據,vector是當前循環條件下String對象。實際上這裏的vectors可以是任何實現了java.util. Collection接口的對象。
<c:forEach begin="0" end="100" var="i" step="1">
count=<c:out value="${i}"/><br>
</c:forEach>
輸出:
count=0
...
count=100
<c:forTokens>
<c:forTokens>標籤有以下屬性 屬 性 描 述 是否必須 缺省值
items 進行循環的項目 是 無
delims 分割符 是 無
begin 開始條件 否 0
end 結束條件 否 集合中的最後一個項目
step 步長 否 1
var 代表當前項目的變量名 否 無
varStatus 顯示循環狀態的變量 否 無
例子
<c:forTokens items="a:b:c:d" delims=":" var="token">
<c:out value="${token}"/>
</c:forTokens>
這個標籤的使用相當於java.util.StringTokenizer類。在這裏將字符串a:b:c:d以:分開循環四次,token是循環到當前分割到的字符串。
4.導入文件和URL
JSTL核心標籤庫支持使用<c:import>來包含文件,使用<c:url>來打印和格式化URL,使用<c:redirect>來重定向URL。
<c:import>
<c:import>標籤包含另外一個頁面代碼到當前頁,它有以下屬性 屬性 描 述 是否必須 缺省值
url 需要導入頁面的url 是 無
context /後跟本地web應用程序的名字 否 當前應用程序
charEncoding 用於導入數據的字符集 否 ISO-8859-1
var 接受導入文本的變量名 否 page
scope 接受導入文本的變量的變量範圍 否 1
varReader 用於接受導入文本的java.io.Reader變量名 否 無
varStatus 顯示循環狀態的變量 否 無
<c:url>
<c:url>標籤輸出一個url地址,它有以下屬性 屬 性 描 述 是否必須缺省值
url url地址 是 無
context /後跟本地web應用程序的名字 否 當前應用程序
charEncoding 用於導入數據的字符集 否 ISO-8859-1
var 接受處理過的url變量名,該變量存儲url 否 輸出到頁
scope 存儲url的變量名的變量範圍 否 page
例子:
<c:import url="http://www.url.com/edit.js" var="newsfeed"/>
將url http://www.url.com/edit.js包含到當前頁的當前位置,並將url保存到newsfeed變量中
<a href="<c:url _fcksavedurl=""<c:url" url="/index.jsp"/>"/>
在當前頁的當前位置輸出<a href="http://www.yourname.com/index.jsp"/>,http://www.yourname.com是當前頁的所在的位置。
<c:redirect>
<c:redirect>標籤將請求重新定向到另外一個頁面,它有以下屬性 屬性 描 述 是否必須 缺省值
url url地址 是 無
context /後跟本地web應用程序的名字 否 當前應用程序
例子:
<c:redirect url="http://www.yourname.com/login.jsp"/>
將請求重新定向到http://www.yourname.com/login.jsp頁,相當於response.setRedirect("http://www.yourname.com/login.jsp");
<c:param>
<c:param>標籤用來傳遞參數給一個重定向或包含頁面,它有以下屬性屬 性 描 述 是否必須 缺省值
name 在request參數中設置的變量名 是 無
value 在request參數中設置的變量值 否 無
例子:
<c:redirect url="login.jsp">
<c:param name="id" value="888"/>
</c:redirect>
將參數888以id爲名字傳遞到login.jsp頁面,相當於login.jsp?id=888
- JSTL格式標籤庫包括格式化日期和數字的標籤、讀取消息資源的標籤、國際化的標籤
格式化日期和數字的標籤:<fmt:formatNumber>
<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 環境顯示當地的貨幣格式。
- <fmt:formatNumber value="12" type="currency" pattern="$.00"/> //-- $12.00
- <fmt:formatNumber value="12" type="currency" pattern="$.0#"/> //-- $12.0
- <fmt:formatNumber value="1234567890" type="currency"/> //-- $1,234,567,890.00(那個貨幣的符號和當前web服務器的 local 設定有關)
- <fmt:formatNumber value="123456.7891" pattern="#,#00.0#"/>// -- 123,456.79
- <fmt:formatNumber value="123456.7" pattern="#,#00.0#"/> //-- 123,456.7
- <fmt:formatNumber value="123456.7" pattern="#,#00.00#"/>// -- 123,456.70
- <fmt:formatNumber value="12" type="percent" /> //-- 1,200% (type 可以是currency、 number、 和percent)。
<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 ”。
<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> 兩組標籤設定的時區來格式化最後的結果。
<fmt:formatDate>動作的屬性
pattern="G yyyy年MM月dd日 E" G表示公元E表示星期幾
type: 可以是time,date或both。控制是否只生成時間,只生成日期,或者時間日期都生成。
dateStyle: 可以是short, medium, long 或 full(default)。控制打印日期使用的具體格式。
timeStyle: 可以是short, medium, long 或 full(default)。控制打印時間使用的具體格式。
value: 這是一個java.util.Date 類型的值,用於生成日期和時間。
<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 中。
<fmt:setTimeZone> <fmt:timeZone>
<fmt:timeZone>標籤用於設置時區,在它的標籤體中,通過value屬性指定的時區將覆蓋JSP環境中現有的所有其他時區設置。該標籤的語法格式如下:
<fmt:timeZone value="timeZone">
body content
</fmt:timeZone>
value屬性的值是一個命名時區的字符串或者是java.util.TimeZone類的一個實例,它支持動態的值。如果value屬性的值爲null或空字符串,標籤體中的內容就使用GMT時區。
如果value屬性的值是表示時區名稱的字符串,這個字符串通過靜態方法java.util.Time Zone.getTimeZone()被解析爲java.util.TimeZone類的一個實例。
讀取消息資源的標籤:<fmt:message> <fmt:param> <fmt:bundle> <fmt:setBundle>
國際化的標籤:<fmt:setlocale> <fmt:requestEncoding>
- JSTL的XML標籤庫包括XML核心標籤庫、XML流程控制標籤、XML文件轉換
XML核心標籤庫:<x:parse> <x:out> <x:set>
XML流程控制標籤:<x:if> <x:choose> <x:when> <x:otherwise> <x:forEach>
XML文件轉換:<x:transform> <x:param>
- JSTL的SQL標籤庫包括設置數據源的標籤、SQL操作的標籤
設置數據源的標籤:
SQL操作的標籤:<sql:setDataSource> <sql:query> <sql:update> <sql:param> <sql:dateParam> <sql:transaction>
- JSTL的函數標籤庫。這個標籤庫主要用於EL表達式的字符串操作。
<fn:contains> <fn:containsIgnoreCase> <fn:startsWith> <fn:endsWith> <fn:escapeXml> <fn:indexOF> <fn:split> <fn:join> <fn:replace> <fn:trim> <fn:substring> <fn:substringAfter> <fn:substringBefore> <fn:toLowerCase> <fn:toUpperCase> <fn:length>
自定義函數:
作用:可以在el表達式中運用實現一定的功能,對el的功能進行擴展。
使用:
1)藉助taglib指令定位tld文件(函數庫位置)
2)形如${mytag:函數名(參數列表值)}
開發:
1)自定義一個類,實現相應靜態方法
2)寫一個函數庫描述文件(tld後綴)
Uri:
Function:說明調用者,java類中對應的方法的關係
<function>
<name>multiply</name>
<function-class>com.itcast.Calculator</function-class>
<function-signature>int multiply(int,int)</function-signature>
</function>
Name:對外使用時的名稱
Function-class:該方法所在類名
Function-signature:類中該方法的聲明,注意:如果引用類型,必須使用類全名
自定義函數可以嵌套:
${calculation:getParameterValue(pageContext.request,calculation:concat("user","name"))}