JavaServer Pages (JSP) is a Java technology that allows software developers to dynamically generate HTML, XML or other types of documents in response to a Web client request. The technology allows Java code and certain pre-defined actions to be embedded into static content.
The JSP syntax adds additional XML tags, called JSP actions, to be used to invoke built-in functionality. Additionally, the technology allows for the creation of JSP tag libraries that act as extensions to the standard HTML or XML tags. Tag libraries provide a platform independent way of extending the capabilities of a Web server.
JSPs are compiled into Java Servlets by a JSP compiler. A JSP compiler may generate a servlet in Java code that is then compiled by the Java compiler, or it may generate byte code for the servlet directly.
Architecturally speaking, JSP can be viewed as a high-level abstraction of servlets that is implemented as an extension of the Servlet 2.1 API. Both servlets and JSPs were originally developed by Sun Microsystems. Starting with version 1.2 of the JSP specification, JavaServer Pages have been developed under the Java Community Process. JSR 53 defines both the JSP 1.2 and Servlet 2.4 specifications and JSR 152 defines the JSP 2.0 specification. As of May 2006 the JSP 2.1 specification has been released under JSR 245 as part of Java EE 5.
A JavaServer Page may be broken down into the following pieces:
Static data is written out to the HTTP response exactly as it appears in the input file. Thus a valid JSP input would be a normal HTML page with no embedded java or actions. In that case, the same data would be sent in the response each and every time by the web server.
JSP directives control how the JSP compiler generates the servlet. The following directives are available:
| import | results in a Java import statement being inserted into the resulting file |
| contentType | specifies the content that is generated. This should be used if HTML is not used or if the character set is not the default character set. |
| errorPage | indicates the page that will be shown if an exception occurs while processing the HTTP request. |
| isErrorPage | if set to true, it indicates that this is the error page. |
| isThreadSafe | indicates if the resulting servlet is thread safe. |
<%@ page import="java.util.*" %> //example import <%@ page contentType="text/html" %> //example contentType <%@ page isErrorPage=false %> //example for non error page <%@ page isThreadSafe=true %> //example for a thread safe JSP
Note: Only the "import" page directive can be used multiple times in the same JSP.
The following scripting variables are always available:
There are three basic kinds of scripting elements that allow java code to be inserted directly into the servlet.
JSP actions are XML tags that invoke built-in web server functionality. The following actions are provided:
| Similar to a subroutine, the Java servlet temporarily hands the request and response off to the specified JavaServer Page. Control will then return to the current JSP, once the other JSP has finished. Using this, JSP code will be shared between multiple other JSPs, rather than duplicated. | |
| Can be used inside a jsp:include, jsp:forward or jsp:params block. Specifies a parameter that will be added to the request's current parameters. | |
| Used to hand off the request and response to another JSP or servlet. Control will never return to the current JSP. | |
| Older versions of Netscape Navigator and Internet Explorer used different tags to embed an applet. This action generates the browser specific tag needed to include an applet. | |
| The content to show if the browser does not support applets. | |
| Gets a property from the specified JavaBean. | |
| Sets a property in the specified JavaBean. | |
| Creates or re-uses a JavaBean available to the JSP page. |
In this forwarding example, the request is forwarded to "subpage.jsp". The request handling does not return to this page.
The plugin example illustrates a uniform way of embedding applets in a web page. Before the advent of the <OBJECT> tag, there was no common way of embedding applets. This tag is poorly designed and hopefully future specs will allow for dynamic attributes (height="${param.height}", code="${chart}", etc) and dynamic parameters. Currently, the jsp:plugin tag does not allow for dynamically called applets. For example, if you have a charting applet that requires the data points to be passed in as parameters, you can't use jsp:params unless the number of data points are constant. You can't, for example, loop through a ResultSet to create the jsp:param tags. You have to hand code each jsp:param tag. Each of those jsp:param tags however can have a dynamic name and a dynamic value.
The scope attribute can be request, page, session or application. It has the following meanings:
The example above will use a Bean Manager to create an instance of the class com.foo.MyBean and store the instance in the attribute named "myBean". The attribute will be available for the life-time of the request. It can be shared among all of the JSPs that were included or forwarded-to from the main JSP that first received the request.
In addition to the pre-defined JSP actions, developers may add their own custom actions using the JSP Tag Extension API. Developers write a Java class that implements one of the Tag interfaces and provide a tag library XML description file that specifies the tags and the java classes that implement the tags.
Consider the following JSP.
<%@ taglib uri="mytaglib.tld" prefix="myprefix" %>
...
The JSP compiler will load the mytaglib.tld XML file and see that the tag 'myaction' is implemented by the java class 'MyActionTag'. The first time the tag is used in the file, it will create an instance of 'MyActionTag'. Then (and each additional time that the tag is used), it will invoke the method doStartTag() when it encounters the starting tag. It looks at the result of the start tag, and determines how to process the body of the tag. The body is the text between the start tag and the end tag. The doStartTag() method may return one of the following:
The myaction tag above would have an implementation class that looked like something below:
public class MyActionTag extends TagSupport { //Releases all instance variables. public void release() {...} public MyActionTag() { ... } //called for the start tag public int doStartTag() { ... } //called at the end tag }
Add Body Tag description.
Internationalization in JSP is accomplished the same way as in a normal Java application, that is by using resource bundles.
The new version of the JSP specification includes new features meant to improve programmer productivity. Namely:
Sun recommends that the Model-view-controller pattern be used with the JSP files in order to split the presentation from request processing and data storage. Either regular servlets or separate JSP files are used to process the request. After the request processing has finished, control is passed to a JSP used only for creating the output. There are several platforms based on Model-view-controller pattern for web tiers (such as Struts and Spring framework).
Input JSP
<%@ page errorPage="myerror.jsp" %> <%@ page import="com.foo.bar" %> <%! int serverInstanceVariable = 1;%> ... <% int localStackBasedVariable = 1; %>
... <%= "expanded inline data " + 1 %> Resulting servlet
package jsp_servlet; import java.util.*; import java.io.*; import javax.servlet.*; import javax.servlet.http.*; import javax.servlet.jsp.*; import javax.servlet.jsp.tagext.*; import com.foo.bar; //imported as a result of <%@ page import="com.foo.bar" %> import ...
class _myserlvet implements javax.servlet.Servlet, javax.servlet.jsp.HttpJspPage { //inserted as a //result of <%! int serverInstanceVariable = 1;%> int serverInstanceVariable = 1; ...
public void _jspService( javax.servlet.http.HttpServletRequest request, javax.servlet.http.HttpServletResponse response ) throws javax.servlet.ServletException, java.io.IOException { javax.servlet.ServletConfig config = ...;//get the servlet config Object page = this; PageContext pageContext = ...;//get the page context for this request javax.servlet.jsp.JspWriter out = pageContext.getOut(); HttpSession session = request.getSession( true ); try { out.print( "\r\n" ); out.print( "
\r\n" ); ... //from <% int localStackBasedVariable = 1; %> int localStackBasedVariable = 1; ... out.print( "\r\n" ); out.print( "
\r\n" ); ... } catch ( Exception _exception ) { //clean up and redirect to error page in <%@ page errorPage="myerror.jsp" %> } } } " ); //note, toStringOrBlank() converts the expression into a string or if // the expression is null, it uses the empty string. //from <%= "expanded inline data " + 1 %> out.print( toStringOrBlank( "expanded inline data " + 1 ) ); out.print( " Publications
- JavaServer Pages, Third Edition, Hans Bergsten, O'Reilly & Associates, Inc., Sebastopol, California, 2003. ISBN 0-596-00563-6
See also
- JSTL
- Java EE
- JavaServer Faces
- Java Servlet
- SSJS
- WAR (file format)
- EAR (file format)
- JAR (file format)
- Apache Tomcat
External links
- Sun's JSP product description
- JSR 245 (JSP 2.1)
- JSR 152 (JSP 2.0)
- JSR 53 (JSP 1.2)
- Free JSP training/learning materials
Java enterprise platform | Java specification requests
JSP | JSP | JavaServer Pages | Java Server Pages | JSP | JavaServer Pages | JSP | JSP | Java Server Pages | JavaServer Pages | JavaServer Pages | JavaServer Pages | JavaServer Pages | JSP | Java Server Pages | JavaServer Pages | JSP | Java Server Pages | JSP | JSP
This article is licensed under the GNU Free Documentation License. It uses material from the
"JavaServer Pages".
Home Page • arts • business • computers • games • health • hospitals • home • kids & teens • news • physicians • recreation• reference • regional • science • shopping • society • sports • world