<p>Introduction to Java Servlets</p><p>Table of Contents</p><p>Introduction to Server-Side Technologies Dynamic Generation of Web Pages Basic Technology Behind Dynamic Web Pages Getting Started with Java Servlets Installing Apache Tomcat Compiling and Deploying Java Servlets in Tomcat Template Servlet Structure Hello World Servlet Handling Requests with Servlets HTTP Request Headers Handling HTML forms Bibliography Introduction to Server-Side Technologies</p><p>Dynamic Generation of Web Pages</p><p>Web-based information systems support remote access to Web pages. The Web pages served by such systems come in two flavours. Either they can be static Web pages that are stored and served as files on the server file system, or they can be generated dynamically on the server side. The dynamic Web pages may be generated as a response to a search query, database query, or purchase request submitted by a user of the system. Generally, there are few reasons for dynamic generation of Web pages [HallBrown2003]:</p><p> Web pages are based on user queries, e.g. result pages of search engines, shopping carts in online shops, and so on. The data managed by the system changes often, e.g. wheather forecast sites, news tickers, and similar. Web pages are based on data from a database system, e.g. students data from university databases, online flight reservation, etc. </p><p>There exist a number of server-side technologies for dynamic generation of Web pages. The basic server-side technology is CGI (Common Gateway Interface). It is actaully a standardized specification [CGI1995] of communication between a Web server and external programs. Thus, an external CGI program runs directly on the server side and generates a dynamic Web page. The Web server invokes the external program by passing parameters to it (e.g. user query). The generated Web page is passed back from the external CGI program to the Web server, which in turn forwards the page to the user. All the communication between the Web server and external program is carried using the standard input and output streams. The simplicity of the CGI specification and the fact that CGI programs can be written in any programming language lead to a widespread of CGI-based applications. However, CGI programs have a number of serious drwabacks. The major drawback of CGI programs is the performance issue. Since CGI programs are external programs, the operating system starts a new process for each request to a CGI program. This of course bring the performance costs. Further, there is no possibility for a CGI program to keep database connections open over a number of requests. For each request a new database connection must be established, which leads to significant performance costs in database centric applications. </p><p>Sun's answer to the CGI technology are Java servlets. Java servlets are Java programs running on the side of a Web server and producing dynamic Web pages. Similar to the CGI specification the Java Servlet Specification [JavaServlet2003] standardized how Java programs run and communicate with a Web server to produce dynamic Web pages. The result of the specification is the Java Servlet Application programming interface (API), which is a Java library with classes needed to write Java servlets that produce dynamic Web pages. The current version of the Java servlet Specification and Java Servlet API is 2.3. The version 2.4 has currently the status of a proposed draft. The reference implementation of the Java Servlet Specification is Apache Tomcat [Tomcat1999]. The version 4.1.27 of Tomcat implements the Java Servlet Specification 2.3. Actually, Tomcat is a so-called servlet engine, which is a Java program that provides an execution context for a number of Java servlets, which run within separate Java threads inside the Tomcat process. Tomcat provides all the communicational functions between servletsand Web server, as specified in the Java Servlet Specification. </p><p>Java servlets have a number od advantages over traditional CGI technologies for generating dynaimc content on the Web. These advantages include [HallBrown2003]: </p><p> Efficiency. As mentioned before, for each request for a CGI program the operating system starts a new process to handle that request. In the case of Java servlets, there is only one process, that of the servlet engine. Each Java servlet is just a thread running within the context of the servlet engine process. Of course, starting and stopping a thread costs a lot less in terms of performance than starting and stopping of an operating system process. Especially, if the execution time is small. Java servlets are also more efiicient in terms of memory usage. Thus, in the case of multiple synchronous requests for a single servlet the servlet code is loaded only once and multiple threads are started with the same code. Contrary to that for multiple requests for a CGI program, the operating system must load the code as many times as there are requests. Finally, servlets can keep track of consecutive requests, and store some internal data that help improving performance. For instance, servlets can keep database connections open and thus reduce greatly costs of establishing a connection with a database with each new request. High capability. Servlets can share their data, which makes it possible to implement database connection pools, thus greatly reducing costs of establishing database connections, not only within one servlets but among a number of servlets. Further, servlets can keep information from one request to another, making it possible to easy track user's session, cache results from previous computations, and so on. Finally, servlets can talk directly to the Web server and access its data stored in standard places. Portability. Servlets are Java programs written using a standardized API. Thus, servlets written for one platform may be easily ported to another without no need for changing them. Servlet engines are available for all major platforms and all major Web server products. Java software libraries. Since servlets are Java programs they can use the standard Java API or any other Java library available. Thus, libraries for manipulating connections with database managment systems (JDBC libraries), libraries for manipulating digital images, Java XML libraries, etc. are all accessible in Java servlets. </p><p>Basic Technology Behind Dynamic Web Pages</p><p>The Web utilizes a classical client-server architecture. Thus, a Web client sends a request over the Internet to a Web server asking it for a specific Web page. To address a Web page the client specify its Uniforme Resource Locator (URL) to the server. Communication between the client and the server is carried out by means of HyperText Transfer Protocol (HTTP). HTTP is a simple text-based protocol. An HTTP request in its simple case can consist of a single request line containing only GET keyword together with the URL of a Web page. As the answer to this simple request the server will respond by sending the requested page back to the client. </p><p>In the general case, an HTTP request consists of: </p><p> Request line, which contains an HTTP method (usually GET or POST) and a URL. GET method just retrieves the data from the server, whereas POST method implies that the client sends data to the server. A number of HTTP headers, which set properties of connection between the client and server. For example, Accept header specifies which MIME types are preferred by the client, Accept-Language header specifies which language is preferred by the client if the server has versions of the requested page in different languages, User-Agant specifies type of the client (browser), and so on. All HTTP headers are optional, except Content-Length header, which is required for POST method to specify how much data is sent from the client to the server. Content, that is data sent by the client to the server in the case of POST method. </p><p>Mostly, dynamic Web pages are generated in accordance with parameters sent by users to a Web server. For instance, to submit a search query to a search engine users type in their serach terms in an HTML form and press the submit button to send the data. HTTP utilizes two possibities to send such parameters from the client to the server: </p><p> With GET method parameters are encoded in the URL included in the request line. Parameters are submitted as key-value pairs connected with equal '=' sign. Multiple paramaters are separated with ampersand '&' sign. Spaces are encoded as plus '+' sign, and special characters are encoded as a hexidecimal value preceeded with percentage '%' sign. The encoded parameters are preceeded with a question mark '?' sign and attached to the original URL. A typical example of encoding user parameters in URL looks as follows. </p><p>Example 1. Encoding Parameters in URL</p><p> http://www.google.at/search?q=Java+Servlets&ie=UTF-8&oe=UTF- 8&hl=de&btnG=Google+Suche&meta=</p><p>With the above URL parameters for a search query are sent to the Google search engine. The parameters come in key-value pairs: q=Java Servlets, ie=UTF-8, oe=UTF-8, hl=de, btnG=Google Suche, and meta parameter has no value. </p><p>Since the length of a URL is limited to 1024 bytes this method allows only limited number of parameters to be transmitted. </p><p> With POST method parameters are sent as the content of the request. The length of the content is specified as a special Content-Length HTTP header. POST method allows sending of binary data as content, or even mixed binary and text data as content. This is very often used for uploading binary data, such as digital images, compressed files, etc. to the server. On the client side POST method is usually applied within HTML forms. Here is a typical example of such an HTML form. </p><p>Example 2. POST Method with HTML Form</p><p><form action ="http:coronet.iicm.edu//Form" method="POST"> First Name: <input type="text" name="name" size="20" maxlength="50"> Second Name: <input type = "text" name = "second_name" size = "20" maxlength = "50"> Matrikel Number: <input type = "text" name = "nr" size = "20" maxlength = "50"> Study Field: <select name="study_field"> <option value="F874">Telematics <option value="F860">Technical Mathematics <option value="F033523">Software Development <option value="F033211">Telematics Bachelor <option value="F033221">Geomatics </select> <input type="submit" value="Register"> </form></p><p>Thus, parameters sent to the server are name, second_name, nr, and study_field. Getting Started with Java Servlets</p><p>Installing Apache Tomcat</p><p>The first step in working with Java servlets is installing the software, so-called servlet engine, that implements the Java Servlet Specification and provides the Java Servlet API. The reference implementation of servlet engine is Apache Tomcat [Tomcat1999]. The current version of Apache Tomcat is 4.1.27. Apache Tomcat is an open source software product released under Apache Software Licence [Apache2000]. </p><p>Installing Apache Tomcat is quite simple. Firstly, the appropriate version for the operating system must be downloaded. All Apache Tomcat versions might be obtained as source files, or as precompiled binary files. Building the system from source files requires some additional software, which can be obtained from the Apache Java Web site [Jakarta2003]. The complete instructions for buliding and installing Apache Tomcat from the source files can be found on Apache Tomcat Web site. </p><p>On the other hand, installing the binary version of the system can be accomplished in only few steps. For both Linux and Windows operating systems a similar installation procedure might be applied. Here the Linux procedure is explained, to install the system on Windows some small modifications are needed (e.g. *.bat files instead of *.sh files, c:\tomcat instead of /tomcat, etc.). </p><p> Decompress the downloaded binary archive into a directory in your file system, lets say in "/tomcat" directory. Change to /tomcat/bin directory and make the start and stop scripts (startup.sh and shutdown.sh) executable. Invoke the start and stop scripts to start/stop the system. </p><p>Example 3. Installing Tomcat on a Linux machine</p><p>#installation in directory /tomcat cd /tomcat tar xzf <path-to-tomcat-binary-archive>/jakarta-tomcat-4.1.27.tar.gz cd jakarta-tomcat-4.1.27</p><p>#make scripts executable chmod +x bin/*.sh</p><p>#start tomcat (windows: use bin/startap.bat) bin/startup.sh</p><p>#stop tomcat (windows: use bin/shutdown.bat) bin/shutdown.sh There is a Windows installer version available for Windows operating system. To install the system with this binary distribution just double click on the downloaded executable archive and follow the instructions on the screen. A nice feature of this distribution for Windows XP/2000/NT operating system is that the system is automatically installed as a Windows service, which may be controlled from the Managment Console available in Control Panel. </p><p>Once when the system is running it can be accessed with a standard Web browser under http://localhost:8080, or http://<hostname>:8080 </p><p>Compiling and Deploying Java Servlets in Tomcat</p><p>Since Java servlets are typical Java programs to compile them you must use a standard Java compiler. The CLASSPATH environment variable must include the Java Servlet API, which comes with Apache Tomcat. The library is stored under the common/lib/servlet.jar in the Tomcat installation directory (e.g. /tomcat/common/lib/servlet.jar). After compiling all necessery Java source files servlets need to be deployed in Tomcat. </p><p>Apache Tomcat works with so-called Web applications. A Web application is a collection of one or more servlets combined with external Java libraries, static resources such as digital images, static HTML pages, etc. to provide a specific functionality. For instance, online shopping application might be realises as a Tomcat Web application. </p><p>Each Tomcat Web application has the same predefined structure: </p><p> All Web applications are stored as directories under the webapps directory (e.g. /tomcat/webapps) directory of the Tomcat installation. Web application name is identical with the name of its directory, e.g. a Web application called "online- shop" is stored in the directory called online-shop (e.g. /tomcat/webapps/online- shop) and it is accesible via http://localhost:8080/online-shop, or http://<hostname>:8080/online-shop. Static resources of a Web application (e.g. HTML pages, images, etc.) are stored in the Web application directory. There is a special subdirectory called WEB-INF of the Web application directory, e.g. /tomcat/webapps/online-shop/WEB-INF. The WEB-INF directory contains two subdirectories: classes (e.g. /tomcat/webapps/online-shop/WEB-INF/classes) and lib (e.g. /tomcat/webapps/WEB-INF/online-shop/lib) directory. The first of these two subdirectories contains all Java class files required to run a particular Web application. The lib directory contains external Java libraries (e.g. Java archive - jar files) needed to run the Web application. For example, if the Web application connects to a database managment system, the Java library (JDBC driver) needed to establish the connection is placed in the lib directory. There is a special file called web.xml in the WEB-INF directory. This file includes all configuration directives for a particular Web application, in the form of key-value parameters that are paased to a servlet when it is initialized. For example, the username and password for a user of the backend database managment system might be defined in the web.xml file. Further, in this file the typical description of all Java servlets from a particular Web application is provided. This description includes the unique servlet name, name of the Java servlet class, and a number od additional servlet attributes, such as URL mapping for the servlet, and so on. </p><p>Example 4. Template Structure of Tomcat Web Application</p><p>|-tomcat | | | |-webapps | | | | | |-online-shop | | | | | | | |-WEB-INF | | | | | | | | | |-web.xml | | | | | | | | | |-lib | | | | | | | | | | | |-*.jar (e.g. mysql- connector.jar) | | | | | | | | | |-classes | | | | | | | | | | | |-*.class (e.g. ShopingCartServlet.class) | | | | | | | |-*.htm (e.g. navigation.html) | | | | | | | |-*.gif, *.jpg (e.g. shopping_cart.jpg)</p><p>Example 5. Typical web.xml file</p><p><?xml version="1.0" encoding="ISO-8859-1"?> <!DOCTYPE web-app PUBLIC "-//Sun Microsystems, Inc.//DTD Web Application 2.2//EN" "http://java.sun.com/j2ee/dtds/web-app_2_2.dtd"> <web-app> <servlet> <servlet-name>Shopping Cart</servlet-name> <description>Keeps track of items that user bought</description> <servlet-class>ShoppingCartServlet</servlet-class> <init-param> <param-name>database-username</param-name> <param-value>dhelic</param-value> </init-param> </servlet> <servlet-mapping> <servlet-name>Shopping Cart</servlet-name> <url-pattern>Basket</url-pattern> </servlet-mapping> </web-app></p><p>Template Servlet Structure</p><p>The Java Servlet API [JavaServletAPI2003] a number of Java classes which are used for developing of Java servlets. This API consists of two Java packages: javax.servlet and javax.servlet.http. The first package contains Java classes and interfaces which implement a generic servlet behavior, whereas the second javax.servlet.http package provides Java classes and interfaces that handle more specific servlet behaviour in an HTTP based environment. Thus, the most of the time programmers work with the classes from the second package. These two packages provide an object-oriented abstraction of the underlying networking technology. For example, to handle HTTP GET method programmers only need to implement a method in a Java class, to obtain parameters sent by a user they call methods on a high-level Java object representing the request sent by the user, and so on. </p><p>A Java servlet is a normal Java class which is defined as a subclass of the abstract class HttpServlet from the javax.servlet.http package. The abstract HttpServlet class has a number of public methods, each of them corresponding to an HTTP method, such as GET or POST method. A subclass of the Http Servlet class must implement at least one of these methods to handle the corresponding HTTP method. Here are some of the most important methods from the public interface of the HttpServlet class: </p><p> doGet() method, for handling HTTP GET requests doPost() method, for handling HTTP POST requests doDelete() method, for handling HTTP DELETE requests doPut() method, for handling HTTP PUT requests </p><p>Usually, for generation of dynamic Web pages doGet() and/or doPost() methods are implemented. These methods are called by the servlet engine whenever an HTTP request with the corresponding HTTP method is issued to the server. Normally, the servlet engine handles only a single instance of a particular Java servlet. For each new request to this servlet the sevlet engine starts a new thread and invokes the corresponding method of the servlet within the execution context of the new thread. </p><p>In the most simple case a Java servlet only implements doGet() method. Thus, we can create a template servlet structure, which can be used for a rapid devlopment of Java servlets. The following code can be used as such template servlet. </p><p>Example 6. Template Servlet</p><p>/** * Template Servlet * */ import javax.servlet.ServletException; import javax.servlet.http.HttpServlet; import javax.servlet.http.HttpServletRequest; import javax.servlet.http.HttpServletResponse; import javax.servlet.http.HttpSession; import java.io.IOException; import java.io.PrintWriter; public class TemplateServlet extends HttpServlet{</p><p>//------/** * Handles HTTP GET method. * @param request HTTP request * @param response HTTP response * @exception ServletException * @exception IOException */ </p><p> public void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException{</p><p>// Use "request" to read incoming parameters, e.g. request.getParameter("query");</p><p>// Use "response" to write HTTP headers</p><p>PrintWriter writer = response.getWriter(); // Use "writer" to send response to the client }</p><p>}</p><p>Two new classes appeared in the above example: HttpServletRequest and HttpSercletResponse class. These two classes provide an abstraction of the HTTP request and response, respectivelly. Thus, they provide methods to obtain parameters submitted by users (e.g. getParameter(name) method of the HttpServletRequest class), to write response to the client (e.g. getWriter() method of the HttpServletResponse class that returns a writer stream for writing response to the client), and similar. </p><p>Hello World Servlet</p><p>As the next example that does something useful (e.g. prints HelloWorld with today's date in browser ;=)) we will implement the famous Hello World example. Of course, we will reuse the above template servlet structure and extend it to implemt our desired functionality. </p><p>Example 7. Hello World Servlet /** * Hello World Servlet * */ import javax.servlet.ServletException; import javax.servlet.http.HttpServlet; import javax.servlet.http.HttpServletRequest; import javax.servlet.http.HttpServletResponse; import javax.servlet.http.HttpSession; import java.io.IOException; import java.io.PrintWriter; import java.util.Date; public class HelloWorldServlet extends HttpServlet{</p><p>//------/** * Handles HTTP GET method. Sends "HelloWorld" as response to the client. * @param request HTTP request * @param response HTTP response * @exception ServletException * @exception IOException */ </p><p> public void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException{ String hello = "Hello World"; response.setContentType("text/html"); // set mime type of the response PrintWriter writer = response.getWriter(); writer.println("<html>"); writer.println("\t<head>"); writer.println("\t\t<link rel = \"stylesheet\" type = \"text/css\" href = \"style.css\">"); writer.println("\t\t<title>" + hello + "</title>"); writer.println("\t</head>"); writer.println("\t<body>"); writer.println(hello + " (" + (new Date()) + ")"); writer.println("\t</body>"); writer.println("</html>"); }</p><p>}</p><p>The Hello World example is accessible online at http://coronet.iicm.edu/mmis- servlets/HelloWorld. The source code is also avaliable onlne: HelloWorldServlet.java. The first thing we do in the Hello World example is that we set type of the response. To do so we invoke response.setContentType() method and provide a mime type as a string argument (e.g. "text/html"). This method sets a corresponding header in the HTTP response, so that the client (e.g. Web browser) knows what kind of data it gets. In our case that data is of course an HTML page. Finally, in the Hello World example we obtain the writer stream of the response object and write our HTML page to that stream. Writing an HTML page to the writer stream requires writing all HTML tags that constitute a valid HTML page to the writer. </p><p>The first thing to notice in the Hello World example is that writing a servlet is usually related with writing a (possibly) large number of writer.println() statements to produce a valid HTML. Moreover, if we have a number of servlets, or a number of methods that write out HTML we usually end up with a lot of repeating writer.println() statements (e.g. writing document head, style sheet elements, ect.). </p><p>To simplify the above process the so-called Element Construction Set [ECS2003] was developed within the scope of Apache Jakarta Project [Jakarta2003]. The Element Construction Set supports generation of HTML without need for numerous writer.println() statements. To make your servlets aware of the Element Construction Set you need to add the Java library implementing the Element Construction Set into the lib directory of your web application WEB-INF directory (e.g. /tomcat/webapps/hello/WEB- INF/lib). The Element Construction Set (ECS) might be obtained from the http://jakarta.apache.org/ecs/. </p><p>Example 8. Hello World Servlet with ECS</p><p>/** * Hello World Servlet with ECS * */ import javax.servlet.ServletException; import javax.servlet.http.HttpServlet; import javax.servlet.http.HttpServletRequest; import javax.servlet.http.HttpServletResponse; import javax.servlet.http.HttpSession; import org.apache.ecs.Document; import org.apache.ecs.Doctype; import org.apache.ecs.Doctype.Html40Strict; import org.apache.ecs.html.Body; import org.apache.ecs.html.Head; import org.apache.ecs.html.Title; import org.apache.ecs.html.Link; import java.io.IOException; import java.io.PrintWriter; import java.util.Date; public class ECSHelloWorldServlet extends HttpServlet{</p><p>//------/** * Handles HTTP GET method. Sends "HelloWorld" as response to the client. * @param request HTTP request * @param response HTTP response * @exception ServletException * @exception IOException */ </p><p> public void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException{ String hello = "Hello World"; response.setContentType("text/html"); PrintWriter writer = response.getWriter();</p><p>Document document = new Document(); document.setDoctype(new Doctype.Html40Strict()); Title title = new Title(hello); document.setTitle(title); Head head = document.getHead(); Body body = document.getBody(); Link link = new Link(); link.setRel("stylesheet"); link.setType("text/css"); link.setHref("style.css"); head.addElement(link); body.addElement(hello + " (" + (new Date()) + ")"); document.output(writer); }</p><p>}</p><p>The Hello World with ECS example is accessible online at http://coronet.iicm.edu/mmis- servlets/ECSHelloWorld. The source code is also avaliable onlne: ECSHelloWorldServlet.java. </p><p>In the new Hello World example we first need to import all the ECS specific classes, such as Document, Doctype.Html40Strict, Body, Title, Link, etc. In the doGet() method we don't write directly to the writer stream, but rather create the response as an instance of the Document class, and add elements to that object. Thus, first we add a head element, which contains a title and a link element for a style sheet. At the next step, we add a body element containing our "Hello World" string together with the current date. Finally, we dump the document to the writer stream, thus sending the response to the client. </p><p>At the first glance the ECS example does not look shorter or even simpler (we need also to learn how to use different ECS classes) than the first Hello World example, but the Hello World example is actually to simple to really see the difference between a servlet with and without ECS. In larger projects, however, the ECS for sure pays off, since you can easily share ECS elements between methods or even between servlets, thus making it possible to reuse huge number of repeating HTML elements. For example, a link element that specifies a style sheet can be easily shared between methods and servlets, and most probably you will need only one link element (i.e. you need only one style sheet for a number of Web pages) for the whole application. Handling Requests with Servlets</p><p>HTTP Request Headers</p><p>Usually, each HTTP request contains a number of HTTP headers. The client sets HTTP headers to inform server about its communication preferences, about length of the content submitted, authorization information, cookies, and similar. The HttpServletRequest class represents a Java abstraction of HTTP request, thus providing high-level methods for investigating HTTP headers. The getHeader() method accepts as an argument the name of a header and returns its value if the header was submittes by the client. If the header was not included in the client's request then this method returns null. The method getHeaderNames() returns an iterator over all header names that were submitted by the client. The next example prints out all HTTP request headers submitted by the client. </p><p>Example 9. Printing HTTP Request Headers</p><p>/** * HTTP Headers * */ import org.apache.ecs.Document; import org.apache.ecs.Doctype; import org.apache.ecs.Doctype.Html40Strict; import org.apache.ecs.html.Body; import org.apache.ecs.html.Head; import org.apache.ecs.html.Title; import org.apache.ecs.html.Link; import org.apache.ecs.html.Table; import org.apache.ecs.html.TR; import org.apache.ecs.html.TH; import org.apache.ecs.html.TD; import org.apache.ecs.html.P; import javax.servlet.ServletException; import javax.servlet.http.HttpServlet; import javax.servlet.http.HttpServletRequest; import javax.servlet.http.HttpServletResponse; import javax.servlet.http.HttpSession; import java.io.IOException; import java.io.PrintWriter; import java.util.Date; import java.util.Enumeration; public class HeaderServlet extends HttpServlet{</p><p>//------/** * Handles HTTP GET method. Prints HTTP headers in an HTML table. * @param HttpServletRequest request * @param HttpServletResponse response * @exception ServletException * @exception IOException */</p><p> public void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException{ response.setContentType("text/html"); PrintWriter writer = response.getWriter();</p><p>Document document = new Document(); document.setDoctype(new Doctype.Html40Strict()); Title title = new Title("Header Servlet"); document.setTitle(title); Head head = document.getHead(); Body body = document.getBody(); Link link = new Link(); link.setRel("stylesheet"); link.setType("text/css"); link.setHref("style.css"); head.addElement(link);</p><p>Table table = new Table(); // print headers in a table TR table_header = new TR(true); table_header.addElement((new TH(true)).addElement("Key")); table_header.addElement((new TH(true)).addElement("Value")); table.addElement(table_header); Enumeration parameters = request.getHeaderNames(); while(parameters.hasMoreElements()){ String key = (String) parameters.nextElement(); String value = request.getHeader(key); TR table_row = new TR(true); table_row.addElement((new TD(true)).addElement(key)); table_row.addElement((new TD(true)).addElement(value)); table.addElement(table_row); } P paragraph = new P(); paragraph.setNeedClosingTag(true); paragraph.addElement("HTTP Headers"); body.addElement(paragraph); body.addElement(table);</p><p> document.output(writer); }</p><p>//------/** * Handles HTTP POST method. Just invokes goGet() method. * @param HttpServletRequest request * @param HttpServletResponse response * @exception ServletException * @exception IOException */</p><p> public void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException{ doGet(request, response); } }</p><p>This example is accessible online at http://coronet.iicm.edu/mmis-servlets/Header. The source code is also avaliable onlne: HeaderServlet.java. </p><p>In the above example we handle also the POST method. However, in the doPost() method we just invoke the doGet() method passing parameters that we obtained for the POST request. This can be seen as a standard approach for handling these two methods. Thus, we only implement one of these methods and redirect the other to the implemented method. Of course, we need to take care about some specific issues of POST method, such as processing the data submitted with the POST request. </p><p>The HttpServletRequest class provides also a number of methods that allow programmers to retrieve information about the context in which a servlet is running, as well as the context of the current request. These methods are further compatible with CGI environement variables, which are the part of the CGI specification. For example, these methods include: </p><p> getAuthType() for retrieving the type of authorization if an authorization header was supplied. getContentLength(), which gets the length of the content supplied with the POST method. The same information might be obtained by getHeader("CONTENT- LENGTH") method, but since this information is very often needed this special method was implemented. getContentType(), gets type of the data submitted with the POST method. Again, this information might be obtained through HTTP headers as well. getRemoteAddr(), the IP address of the client. getRemoteHost(), the domain name of the client. getRemoteUser(), the username if an authorization header was supplied with the request. getServerName(), the domain name where servlet is running. getServerPort(), the port on which the server is listening. getServerProtocol(), the name and version of protocol that is used for the request. For complete list of the methods provided by the HttpServletRequest class consult the Java Servlet API documentation at http://java.sun.com/products/servlet/2.3/javadoc/index.html. </p><p>Handling HTML forms</p><p>HTML forms are often used to allow users to submit data to the server. For instance, to submit a search query to a search engine users type in their search terms in a text field provided by an HTML form. In an online reservation application users wotk with HTML forms to choose their preferable day of travel, travel conditions, and so on. Regarding the HTTP method used to submit the data, these HTML parameters are encoded as URLs (in the case of GET method), or they are submited as the request content (in the case of POST method). </p><p>Usually, decoding parameters on the server side in the case of CGI programs needed to be accomplished by programmers. These was one of the most tedious part of CGI programming, and one of the reasons for the Java Servlet API developers to include this in the Servlet API. Thus, the HttpServlet Request class provides higl level methods which programmers can call to obtain the parameters submitted by users. Therby the HTTP method used for the request is totally abstracted in the API, thus allowing programmers to obtain parameters in the same way (i.e., by calling the same methods) regardless of the HTTP method used in the request. There are three methods in the HttpServletRequest class to obtain the request parameters: </p><p> getParameter(), which takes as an argument the name of the parameter from HTML form. This method returns a String if the parameter with the specified name exists, otherwise null is returned. Generally, a parameter submitted by a user might have multiple values. In that case this method returns the first value for this parameter. getParameterValues(), which takes as an argument the name of the parameter from HTML form. This method returns an array of Strings if the parameter with the specified name exists, otherwise null is returned. getParameterNames(), which returns an iterator over the names of all parameters submitted by a user. Thus, we might use this method to firstly get all names of parameters, and then we can call other two methods to obtain values of parameters. </p><p>The next example provides a Java servlet that handles the parameters submitted by a user. For the front-end of this example we have a simple HTML form, which is a registration form that allows students to register for a university course. In this example we use the GET method to submit the data. </p><p>Example 10. HTML for Students Registration (GET Method)</p><p><!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd"> <html> <head> <title>Form example</title> <meta http-equiv = "Content-type" content = "text/html; charset=iso-8859-1"> <link rel = "stylesheet" type = "text/css" href = "style.css"> </head> <body> <h2>Registration for MMIS</h2> <form action ="/mmis-servlets/Form" method="GET"> Name: <p> <input type = "text" name = "name" size = "20" maxlength = "50"> </p> Second Name: <p> <input type = "text" name = "second_name" size = "20" maxlength = "50"> </p> Matrikel Number: <p> <input type = "text" name = "nr" size = "20" maxlength = "50"> </p> Study Field: <p> <select name = "study_field"> <option value = "F874">Telematics <option value = "F860">Technical Mathematics <option value = "F033523">Software Development <option value = "F033211">Telematics Bachelor <option value = "F033221">Geomatics </select> </p> <p> <input type = "submit" value = "Register"> </p> </form> </body> </html></p><p>This HTML form is accessible online at http://coronet.iicm.edu/mmis/examples/java/form/form_get.html. </p><p>For submitting the data with the POST method we need to modify the form element of the GET example. The rest of the HTML form is same as before. Example 11. HTML for Students Registration (POST Method)</p><p>... <form action ="/mmis-servlets/Form" method="POST"> ...</p><p>The POST HTML form is accessible online at http://coronet.iicm.edu/mmis/examples/java/form/form_post.html. </p><p>Finally, we have the Java Servlet that handles the HTML forms. As mentioned in the example above, both of HTTP methods are handled with one and the same Java servlet, where requests including POST method are simple forwarded to the doGet() method. </p><p>Example 12. Java Servlet Handling HTML Forms</p><p>/** * Handles parameters submitted by users * */ import org.apache.ecs.Document; import org.apache.ecs.Doctype; import org.apache.ecs.Doctype.Html40Strict; import org.apache.ecs.html.Body; import org.apache.ecs.html.Head; import org.apache.ecs.html.Title; import org.apache.ecs.html.Link; import org.apache.ecs.html.Table; import org.apache.ecs.html.TR; import org.apache.ecs.html.TH; import org.apache.ecs.html.TD; import org.apache.ecs.html.P; import javax.servlet.ServletException; import javax.servlet.http.HttpServlet; import javax.servlet.http.HttpServletRequest; import javax.servlet.http.HttpServletResponse; import javax.servlet.http.HttpSession; import java.io.IOException; import java.io.PrintWriter; import java.util.Date; import java.util.Enumeration; public class FormServlet extends HttpServlet{</p><p>//------/** * Handles HTTP GET method. Prints user parameters in an HTML table. * @param HttpServletRequest request * @param HttpServletResponse response * @exception ServletException * @exception IOException */</p><p> public void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException{ response.setContentType("text/html"); PrintWriter writer = response.getWriter();</p><p>Document document = new Document(); document.setDoctype(new Doctype.Html40Strict()); Title title = new Title("Form Servlet"); document.setTitle(title); Head head = document.getHead(); Body body = document.getBody(); Link link = new Link(); link.setRel("stylesheet"); link.setType("text/css"); link.setHref("style.css"); head.addElement(link);</p><p>Table table = new Table(); TR table_header = new TR(true); table_header.addElement((new TH(true)).addElement("Key")); table_header.addElement((new TH(true)).addElement("Value")); table.addElement(table_header); Enumeration parameters = request.getParameterNames(); while(parameters.hasMoreElements()){ String key = (String) parameters.nextElement(); String value = request.getParameter(key); TR table_row = new TR(true); table_row.addElement((new TD(true)).addElement(key)); table_row.addElement((new TD(true)).addElement(value)); table.addElement(table_row); } P paragraph = new P(); paragraph.setNeedClosingTag(true); paragraph.addElement("Form Variables"); body.addElement(paragraph); body.addElement(table);</p><p> document.output(writer); }</p><p>//------/** * Handles HTTP POST method. Just invokes goGet() method. * @param HttpServletRequest request * @param HttpServletResponse response * @exception ServletException * @exception IOException */</p><p> public void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException{ doGet(request, response); } }</p><p>The source code of this example is avaliable onlne: FormServlet.java. Bibliography</p><p>Books</p><p>[HallBrown2003] Marty Hall and Larry Browni. Copyright © 1999 Marty Hall. 0130092290. Sun Microsystems Press and Prentice Hall PTR. Core Servlets and Java Server Pages. </p><p>Online Resources</p><p>[CGI1995] The CGI Specification, Version 1.1. http://hoohoo.ncsa.uiuc.edu/cgi/interface.html. </p><p>[JavaServlet2003] The Java Servlet Specification, Version 2.3. http://java.sun.com/products/servlet/download.html. </p><p>[JavaServletAPI2003] The Java Servlet API, Version 2.3. http://java.sun.com/products/servlet/2.3/javadoc/index.html. </p><p>[Tomcat1999] Apache Tomcat. http://jakarta.apache.org/tomcat/index.html. </p><p>[Apache2000] Apache Software Licences. http://www.apache.org/licenses/. </p><p>[Jakarta2003] Apache Jakarta Project. http://jakarta.apache.org/. </p><p>[ECS2003] Element Construction Set. http://jakarta.apache.org/ecs/. </p>
Details
-
File Typepdf
-
Upload Time-
-
Content LanguagesEnglish
-
Upload UserAnonymous/Not logged-in
-
File Pages20 Page
-
File Size-