JSTL support is dependent on the appserver/servletcontainer used. Some ships with JSTL, others doesn't. This is regardless of the JSP/Servlet version. For example Sun Glassfish (as being a full fledged Java EE implementation) ships with JSTL out of the box and for example Apache Tomcat (as being a simple JSP/Servlet implementation) doesn't. For them you'll need to install JSTL yourself.
It's actually pretty simple (assuming you're using Servlet 2.5 or newer):
- Download jstl-1.2.jar.
- Put/copy it in webapp's
/WEB-INF/lib
folder (which is part of webapp's default classpath).
Declare the tags in top of JSP as per this JSTL documentation (click any of the taglibs to see the declaration examples). For JSTL core it's the following:
<%@ taglib prefix="c" uri="http://java.sun.com/jsp/jstl/core" %>
That's all. If you're (still) on Servlet 2.4, then you'll need to download jstl.jar
and standard.jar
instead (which are part of JSTL 1.1). Remnant of the steps are the same (just put in classpath and declare in top of JSP).
You may notice that some poor online tutorials would suggest to extract the JAR file and clutter the webapp's web.xml
with the TLD declarations. You should never do that, this is a wrong suggestion which is caused by the change in taglib URI's during the JSTL 1.0 -> JSTL 1.1 step. Instead of updating the taglib URI's in JSP, ones decided to redefine the old taglib URI's in web.xml
and it became a myth.
JSP itself ships with only the <jsp:xxx>
tags out of the box. You can find them all in this document (which is indeed pretty old, but has not changed up to with the current JSP 2.2).