Articles : Tutorials : Server-Side Web Applications Using Servlets and JSP :

Part 3: First Servlets

Contents
Basic Servlet Structure
A Simple Servlet Generating Plain Text
A Servlet that Generates HTML
Simple HTML-Building Utilities

1. Basic Servlet Structure

Here's the outline of a basic servlet that handles GET requests. GET requests, for those unfamiliar with HTTP, are requests made by browsers when the user:

  • types in a URL on the address line
  • follows a link from a Web page
  • or makes an HTML form that does not specify a METHOD.
    Servlets can also very easily handle POST requests, which are generated when someone creates an HTML form that specifies METHOD="POST". We'll discuss that in later sections.

    import java.io.*;
    import javax.servlet.*;
    import javax.servlet.http.*;
    
    public class SomeServlet extends HttpServlet {
      public void doGet(HttpServletRequest request,
                        HttpServletRequest response)
          throws ServletException, IOException {
    
        // Use "request" to read incoming HTTP headers (e.g. cookies)
        // and HTML form data (e.g. data the user entered and submitted)
    
        // Use "response" to specify the HTTP response line and headers
        // (e.g. specifying the content type, setting cookies).
    
        PrintWriter out = response.getWriter();
        // Use "out" to send content to browser
      }
    }
    

    (Download the template source code.)

    To be a servlet, a class should extend HttpServlet and override doGet or doPost (or both), depending on whether the data is being sent by GET or by POST. These methods take two arguments:

  • an HttpServletRequest
  • and an HttpServletResponse.

    The HttpServletRequest has methods that let you find out about incoming information such as FORM data, HTTP request headers, and the like.

    The HttpServletResponse has methods that:

  • let you specify the HTTP response line (200, 404, etc.)
  • let you specify the response headers (Content-Type, Set-Cookie, etc.)
  • and, most importantly, let you obtain a PrintWriter used to send output back to the client.

    For simple servlets, most of the effort is spent in println statements that generate the desired page. Note that doGet and doPost throw two exceptions, so you are required to include them in the declaration. Also note that you have to import classes in:

  • java.io (for PrintWriter, etc.)
  • javax.servlet (for HttpServlet, etc.)
  • and javax.servlet.http (for HttpServletRequest and HttpServletResponse).
    Finally, note that doGet and doPost are called by the service method, and in a few cases you might want to override service directly.

    NEXT


    This tutorial is now available as a book: Core Servlets and JavaServer Pages by Marty Hall, published by Sun Microsystems Press. Read all about it at CoreServlets.com


    Server-Side Web Applications using Java Servlets versions 2.1/2.2 and JavaServer Pages (JSP) version 1.0: A Tutorial
    © 1999-2000 Marty Hall.
    All source code freely available for unrestricted use.
    Created for work in the Research and Technology Development Center of the Johns Hopkins University Applied Physics Lab, for courses in the Johns Hopkins Part-Time MS Program in Computer Science, and for various industry seminars and on-site Java short courses.
    Please note that this is a first draft of the tutorial, so please send corrections, comments, and suggestions to me at hall@apl.jhu.edu.
    Reprinted with permission from the author. Click here to visit the original version

    How to Add Java Applets to Your Site

    New on the Java Boutique:

    New Review:

    Time Management Made Easy with the Quartz Enterprise Job Scheduler
    Why not just use the Java timer API? This open source scheduling API boasts simplicity, ease-of-integration, a well-rounded feature set, and it's free!

    New Applet:

    Reverse Complement
    Reverse Complement is a simple applet that converts DNA or RNA sequences into three useful formats.

    Elsewhere on internet.com:

    WebDeveloper Java
    Lots of Java information on webdeveloper.com

    WDVL Java
    Thorough Java resource at the Web Developer's Virtual Library.

    ScriptSearch Java
    Hundreds of free Java code files to download.

    jGuru: Your View of the Java Universe
    Customizable portal with online training, FAQs, regular news updates, and tutorials.