810 likes | 1.01k Views
JSP – Java Server Page. DBI – Representation and Management of Data on the Internet. What is JSP. http://java.sun.com/products/jsp A way to create dynamic web pages Based on Java Technology Large library base Platform independence Server side processing
E N D
JSP – Java Server Page DBI – Representation and Management of Data on the Internet
What is JSP • http://java.sun.com/products/jsp • A way to create dynamic web pages • Based on Java Technology • Large library base • Platform independence • Server side processing • Separates the graphical design from the dynamic content
Relationships • In servlets, • HTML code is printed from java code • In JSP pages • Java code is embadded in HTML code Template text Java HTML Java HTML
In General Lines • JSP-enabled server • picks up .jsp page • parses it • converts it to runnable form • runs it • Converts page to a Java servlet (JspPage), with your code inside the _jspService()method • compiles it • runs servlet protocol
Separating Graphical Design and Dynamic Content • Not a new idea (e.g. PHP, mod_perl, shtml, ASP) • Graphical Design and System Design are two separate and distinct specialities: • Different languages (HTML vs. Java) • Different goals • Different Training • Should be separated for optimal project management • JSP does this by allowing special Java tags in HTML
An Example <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.0 Transitional//EN"> <HTML> <HEAD> <TITLE>Hello World Example</TITLE> </HEAD> <BODY> <H2>Hello World Example</H2> <B><% out.println("Hello World"); %></B> </BODY> </HTML>
Translating and Executing JSP Pages • A JSP page is executed in a JSP container, generally installed in a Web server • Think of a “JSP container” as a JVM with suitable software installed • The underlying semantic model is that of a servlet • A typical JSP container will translate the JSP page to a Java servlet • By default, translation and compilation of a JSP page is likely to occur the first time the page is accessed
The Source Code • In Tomcat 3.2.1, you can find the generated Java and the class files in a subdirectory under tomcat_home/work.
public void _jspService(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException { request.setContentType("text/html"); HttpSession session = request.getSession(true); JspWriter out = response.getWriter(); out.println("<H1>A Random Number</H1>"); out.println(Math.random()); ... } Translation <H1>A Random Number</H1> <%= Math.random() %>
JSP Features • Standard directives guiding translation of a JSP page to a servlet • Standard actions in the form of predefined JSP tags • Script language declarations, scriptlets, and expressions for including Java (or other language) fragments that embed dynamic content • A portable tag extension mechanism, for building tag libraries—effectively extending the JSP language
More Details Writing JSP Pages
Template HTML • The HTML code that wraps the code is like a template • Created as an ordinary HTML • The dynamic parts are created on runtime and are inserted into the template
JSP Scripting Elements • JSP scripting elements let you insert Java code into the servlet that will be generated from the JSP page • There are three forms: • Expressions of the form <%=expression%> that are evaluated and inserted into the output, • Scriptlets of the form <%code%> that are inserted into the servlet's service method, and • Declarations of the form <%!code%> that are inserted into the body of the servlet class, outside of any existing methods
JSP Expressions • A JSP expression is used to insert Java values directly into the output • It has the following form: <%= Java Expression %> • The Java expression is • evaluated, • converted to a string, and • inserted into the page • This evaluation is performed at runtime (when the page is requested), and thus has full access to information about the request
Predefined Variables • The following predefined variables can be used: • request, the HttpServletRequest • response, the HttpServletResponse • session, the HttpSession associated with the request (if any) • out, the PrintWriter (a buffered version of type JspWriter) used to send output to the client
Examples • For example, the following shows the date/time that the page was requested: Current time: <%= new java.util.Date() %> • For example, the following shows the hostname: Your hostname: <%= request.getRemoteHost() %>
<HTML> <HEAD> <TITLE>JSP Expressions</TITLE> </HEAD> <BODY> <H2>JSP Expressions</H2> <UL> <LI>Current time:<%= new java.util.Date() %> <LI>Your hostname:<%= request.getRemoteHost() %> <LI>Your session ID:<%= session.getId() %> <LI>The <CODE>testParam</CODE> form parameter: <%= request.getParameter("testParam") %> </UL> </BODY> </HTML>
JSP Scriplets • JSP scriptlets let you insert arbitrary code into the servlet method that will be built to generate the page ( _jspService ) • Scriptlets have the following form: <% Java Code %> • Scriptlets have access to the same automatically defined variables as expressions
Producing Code • Scriplets produce output HTML by printing into the out variable • Example: <% String queryData = request.getQueryString(); out.println("Attached GET data: " + queryData); %>
HTML Code in Scriptlets • HTML code before and after the scriplets is converted to print methods: <% if (Math.random() < 0.5) { %> You <B>won</B> the game! <% } else { %> You <B>lost</B> the game! <% } %> if (Math.random() < 0.5) { out.println("You <B>won</B> the game!"); } else { out.println("You <B>lost</B> the game!"); }
<%= foo() %> <% bar(); %> public void_jspService(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException { request.setContentType("text/html"); HttpSession session = request.getSession(true); JspWriterout = response.getWriter(); out.println(foo()); bar(); ... }
Example of Using Scriplets (1) <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.0 Transitional//EN"> <HTML> <HEAD> <TITLE>Color Testing</TITLE> </HEAD> <% String bgColor = request.getParameter("bgColor"); boolean hasExplicitColor; if (bgColor != null) { hasExplicitColor = true; } else { hasExplicitColor = false; bgColor = "WHITE"; } %>
Example of Using Scriplets (2) <BODY BGCOLOR="<%= bgColor %>"> <H2 ALIGN="CENTER">Color Testing</H2> <% if (hasExplicitColor) { out.println("You supplied an explicit background color of "+ bgColor + "."); } else { out.println("Using default background color ” + “of WHITE. Supply the bgColor request ” + “attribute to try a standard color, “ + “an RRGGBB value, or to see if your browser” + “supports X11 color names."); } %> </BODY> </HTML>
JSP Declaration • A JSP declaration lets you define methods or fields that get inserted into the main body of the servlet class (outside of the service method processing the request) • It has the following form: <%! Java Code %> • Declarations do not produce output • They are used, for example, to define variables
Example • We want to print out the number of times the current page has been requested since the server booted (or the servlet class was changed and reloaded): <%! private int accessCount = 0; %> Accesses to page since server reboot: <%= ++accessCount %>
Predefined Variables • As we have seen before, there are variables that can be used in the code • There are eight automatically defined variables, sometimes called implicit objects • The available variables are request, response, out, session, application,config, pageContext, and page
request • This is the HttpServletRequest associated with the request • It lets you • look at the request parameters (via getParameter), • the request type (GET, POST, HEAD, etc.), and • the incoming HTTP headers (cookies, etc.)
response • This is the HttpServletResponse associated with the response to the client • The output stream is buffered, • Thus, it is legal to set HTTP status codes and response headers, even though this is not permitted in regular servlets once any output has been sent to the client
out • This is the PrintWriter used to send output to the client • However, in order to make the response object useful, this is a buffered version of PrintWriter called JspWriter • Note that you can adjust the buffer size, or even turn buffering off, through use of the buffer attribute of the page directive
session • This is the HttpSession object associated with the request • Sessions are created automatically, so this variable is bound even if there was no incoming session reference (unless session was turned off using the session attribute of the page directive)
application • This is the ServletContext as obtained via getServletConfig().getContext() • Servlets and JSP pages can hold constant data in the ServletContext object • Getting and setting attributes is with getAttribute and setAttribute • The ServletContext is shared by all the servlets in the server
config • This is the ServletConfig of the page
pageContext • JSP introduced a new class called PageContext • It encapsulate use of server-specific features like higher performance JspWriters • The idea is that, if you access the server-specific features through this class rather than directly, your code will still run on "regular" servlet/JSP engines
page • This is simply a synonym for this • page is not very useful in Java codes in JSP pages • It was created as a placeholder for the time when the scripting language could be something other than Java
JSP Directives • A JSP directive affects the overall structure of the servlet class that is created from the JSP page • It usually has the following form: <%@ directive attribute="value" %> • Multiple attribute settings for a single directive can be combined: <%@ directive attribute1="value1" attribute2="value2" ... attributeN="valueN" %>
Directives • There are three main types of directive: • page, which lets you do things like • import classes • customize the servlet superclass • include, which lets you • insert a file into the servlet class at the time the JSP file is translated into a servlet • taglib directive • indicates a library of custom tags that the page can include
The page Directive • The page directive lets you define the following attributes: • import="package.class“ <%@ page import="java.util.*" %> • contentType="MIME-Type" <%@ page contentType="text/plain" %> (it is the same as <% response.setContentType("text/plain"); %>)
More Page Directives • isThreadSafe=“true|false” • Normal servlet processing or implementing SingleThreadModel • session=“true|false” • Allowing/disallowing sessions • buffer=“sizekb|none” • specifies the buffer size for the JspWriterout • autoflush=“true|false” • Flush buffer when full or throws an exception when buffer isfull
And More Directives • extends=“package.class” • info=“message” • A message for the getServletInfo method • errorPage=“url” • Define a JSP page that handles uncaught exceptions • isErrorPage=“true|false” • language=“java”
The include Directive • This directive lets you include files at the time the JSP page is translated into a servlet • The directive looks like this: <%@ include file="relative url" %>
Writing JSP in XML • We can replace the JSP tags with XML tags that represent • Expressions • Scriptles • Declarations • Directives
<jsp:expression> Java Expression </jsp:expression> <%= Java Expression %> <jsp:scriptlet> Code Java </jsp:scriptlet> <% Code %> <jsp:declaration> Java Declaration </jsp:declaration> <%! declaration %> <jsp:directive.type Attribute = value/> <%@ directive %>
Actions • JSP actions use constructs in XML syntax to control the behavior of the servlet engine • You can • dynamically insert a file, • reuse JavaBeans components, • forward the user to another page, or • generate HTML for the Java plugin
Available Actions • Available actions include: • jsp:include - Include a file at the time the page is requested • jsp:useBean - Find or instantiate a JavaBean • jsp:setProperty - Set the property of a JavaBean • jsp:getProperty - Insert the property of a JavaBean into the output • jsp:forward - Forward the requester to a new page • jsp:plugin - Generate browser-specific code that makes an OBJECT or EMBED tag for the Java plugin
The jsp:include Action • This action lets you insert files into the page being generated • The file inserted when page is requested • The syntax looks like this: <jsp:include page="relative URL" flush="true" />
The jsp:forward Action • Forwards request to another page • Syntax: <jsp:forward page="relative URL"/> • It has a single attribute, page, which should consist of a relative URL • This could be a static value, or could be computed at request time • Examples: <jsp:forward page="/utils/errorReporter.jsp" /> <jsp:forward page="<%= someJavaExpression %>" />
Using Beans • JavaBeans are reusable software components that can be manipulated visually in a builder tool • Introspaction – analyze how the bean works • Customization – the user can customize the look of the bean • Events support • Properties support • Persistence – allowing saving the bean on a persistent mechanism and loading it