XML Tag Library
The JSTL XML tag set is listed in Table 6-4.
Table 6-4 XML Tags Area Function Tags Prefix XML Coreout
parse
set
x
Flow controlchoose
when
otherwise
forEach
if
Transformationtransform
param
A key aspect of dealing with XML documents is to be able to easily access their content. XPath (see
http://java.sun.com/xml/jaxp
), a W3C recommendation since 1999, provides an easy notation for specifying and selecting parts of an XML document. In the JSTL XML tags, XPath expressions specified using theselect
attribute are used to select portions of XML data streams. Note that XPath is used as a local expression language only for theselect
attribute. This means that values specified forselect
attributes are evaluated using the XPath expression language but that values for all other attributes are evaluated using the rules associated with the JSP 2.0 expression language.In addition to the standard XPath syntax, the JSTL XPath engine supports the following scopes to access web application data within an XPath expression:
These scopes are defined in exactly the same way as their counterparts in the JSP expression language discussed in Implicit Objects (page 125). Table 6-5 shows some examples of using the scopes.
The XML tags are illustrated in another version (
bookstore5
) of the Duke's Bookstore application. This version replaces the database with an XML representation of the bookstore database, which is retrieved from another web application. The directions for building and deploying this version of the application are in The Example JSP Document (page 150).Core Tags
The core XML tags provide basic functionality to easily parse and access XML data.
The
parse
tag parses an XML document and saves the resulting object in the EL variable specified by attributevar
. Inbookstore5
, the XML document is parsed and saved to a context attribute inparsebooks.jsp
, which is included by all JSP pages that need access to the document:<c:if test="${applicationScope:booklist == null}" > <c:import url="${initParam.booksURL}" var="xml" /> <x:parse doc="${xml}" var="booklist" scope="application" /> </c:if>The
set
andout
tags parallel the behavior described in Variable Support Tags and Miscellaneous Tags for the XPath local expression language. Theset
tag evaluates an XPath expression and sets the result into a JSP EL variable specified by attributevar
. Theout
tag evaluates an XPath expression on the current context node and outputs the result of the evaluation to the currentJspWriter
object.The JSP page
bookdetails.jsp
selects a book element whoseid
attribute matches the request parameterbookId
and sets theabook
attribute. Theout
tag then selects the book'stitle
element and outputs the result.<x:set var="abook" select="$applicationScope.booklist/ books/book[@id=$param:bookId]" /> <h2><x:out select="$abook/title"/></h2>As you have just seen,
x:set
stores an internal XML representation of a node retrieved using an XPath expression; it doesn't convert the selected node into aString
and store it. Thus,x:set
is primarily useful for storing parts of documents for later retrieval.If you want to store a
String
, you must usex:out
withinc:set
. Thex:out
tag converts the node to aString
, andc:set
then stores theString
as an EL variable. For example,bookdetails.jsp
stores an EL variable containing a book price, which is later provided as the value of afmt
tag, as follows:<c:set var="price"> <x:out select="$abook/price"/> </c:set> <h4><fmt:message key="ItemPrice"/>: <fmt:formatNumber value="${price}" type="currency"/>The other option, which is more direct but requires that the user have more knowledge of XPath, is to coerce the node to a
String
manually by using XPath'sstring
function.Flow Control Tags
The XML flow control tags parallel the behavior described in Flow Control Tags for XML data streams.
The JSP page
bookcatalog.jsp
uses theforEach
tag to display all the books contained inbooklist
as follows:<x:forEach var="book" select="$applicationScope:booklist/books/*"> <tr> <c:set var="bookId"> <x:out select="$book/@id"/> </c:set>= <td bgcolor="#ffffaa"> <c:url var="url" value="/bookdetails" > <c:param name="bookId" value="${bookId}" /> <c:param name="Clear" value="0" /> </c:url> <a href="${url}"> <strong><x:out select="$book/title"/> </strong></a></td> <td bgcolor="#ffffaa" rowspan=2> <c:set var="price"> <x:out select="$book/price"/> </c:set> <fmt:formatNumber value="${price}" type="currency"/> </td> <td bgcolor="#ffffaa" rowspan=2> <c:url var="url" value="/catalog" > <c:param name="Add" value="${bookId}" /> </c:url> <p><strong><a href="${url}"> <fmt:message key="CartAdd"/> </a> </td> </tr> <tr> <td bgcolor="#ffffff"> <fmt:message key="By"/> <em> <x:out select="$book/firstname"/> <x:out select="$book/surname"/></em></td></tr> </x:forEach>Transformation Tags
The
transform
tag applies a transformation, specified by an XSLT stylesheet set by the attributexslt
, to an XML document, specified by the attributedoc
. If thedoc
attribute is not specified, the input XML document is read from the tag's body content.The
param
subtag can be used along withtransform
to set transformation parameters. The attributesname
andvalue
are used to specify the parameter. Thevalue
attribute is optional. If it is not specified, the value is retrieved from the tag's body.