The Life Cycle of a JSP Page
A JSP page services requests as a servlet. Thus, the life cycle and many of the capabilities of JSP pages (in particular the dynamic aspects) are determined by Java Servlet technology. You will notice that many sections in this chapter refer to classes and methods described in Chapter 3.
When a request is mapped to a JSP page, the web container first checks whether the JSP page's servlet is older than the JSP page. If the servlet is older, the web container translates the JSP page into a servlet class and compiles the class. During development, one of the advantages of JSP pages over servlets is that the build process is performed automatically.
Translation and Compilation
During the translation phase each type of data in a JSP page is treated differently. Static data is transformed into code that will emit the data into the response stream. JSP elements are treated as follows:
- Directives are used to control how the web container translates and executes the JSP page.
- Scripting elements are inserted into the JSP page's servlet class. See Chapter 8 for details.
- Expression language expressions are passed as parameters to calls to the JSP expression evaluator.
jsp:[set|get]Propertyelements are converted into method calls to JavaBeans components.
jsp:[include|forward] elements are converted into invocations of the Java Servlet API.- The
jsp:pluginelement is converted into browser-specific markup for activating an applet.- Custom tags are converted into calls to the tag handler that implements the custom tag.
In the Application Server, the source for the servlet created from a JSP page named
pageNameis in this file:For example, the source for the index page (named
index.jsp) for thedatelocalization example discussed at the beginning of the chapter would be namedBoth the translation and the compilation phases can yield errors that are observed only when the page is requested for the first time. If an error is encountered during either phase, the server will return
JasperExceptionand a message that includes the name of the JSP page and the line where the error occurred.After the page has been translated and compiled, the JSP page's servlet (for the most part) follows the servlet life cycle described in Servlet Life Cycle (page 61):
If the container needs to remove the JSP page's servlet, it calls the
jspDestroymethod.Execution
You can control various JSP page execution parameters by using
pagedirectives. The directives that pertain to buffering output and handling errors are discussed here. Other directives are covered in the context of specific page-authoring tasks throughout the chapter.Buffering
When a JSP page is executed, output written to the response object is automatically buffered. You can set the size of the buffer using the following page directive:
A larger buffer allows more content to be written before anything is actually sent back to the client, thus providing the JSP page with more time to set appropriate status codes and headers or to forward to another web resource. A smaller buffer decreases server memory load and allows the client to start receiving data more quickly.
Handling Errors
Any number of exceptions can arise when a JSP page is executed. To specify that the web container should forward control to an error page if an exception occurs, include the following
pagedirective at the beginning of your JSP page:The Duke's Bookstore application page
preludeerrorpage.jspfcontains the directiveThe following page directive at the beginning of
errorpage.jspindicates that it is serving as an error pageThis directive makes an object of type
javax.servlet.jsp.ErrorDataavailable to the error page so that you can retrieve, interpret, and possibly display information about the cause of the exception in the error page. You access the error data object in an EL (see Unified Expression Language) expression via the page context. Thus,${pageContext.errorData.statusCode}is used to retrieve the status code, and${pageContext.errorData.throwable}retrieves the exception. You can retrieve the cause of the exception using this expression:For example, the error page for Duke's Bookstore is as follows:
<%@ page isErrorPage="true" %> <%@ taglib uri="http://java.sun.com/jsp/jstl/core" prefix="c" %> <%@ taglib uri="http://java.sun.com/jsp/jstl/fmt" prefix="fmt" %> <html> <head> <title><fmt:message key="ServerError"/></title> </head> <body bgcolor="white"> <h3> <fmt:message key="ServerError"/> </h3> <p> : ${pageContext.errorData.throwable.cause} </body> </html>
Note: You can also define error pages for the WAR that contains a JSP page. If error pages are defined for both the WAR and a JSP page, the JSP page's error page takes precedence.