1 / 43

Introduction to JavaServer Pages

Introduction to JavaServer Pages. Vijayan Sugumaran Dept. of DIS Oakland University. Parts of this presentation was provided by www.coreservlets.com. The Need for JSP. With servlets, it is easy to Read form data Read HTTP request headers Set HTTP status codes and response headers

cliff
Download Presentation

Introduction to JavaServer Pages

An Image/Link below is provided (as is) to download presentation Download Policy: Content on the Website is provided to you AS IS for your information and personal use and may not be sold / licensed / shared on other websites without getting consent from its author. Content is provided to you AS IS for your information and personal use only. Download presentation by click this link. While downloading, if for some reason you are not able to download a presentation, the publisher may have deleted the file from their server. During download, if you can't get a presentation, the file might be deleted by the publisher.

E N D

Presentation Transcript


  1. Introduction to JavaServer Pages Vijayan Sugumaran Dept. of DIS Oakland University Parts of this presentation was provided by www.coreservlets.com

  2. The Need for JSP • With servlets, it is easy to • Read form data • Read HTTP request headers • Set HTTP status codes and response headers • Use cookies and session tracking • Share data among servlets • Remember data between requests • Get fun, high-paying jobs • But, it sure is a pain to • Use those println statements to generate HTML • Maintain that HTML

  3. The JSP Framework • Idea: • Use regular HTML for most of page • Mark servlet code with special tags • Entire JSP page gets translated into a servlet (once), and servlet is what actually gets invoked (for each request) • Example: • JSP • Thanks for ordering <I><%= request.getParameter("title") %></I> • URL • http://host/OrderConfirmation.jsp?title=Core+Web+Programming • Result • Thanks for ordering Core Web Programming

  4. Benefits of JSP • Although JSP technically can't do anything servlets can't do, JSP makes it easier to: • Write HTML • Read and maintain the HTML • JSP makes it possible to: • Use standard HTML tools such as HomeSite or DreamWeaver • Have different members of your team do the HTML layout than do the Java programming • JSP encourages you to • Separate the (Java) code that creates the content from the (HTML) code that presents it

  5. Advantages of JSP Over Competing Technologies • Versus ASP or ColdFusion • Better language for dynamic part • Portable to multiple servers and operating systems • Versus PHP • Better language for dynamic part • Better tool support • Versus pure servlets • More convenient to create HTML • Can use standard tools (e.g., HomeSite) • Divide and conquer • JSP programmers still need to knowservlet programming

  6. Advantages of JSP (Contd.) • Versus client-side JavaScript (in browser) • Capabilities mostly do not overlap with JSP, but • You control server, not client • Richer language • Versus server-side JavaScript (eg, LiveWire, BroadVision, JRun) • Richer language • Versus static HTML • Dynamic features • Adding dynamic features no longer"all or nothing" decision

  7. Setting Up Your Environment • Don’t have to set any CLASSPATH • Don’t have to compile your jsp page • Don’t have to use packages to avoid name conflicts • Don’t have to put JSP page in a special directory • Placed along with html documents • Some servers reserve certain parts of Web hierarchy for JSP pages. Tomcat 3 and JRun (standalone) don't. • Don’t have to use special URL to invoke JSP page • Caveats • Previous rules about CLASSPATH, install dirs, etc., still apply to regular Java classes used by a JSP page

  8. Example <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.0 Transitional//EN"> <HTML> <HEAD> <TITLE>JSP Expressions</TITLE> <META NAME="author" CONTENT="Marty Hall"> <META NAME="keywords" CONTENT="JSP,expressions,JavaServer,Pages,servlets"> <META NAME="description" CONTENT="A quick example of JSP expressions."> <LINK REL=STYLESHEET HREF="JSP-Styles.css" TYPE="text/css"> </HEAD>

  9. Example (Continued) <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>

  10. Example Result • If location was • C:\Program Files\Apache Software Foundation\Tomcat 5.0\webapps\vijay\jsp_pages • URL would behttp://localhost:8080/vijay/jsp_pages/Expressions.jsp

  11. Most Common MisunderstandingForgetting JSP is Server-Side Technology • Very common question • I can’t do such and such with HTML. Will JSP let me do it? • Why don’t this question make sense? • JSP runs entirely on server • It doesn’t change content the client (browser) can handle • Similar questions • How do I put a normal applet in a JSP page?Answer: send an <APPLET…> tag to the client • How do I put an image in a JSP page?Answer: send an <IMG …> tag to the client • How do I use JavaScript/Acrobat/Shockwave/Etc?Answer: send the appropriate HTML tags

  12. Another Common MisunderstandingTranslation/Request Time Confusion • What happens at page translation time? • JSP constructs get translated into servlet code. • What happens at request time? • Servlet code gets executed. No interpretation of JSP occurs at request time. The original JSP page is totally ignored at request time; only the servlet that resulted from it is used. • When does page translation occur? • Typically, the first time JSP page is accessed after it is modified. This should never happen to real user (developers should test all JSP pages they install). • Page translation does not occur for each request.

  13. JSP/Servlets in the Real World • ofoto.com: print and manage digital and conventional photos.

  14. JSP/Servlets in the Real World • First USA Bank: largest credit card issuer in the world; most on-line banking customers

  15. JSP/Servlets in the Real World • Delta Airlines: entire Web site, including real-time schedule info

  16. JSP/Servlets in the Real World • American Century Investments: more than 70 mutual funds, $90 billion under management, two million investors

  17. JSP/Servlets in the Real World • Excite: one of the top five Internet portals; one of the ten busiest sites on the Web

  18. Quick Summary So far… • JSP makes it easier to create and maintain HTML, while still providing full access to servlet code • JSP pages get translated into servlets • It is the servlets that run at request time • Client does not see anything JSP-related • You still need to understand servlets • Understanding how JSP really works • Servlet code called from JSP • Knowing when servlets are better than JSP • Mixing servlets and JSP • Other technologies use similar approach, but aren't as portable and don't let you use Java for the "real code"

  19. JSP Development Model • JSP developer writes a .jsp source file and stores it in the web application directory • .jsp file is no different from an ordinary html file • When the .jsp URL is invoked for the first time, the JSP container reads the .jsp file, parses its contents, and generates the source code for an equivalent java servlet • It then compiles and creates a .class file • The JSP container loads the servlet class and uses it to service the HTTP request. • Translation time – Generating the servlet source code from a .jsp file • Request time – Invoking the servlet to handle the HTTP request

  20. Components of a JSP Page • A .jsp file contains • JSP Elements • Instructions to the JSP container about what code to generate and how it should operate • These elements have specific start and end tags that identify them to the JSP compiler • Fixed Template data • Everything else that is not recognized by the JSP container • Usually HTML data, passed through unmodified • Results in HTML code that is sent to the client • Any combination of the two

  21. JSP Elements • Three types of JSP Elements • Directives • Instructions to the JSP container that describes what code should be generated • <%@ directive-name [attribute=“value” attribute=“value” ….] %> • Three standard directives • page directive • include directive • taglib directive • Scripting Elements • Lets you specify Java code that will become part of the resultant servlet • Actions • Specify existing components that should be used and otherwise control the behavior of JSP engine

  22. Uses of JSP Constructs • Scripting elements calling servlet code directly • Scripting elements calling servlet code indirectly (by means of utility classes) • Beans • Custom tags • Servlet/JSP combo (MVC), with beans and possibly custom tags SimpleApplication ComplexApplication

  23. Basic Syntax • HTML Text • <H1>Blah</H1> • Passed through to client. Really turned into servlet code that looks like • out.print("<H1>Blah</H1>"); • HTML Comments • <!-- Comment --> • Same as other HTML: passed through to client • JSP Comments • <%-- Comment --%> • Not sent to client • To get <% in output, use <\%

  24. Types of Scripting Elements • Expressions • Format: <%= expression %> • Evaluated and inserted into the servlet’s output. I.e., results in something like out.print(expression) • Scriptlets • Format: <% code %> • Inserted verbatim into the servlet’s _jspService method (called by service) • Declarations • Format: <%! code %> • Inserted verbatim into the body of the servlet class, outside of any existing methods

  25. JSP Expressions • Format • <%= Java Expression %> • Result • Expression evaluated, converted to String, and placed into HTML page at the place it occurred in JSP page • That is, expression placed in _jspService inside out.print • Examples • Current time: <%= new java.util.Date() %> • Your hostname: <%= request.getRemoteHost() %> • XML-compatible syntax • <jsp:expression>Java Expression</jsp:expression> • XML version not supported by Tomcat 3. Until JSP 1.2, servers are not required to support it. Even then, you cannot mix versions within a single page.

  26. JSP/Servlet Correspondence • Original JSP <H1>A Random Number</H1> <%= Math.random() %> • Possible resulting servlet code public void _jspService(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException { response.setContentType("text/html"); HttpSession session = request.getSession(true); JspWriter out = response.getWriter(); out.println("<H1>A Random Number</H1>"); out.println(Math.random()); ... }

  27. Example Using JSP Expressions <BODY> <H2>JSP Expressions</H2> <UL> <LI>Current time: <%= new java.util.Date() %> <LI>Your hostname: <%= request.getRemoteHost() %> <LI>The URI Requested: <%= request.getRequestURI() %> <LI>The Protocol Used: <%= request.getProtocol() %> <LI>Your session ID: <%= session.getId() %> <LI>The <CODE>testParam</CODE> form parameter: <%= request.getParameter("testParam") %> </UL> </BODY>

  28. Predefined Variables • request • The HttpServletRequest (1st argument to service/doGet) • response • The HttpServletResponse (2nd arg to service/doGet) • out • The Writer (a buffered version of type JspWriter) used to send output to the client • session • The HttpSession associated with the request (unless disabled with the session attribute of the page directive) • application • The ServletContext (for sharing data) as obtained via getServletConfig().getContext().

  29. JSP Scriptlets • Format • <% Java Code %> • Result • Code is inserted verbatim into servlet's _jspService method • Example • <% String queryData = request.getQueryString();out.println("Attached GET data: " + queryData); %> • <% response.setContentType("text/plain"); %> • XML-compatible syntax • <jsp:scriptlet>Java Code</jsp:scriptlet>

  30. JSP/Servlet Correspondence • Original JSP <%= foo() %> <% bar(); %> • Possible resulting servlet code public void _jspService(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException { response.setContentType("text/html"); HttpSession session = request.getSession(true); JspWriter out = response.getWriter(); out.println(foo()); bar(); ... }

  31. Example Using JSP Scriptlets <!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"; } %>

  32. Example Using JSP Scriptlets (Contd.) <BODY BGCOLOR="<%= bgColor %>"> <H2 ALIGN="CENTER">Color Testing</H2> <% if (hasExplicitColor) { … } else { … } %> </BODY> </HTML>

  33. JSP Scriptlets: Results

  34. JSP Declarations • Format • <%! Java Code %> • Result • Code is inserted verbatim into servlet's class definition, outside of any existing methods • Examples • <%! private int someField = 5; %> • <%! private void someMethod(...) {...} %> • XML-compatible syntax • <jsp:declaration>Java Code</jsp:declaration>

  35. JSP/Servlet Correspondence • Original JSP <H1>Some Heading</H1> <%! private String randomHeading() { return("<H2>" + Math.random() + "</H2>"); } %> <%= randomHeading() %> • (Alternative: make randomHeading a static method in a separate Java class)

  36. JSP/Servlet Correspondence • Possible resulting servlet code public class xxxx implements HttpJspPage { private String randomHeading() { return("<H2>" + Math.random() + "</H2>"); } public void _jspService(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException { response.setContentType("text/html"); HttpSession session = request.getSession(true); JspWriter out = response.getWriter(); out.println("<H1>Some Heading</H1>"); out.println(randomHeading()); ... } ... }

  37. Example Using JSP Declarations <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.0 Transitional//EN"> <HTML><HEAD><TITLE>JSP Declarations</TITLE> <LINK REL=STYLESHEET HREF="JSP-Styles.css" TYPE="text/css"> </HEAD> <BODY> <H1>JSP Declarations</H1> <%! private int accessCount = 0; %> <H2>Accesses to page since server reboot: <%= ++accessCount %> </H2> </BODY> </HTML>

  38. JSP Declarations: Result • After 15 total visits by an arbitrary number of different clients

  39. JSP Declarations: the jspInit and jspDestroy Methods • JSP pages, like regular servlets, sometimes want to use init and destroy • Problem: the servlet that gets built from the JSP page might already use init and destroy • Overriding them would cause problems. • Thus, it is illegal to use JSP declarations to declare init or destroy. • Solution: use jspInit and jspDestroy. • The auto-generated servlet is guaranteed to call these methods from init and destroy, but the standard versions of jspInit and jspDestroy are empty (placeholders for you to override).

  40. JSP Declarations & Predefined Variables • Problem • The predefined variables (request, response, out, session, etc.) are local to the _jspService method. Thus, they are not available to methods defined by JSP declarations or to methods in helper classes. What can you do about this? • Solution: pass them as arguments. E.g.<%! private void someMethod(HttpSession s) { doSomethingWith(s);} %> <% someMethod(session); %> • Note that the println method of JspWriter throws IOException • Use “throws IOException” for methods that use println

  41. Using JSP Expressions as Attribute Values • Static Value • <jsp:setProperty name="author" property="firstName"value="Marty" /> • Dynamic Value • <jsp:setProperty name="user" property="id"value=’<%= "UserID" + Math.random() %>’ />

  42. Attributes That Permit JSP Expressions • The name and value properties of jsp:setProperty • See upcoming section on beans • The page attribute of jsp:include • See upcoming section on including files and applets • The page attribute of jsp:forward • See upcoming section on integrating servlets and JSP • The value attribute of jsp:param • See upcoming section on including files and applets

  43. Summary • JSP Expressions • Format: <%= expression %> • Wrapped in out.print and inserted into _jspService • JSP Scriptlets • Format: <% code %> • Inserted verbatim into the servlet’s _jspService method • JSP Declarations • Format: <%! code %> • Inserted verbatim into the body of the servlet class • Predefined variables • request, response, out, session, application • Limit the Java code that is directly in page • Use helper classes, beans, custom tags, servlet/JSP combo

More Related