JSTL Tutorial – JSP – Standard Tag Library (JSTL) Tutorial

JSTL stands for JAVA Standard Tag Library. It provides basic functionality for JSP. Based on the functionality JSTL provides, tags can be classified into following categories.
1. Core Tags
2. Formatting Tags
3. Functions
4. SQL Tags.
5. XML Tags.
The JavaServer Pages Standard Tag Library (JSTL) is a collection of useful JSP tags which encapsulates core functionality common to many JSP applications.

JSTL has support for common, structural tasks such as iteration and conditionals, tags for manipulating XML documents, internationalization tags, and SQL tags. It also provides a framework for integrating existing custom tags with JSTL tags.

Install JSTL Library:
If you are using Apache Tomcat container then follow the following two simple steps:

  • Download the binary distribution from Apache Standard Taglib and unpack the compressed file.
  • To use the Standard Taglib from its Jakarta Taglibs distribution, simply copy the JAR files in the distribution’s ‘lib’ directory to your application’s webappsROOTWEB-INFlib directory.

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

General syntax for including JSTL Tags into JSP are:

<!-- Include Core Tags -->
     <%@ taglib prefix="c" uri="http://java.sun.com/jsp/jstl/core" %>    
     
     <!-- Include Functions Tags -->
     <%@ taglib prefix="fn" uri="http://java.sun.com/jsp/jstl/functions" %>
     
     <!-- Include Format Tags -->
     <%@ taglib prefix="fmt" uri="http://java.sun.com/jsp/jstl/format" %>
     
     <!-- Include SQL Tags -->
     <%@ taglib prefix="sql" uri="http://java.sun.com/jsp/jstl/sql" %>

Core Tags:
The core group of tags are the most frequently used JSTL tags. Following is the syntax to include JSTL Core library in your JSP:

<%@ taglib prefix="c" 
           uri="http://java.sun.com/jsp/jstl/core" %>

There are following Core JSTL Tags:

<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 evalutes 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 <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 delimiters.

<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 tags:
The JSTL formatting tags are used to format and display text, the date, the time, and numbers for internationalized Web sites. Following is the syntax to include Formatting library in your JSP:

<%@ taglib prefix="fmt" 
           uri="http://java.sun.com/jsp/jstl/fmt" %>

Following is the list of Formatting JSTL Tags:
 
<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>   
To display an internationalized message.

<fmt:requestEncoding>   
Sets the request character encoding

SQL tags:
The JSTL SQL tag library provides tags for interacting with relational databases (RDBMSs) such as Oracle, mySQL, or Microsoft SQL Server.

Following is the syntax to include JSTL SQL library in your JSP:

<%@ taglib prefix="sql" 
           uri="http://java.sun.com/jsp/jstl/sql" %>

Following is the list of SQL JSTL Tags:

<sql:setDataSource>
Creates a simple DataSource suitable only for prototyping

<sql:query>
Executes 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 statements as one transaction.

XML tags:
The JSTL XML tags provide a JSP-centric way of creating and manipulating XML documents. Following is the syntax to include JSTL XML library in your JSP.

The JSTL XML tag library has custom tags for interacting with XML data. This includes parsing XML, transforming XML data, and flow control based on XPath expressions.

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

Before you proceed with the examples, you would need to copy following two XML and XPath related libraries into your <Tomcat Installation Directory>lib:

Following is the list of XML JSTL Tags:

<x:out>   
Like <%= … >, but for XPath expressions.

<x:parse>   
Use to parse 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>

<x:when >   
Subtag of <choose> that includes its body if its expression evalutes to ‘true’

<x:otherwise >  
Subtag of <choose> that follows <when> tags and runs only if all of the prior conditions evaluated to ‘false’

<x:transform >  
Applies an XSL transformation on a XML document

<x:param >   
Use along with the transform tag to set a parameter in the XSLT stylesheet

JSTL Functions:
JSTL includes a number of standard functions, most of which are common string manipulation functions. Following is the syntax to include JSTL Functions library in your JSP:

<%@ taglib prefix="fn" 
           uri="http://java.sun.com/jsp/jstl/functions" %>

Following is the list of JSTL Functions:

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 could 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:substringBefore()   
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.

Next