This chapter describes how to create and configure servlets.
This chapter includes the following sections:
WebLogic Server supports the servlet 3.0 specification (see http://jcp.org/en/jsr/detail?id=315), which introduces the following new features:
Asynchronous processing—a servlet no longer has to wait for a response from a resource, such as a database, before its thread can continue. In other words, the thread is not blocked.
Web module deployment descriptor fragments (web fragments)—The web-fragment.xml file enhances pluggability of library JARs which are packaged under WEB-INF/lib. A web fragment is a part or all of the web.xml file that can be specified and included in a library or framework JAR's META-INF directory.
If you selected to install the server examples, you will find these servlet 3.0 code examples, "Using Annotations for Servlets, Filters and Listeners," "Asynchronous Servlet and Request Handling," and "Servlet Web Fragments," in the EXAMPLES_HOME\wl_server\examples\src\examples\javaee6\servlet directory of your WebLogic Server distribution, where EXAMPLES_HOME represents the directory in which the WebLogic Server code examples are configured. For more information about the WebLogic Server code examples, see "Sample Applications and Code Examples" in Understanding Oracle WebLogic Server.
Note:
This release of WebLogic Server deprecates WebLogic Server-specific annotations: @WLServlet, @WLFilter, and @WLInitParam, in favor of the standard annotations defined in the servlet 3.0 specification. In addition, instead ofweblogic.servlet.http.AbstractAsyncServlet, you should use the standard asynchronous processing model defined in the servlet 3.0 specification. For information on configuring servlet 3.0 asynchronous processing, see async-descriptor in weblogic.xml Deployment Descriptor Elements.With Java EE metadata annotations, the standard web.xml deployment descriptor is optional. The servlet specification states annotations can be defined on certain Web components, such as servlets, filters, listeners, and tag handlers. The annotations are used to declare dependencies on external resources. The container will detect annotations on such components and inject necessary dependencies before the component's life cycle methods are invoked. See WebLogic Annotation for Web Components.
However, you can also define servlets as a part of a Web application in several entries in the standard Web application deployment descriptor, web.xml. The web.xml file is located in the WEB-INF directory of your Web application.
The first entry, under the root servlet element in web.xml, defines a name for the servlet and specifies the compiled class that executes the servlet. (Or, instead of specifying a servlet class, you can specify a JSP.) The servlet element also contains definitions for initialization attributes and security roles for the servlet.
The second entry in web.xml, under the servlet-mapping element, defines the URL pattern that calls this servlet.
Servlet mapping controls how you access a servlet. The following examples demonstrate how you can use servlet mapping in your Web application. In the examples, a set of servlet configurations and mappings (from the web.xml deployment descriptor) is followed by a table (see Table 4-1) showing the URLs used to invoke these servlets.
Example 4-1 Servlet Mapping Example
<servlet> <servlet-name>watermelon</servlet-name> <servlet-class>myservlets.watermelon</servlet-class> </servlet> <servlet> <servlet-name>garden</servlet-name> <servlet-class>myservlets.garden</servlet-class> </servlet> <servlet> <servlet-name>list</servlet-name> <servlet-class>myservlets.list</servlet-class> </servlet> <servlet> <servlet-name>kiwi</servlet-name> <servlet-class>myservlets.kiwi</servlet-class> </servlet> <servlet-mapping> <servlet-name>watermelon</servlet-name> <url-pattern>/fruit/summer/*</url-pattern> </servlet-mapping> <servlet-mapping> <servlet-name>garden</servlet-name> <url-pattern>/seeds/*</url-pattern> </servlet-mapping> <servlet-mapping> <servlet-name>list</servlet-name> <url-pattern>/seedlist</url-pattern> </servlet-mapping> <servlet-mapping> <servlet-name>kiwi</servlet-name> <url-pattern>*.abc</url-pattern> </servlet-mapping>
Table 4-1 url-patterns and Servlet Invocation
| URL | Servlet Invoked | 
|---|---|
| http://host:port/mywebapp/fruit/summer/index.html | watermelon | 
| http://host:port/mywebapp/fruit/summer/index.abc | watermelon | 
| http://host:port/mywebapp/seedlist | list | 
| http://host:port/mywebapp/seedlist/index.html | The default servlet, if configured, or an HTTP 404 File Not Found error message. If the mapping for the  | 
| http://host:port/mywebapp/seedlist/pear.abc | kiwi If the mapping for the list servlet had been  | 
| http://host:port/mywebapp/seeds | garden | 
| http://host:port/mywebapp/seeds/index.html | garden | 
| http://host:port/mywebapp/index.abc | kiwi | 
ServletServlet can be used to create a default mappings for servlets. For example, to create a default mapping to map all servlets to /myservlet/*, so the servlets can be called using http://host:port/web-app-name/myservlet/com/foo/FooServlet, add the following to your web.xml file. (The web.xml file is located in the WEB-INF directory of your Web application.)
<servlet> <servlet-name>ServletServlet</servlet-name> <servlet-class>weblogic.servlet.ServletServlet</servlet-class> </servlet> <servlet-mapping> <servlet-name>ServletServlet</servlet-name> <url-pattern>/myservlet/*</url-pattern> </servlet-mapping>
Each Web application has a default servlet. This default servlet can be a servlet that you specify, or, if you do not specify a default servlet, WebLogic Server uses an internal servlet called the FileServlet as the default servlet.
You can register any servlet as the default servlet. Writing your own default servlet allows you to use your own logic to decide how to handle a request that falls back to the default servlet.
Setting up a default servlet replaces the FileServlet and should be done carefully because the FileServlet is used to serve most files, such as text files, HTML file, image files, and more. If you expect your default servlet to serve such files, you will need to write that functionality into your default servlet.
To set up a user-defined default servlet:
Define your servlet as described in Configuring How a Client Accesses a Web Application.
Add a servlet-mapping with url-pattern = "/" as follows:
<servlet-mapping> <servlet-name>MyOwnDefaultServlet</servlet-name> <url-pattern>/myservlet/*(</url-pattern> </servlet-mapping>
If you still want the FileServlet to serve files with other extensions:
Define a servlet and give it a <servlet-name>, for example myFileServlet.
Define the <servlet-class> as weblogic.servlet.FileServlet.
Using the <servlet-mapping> element, map file extensions to the myFileServlet (in addition to the mappings for your default servlet). For example, if you want the myFileServlet to serve.gif files, map *.gif to the myFileServlet.
Note:
TheFileServlet includes the SERVLET_PATH when determining the source filename if the docHome parameter (deprecated in this release) is not specified. As a result, it is possible to explicitly serve only files from specific directories by mapping the FileServlet to /dir/*, etc.You define initialization attributes for servlets in the Web application deployment descriptor, web.xml, in the init-param element of the servlet element, using param-name and param-value tags. The web.xml file is located in the WEB-INF directory of your Web application. For example:
Example 4-2 Example of Configuring Servlet Initialization Attributes in web.xml
<servlet>
  <servlet-name>HelloWorld2</servlet-name> 
  <servlet-class>examples.servlets.HelloWorld2</servlet-class>
  <init-param>
    <param-name>greeting</param-name> 
    <param-value>Welcome</param-value> 
  </init-param>
  <init-param>
    <param-name>person</param-name> 
    <param-value>WebLogic Developer</param-value> 
  </init-param>
</servlet>
The section provides a procedure for writing a simple HTTP servlet, which prints out the message Hello World. A complete code example (the HelloWorldServlet) illustrating these steps is included at the end of this section. Additional information about using various Java EE and WebLogic Server services such as JDBC, RMI, and JMS, in your servlet are discussed later in this document.
Import the appropriate package and classes, including the following:
import javax.servlet.*; import javax.servlet.http.*; import java.io.*;
Extend javax.servlet.http.HttpServlet. For example:
public class HelloWorldServlet extends HttpServlet{
Implement a service() method.
The main function of a servlet is to accept an HTTP request from a Web browser, and return an HTTP response. This work is done by the service() method of your servlet. Service methods include response objects used to create output and request objects used to receive data from the client.
You may have seen other servlet examples implement the doPost() and/or doGet() methods. These methods reply only to POST or GET requests; if you want to handle all request types from a single method, your servlet can simply implement the service() method. (However, if you choose to implement the service() method, you cannot implement the doPost() or doGet() methods, unless you call super.service() at the beginning of the service() method.) The HTTP servlet specification describes other methods used to handle other request types, but all of these methods are collectively referred to as service methods.
All the service methods take the same parameter arguments. An HttpServletRequest provides information about the request, and your servlet uses an HttpServletResponse to reply to the HTTP client. The service method looks like the following:
public void service(HttpServletRequest req,
       HttpServletResponse res) throws IOException
{
Set the content type, as follows:
res.setContentType("text/html");
Get a reference to a java.io.PrintWriter object to use for output, as follows:
PrintWriter out = res.getWriter();
Create some HTML using the println() method on the PrintWriter object, as shown in the following example:
out.println("<html><head><title>Hello World!</title></head>");
out.println("<body><h1>Hello World!</h1></body></html>");
  }
}
Compile the servlet, as follows:
Set up a development environment shell with the correct classpath and path settings.
From the directory containing the Java source code for your servlet, compile your servlet into the WEB-INF/classes directory of the Web application that contains your servlet. For example:
javac -d /myWebApplication/WEB-INF/classes myServlet.java
Deploy the servlet as part of a Web application hosted on WebLogic Server.
Call the servlet from a browser.
The URL you use to call a servlet is determined by:
The name of the Web application containing the servlet and
The name of the servlet as mapped in the deployment descriptor of the Web application. Request parameters can also be included in the URL used to call a servlet.
Generally the URL for a servlet conforms to the following:
http://host:port/webApplicationName/mappedServletName?parameter
The components of the URL are defined as follows:
host is the name of the machine running WebLogic Server.
port is the port at which the above machine is listening for HTTP requests.
webApplicationName is the name of the Web application containing the servlet.
parameters are one or more name-value pairs containing information sent from the browser that can be used in your servlet.
For example, to use a Web browser to call the HelloWorldServlet (the example featured in this document), which is deployed in the examplesWebApp and served from a WebLogic Server running on your machine, enter the following URL:
http://localhost:7001/examplesWebApp/HelloWorldServlet
The host:port portion of the URL can be replaced by a DNS name that is mapped to WebLogic Server.
The preceding steps create a basic servlet. You will probably also use more advanced features of servlets:
Handling HTML form data—HTTP servlets can receive and process data received from a browser client in HTML forms.
Application design—HTTP servlets offer many ways to design your application. The following sections provide detailed information about writing servlets:
Initializing a servlet—if your servlet needs to initialize data, accept initialization arguments, or perform other actions when the servlet is initialized, you can override the init() method.
Use of sessions and persistence in your servlet—sessions and persistence allow you to track your users within and between HTTP sessions. Session management includes the use of cookies. For more information, see the following sections:
Use of WebLogic services in your servlet—WebLogic Server provides a variety of services and APIs that you can use in your Web applications. These services include Java Database Connectivity (JDBC) drivers, JDBC database connection pools, Java Messaging Service (JMS), Enterprise JavaBeans (EJB), and Remote Method Invocation (RMI). For more information, see the following sections:
This section provides the complete Java source code for the example used in the preceding procedure. The example is a simple servlet that provides a response to an HTTP request. Later in this document, this example is expanded to illustrate how to use HTTP parameters, cookies, and session tracking.
Example 4-3 HelloWorldServlet.java
import javax.servlet.*;
import javax.servlet.http.*;
import java.io.*;
public class HelloWorldServlet extends HttpServlet {
  public void service(HttpServletRequest req, 
                      HttpServletResponse res)
       throws IOException
  {
    // Must set the content type first
    res.setContentType("text/html");
    // Now obtain a PrintWriter to insert HTML into
    PrintWriter out = res.getWriter();
    out.println("<html><head><title>" +
                "Hello World!</title></head>");
    out.println("<body><h1>Hello World!</h1></body></html>");
  }
}
You can find the source code and instructions for compiling and running examples in the EXAMPLES_HOME\wl_server\examples\src\examples\splitdir\helloWorldEar directory of your WebLogic Server distribution, where EXAMPLES_HOME represents the directory in which the WebLogic Server code examples are configured. For more information about the WebLogic Server code examples, see "Sample Applications and Code Examples" in Understanding Oracle WebLogic Server.
The following sections provide information on debugging options available in the WebLogic Server servlet container:
Logging access for servlets can be expensive with regard to server performance. Therefore, in cases where access logging is not required, you can improve performance by disabling logging to the access log file.
The optional access-logging-disabled property in the container-descriptor in weblogic.xml can be used to specify whether access logging for an underlying Web application is disabled.
If the property is set as true, then application accesses are not logged.
If the property is not defined or is set as false, then application accesses are logged.
Note:
Theaccess-logging-disabled property functions at the Web application level. Therefore, if it is defined in a Web application, it does not affect other Web applications. This property works under both development mode and production mode.The following example demonstrates how to disable access logging:
<?xml version="1.0" encoding="ISO-8859-1"?> <weblogic-web-app xmlns="http://xmlns.oracle.com/weblogic/weblogic-web-app"> <container-descriptor> <access-logging-disabled>true</access-logging-disabled> </container-descriptor> </weblogic-web-app>
Tracking session change is very helpful when developing applications, especially for replicated sessions. Although you can utilize HttpSessionAttributeListener to track session changes at the Web application level, developers need a finer-grained debugging option to track session changes during a specific request.
The wl_debug_session request attribute or a same-named session attribute can log attribute changes in the current session. When either flag is used, the container logs the modifications of the underlying session in the server log.
You can enable specific session debugging by using either of the following methods:
Set the wl_debug_session attribute to the current session, as follows:
session.setAttribute('wl_debug_session', Boolean.TRUE);
Use the wl_debug_session attribute in the request query string as the indicator. The container adds a wl_debug_session session attribute to the current session, as shown in the following example:
http://localhost/foocontext/foo?wl_debug_session
To stop debugging a session, you can simply remove the wl_debug_session attribute.
Note:
This feature is available only in development mode. The severity of the debug message is at thedebug level. You need to adjust the severity of the logger to debug or lower for the system logger to output the debug message to the server log file.Tracking a request handle footprint is very helpful while in application development mode. For example, when debugging an application, you need to know many pieces of information. This includes such information as: what request is received, how it is dispatched, what session it is bound to it, when the servlet is invoked, and what response is sent. Finally, when a ServletException occurs, you need a way to link the exception to corresponding request to find the root cause of the error.
The WebLogic Server servlet container provides more detailed log messages during request handling to better describe each milestone in a request flow. No additional configuration changes are required other than enabling the DebugHttp logger.
You can then find the footprint of a request handle in the server log. Once in production mode, you should disable DebugHttp logger to maximize server performance.