/ REFERENCE

Reference - JSP JSTL

JSTL

JavaServer Pages Standard Tag Library

Is a collection of useful JSP tags which encapsulates the core functionality common to many JSP applications

Has support for common, structural tasks such as iteration and conditionals, tags for manipulating XML documents, internationalization tags, ans SQL tags, It also provide a framework for integrating the existing custom tags with the JSTL tags

Install

Download the binary distribution from Apache Standard Taglib

Copy the JAR files in the distribution’s ‘lib’ directory to application’s webapps/ROOT/WEB-INF

To use libraries, must include a <taglib> directive at the top of each JSP that uses the library

Core Tag

Are the most commonly used JSTL tags

<%@ taglib prefix = “c” uri = http://java.sun.com/jsp/jstl/core %>
Tag Description
<c:out> Like <%= …>, but for expressions
<c:set> Sets the result of an expression evaluation in a ‘scope’
<c:remove> Removes a scoped variable(from a particular scope, if specified)
<c:catch> Catches any Throwable that occurs in its body and optionally exposes it
<c:if> Simple conditional tag which evaluates its body if the supplied condition is true
<c:choose> Simple conditional tag that establishes a context for mutually exclusive conditional operations, marked by <when> and <otherwise>
<c:when> Subtag of <choose> that includes its body if its condition evaluates to ‘true’
<c:otherwise> Subtag of <choose> that follows the <when> tags and runs only if all of the prior conditions evaluated to ‘false’
<c:import> Retrieves an absolute or relative URL and exposes its contents to either the page, a String in ‘var ’, or a Reader in ‘varReader’
<c:forEach> The basic iteration tag, accepting many different collection types and supporting subsetting and other functionality
<c:forTokens> Iterates over tokens, separated by the supplied delimeters
<c:param> Adds a parameter to a containing ‘import’ tag’s URL
<c:redirect> Redirects to a new URL
<c:url> Creates a URL with optional query parameters

Formatting Tag

Are used to format and display text, the date, the time, and numbers for internationalized Websites

<%@ taglib prefix = “fmt” uri = “http://java.sun.com/jsp/jstl/fmt %>
Tag Description
<fmt:formatNumber> To render numerical value with specific precision or format
<fmt:parseNumber> Parses the string representation of a number, currency, or percentage
<fmt:formatDate> Formats a date and/or time using the supplied styles and pattern
<fmt:parseDate> Parses the string representation of a date and/or time
<fmt:bundle> Loads a resource bundle to be used by its tag body
<fmt:setLocale> Stores the given locale in the locale configuration variable
<fmt:setBundle> Loads a resource bundle and stores it in the named scoped variable or the bundle configuration variable
<fmt:timeZone> Specifies the time zone for any time formatting or parsing actions nested in its body
<fmt:setTimeZone> Stores the given time zone in the time zone configuration variable
<fmt:message> Displays an internationalized message
<fmt:requestEncoding> Sets the request character encoding

SQL Tag

Provides tags for interacting with relational databases (RDBMSs) such as Oracle, mySQL, or MS SQL Server

<%@ taglib prefix = “sql” uri = “http://java.sun.com/jsp/jstl/sql”>
Tag Description
<sql:setDataSource> Creates a simple DataSource suitable only for prototyping
<sql:query> Exceutes the SQL query defined in its body or through the sql attribute
<sql:update> Executes the SQL update defined in its body or through the sql attribute
<sql:param> Sets a parameter in an SQL statement to the specified value
<sql:dateParam> Sets a parameter in an SQL statement to the specified java.util.Date value
<sql:transaction> Provides nested database action elements with a shared Connection, set up to execute all statement as one transaction

XML Tag

Provides a JSP-centric way of creating and manipulating the XML documents

Library has custom tags for interacting with the XML data, this includes parsing the XML, transforming the XML data, and the flow control based on the XPath expressions

<%@ taglib prefix= “x” uri = “http://java.sun.com/jsp/jstl/xml”>

Before use tags, will need to copy the XercesImpl.jar and xalen.jar into `Tomcat Installation Directory/lib-

Tag Description
<x:out> Like <%= …>, but for XPath expressions
<x:parse> Used to parse the XML data specified either via an attribute or in the tag body
<x:set> Sets a variable to the value of an XPath expression
<x:if> Evaluates a test XPath expression and if it is true, it processes its body.
If the test condition is false, the body is ignored
<x:forEach> To loop over nodes in an XML document
<x:choose> Simple conditional tag that establishes a context for mutually exclusive conditional operations marked by <when> and <otherwise> tags
<x:when> Subtag of <choose> that includes its body if its expression evaluates to ‘true’
<x:otherwise> Subtag of <choose> that follows the <when> tags and runs only if all of the prior conditions evaluates to ‘false’
<x:transform> Applies an XSL transformation on a XML document
<x:param> Used along with the transform tag to set a parameter in the XSLT stylesheet

JSTL Function

<%@ taglib prefix = “fn” uri = http://java.sun.com/jsp/jstl/functions %>
Function Description
fn:contains() Tests if an input string contains the specified substring
fn:containsIgnoreCase() Tests if an input string contains the specified substring
in a case insensitive way
fn:endsWith() Tests if an input string ends with the specified suffix
fn:escapeXml() Escapes characters that can be interpreted as XML markup
fn:indexOf() Returns the index
withing a string of the first occurrence of a specified substring
fn:join() Joins all elements of an array into a string
fn:length() Returns the number of items in a collection,
or the number of characters in a string
fn:replace() Returns a string resulting from replacing in an input string
all occurrences with a given string
fn:split() Splits a string into an array of substrings
fn:startsWith() Tests if an input string starts with the specified prefix
fn:substring() Returns a subset of a string
fn:substringAfter() Returns a subset of a string following a specific substring
fn:substirngBefore() Returns a subset of a string before a specific substring
fn:toLowerCase() Converts all of the characters of a string to lower case
fn:toUpperCase() Converts all of the characters of a string to upper case
fn:trim() Removes white spaces from both ends of a string