advertisement
javaboutique
Search Tips
Articles  |   Tutorials  |   Reviews  |   Tools  |   by Category  |   by Date  |   by Name  |   Submit  |   Source  |   Forums  |  
javaboutique
Browse DevX


Partners & Affiliates











advertisement

Articles : Java Networking :

Writing Servlets

Contents
Overview
JSWDK 1.0.1 Note
Setting Up A Servlet Development Environment
Setting The CLASSPATH
Hello, Browser!
GET vs POST
Compiling Hello, Browser!
Hello, [Your Name Here]!
Hello, Again!
Next Steps

Hello, [Your Name Here]!

The previous servlet only attempted to send data to your web browser in the form of HTML using the Serlvet API. The next step in our evolution of servlets involves adding the capability of passing data from a browser to the Servlet—the other direction. This time, instead of just saying hello to the user's browser, the servlet will say Hello to the user loading the Servlet after they have entered their name.

Of course, this will entail some participation the user's part. If there is no name field detected from an HTML form by this servlet, we must program the servlet to display an HTML form containing a name field where the user can enter their information. If the servlet detects that there is a name value entered on the form, then the servlet will display the HTML for "Hello, [name]!" where [name] is the name of the user.

The following code represents the HelloUser.java source code file containing the modifications that we just described.

import java.io.*;
import javax.servlet.*;
import javax.servlet.http.*;

public class HelloUser extends HttpServlet {

    public void doGet(HttpServletRequest request,
                      HttpServletResponse response)
                      throws IOException, ServletException    {

        response.setContentType("text/html");
        PrintWriter out = response.getWriter();

        String name = request.getParameter("name");
        if (name == null || name.equals("")) {
            out.println("<HTML>");
            out.println("<HEAD>");
            out.println("<TITLE>Please Enter Your Name</TITLE>");
            out.println("</HEAD>");
            out.println("<BODY BGCOLOR=\"WHITE\">");
            out.println("<H1>Please Enter Your Name</H1>");
            out.println("<FORM>");
            out.println("Full Name:");
            out.println("<INPUT TYPE=\"TEXT\" NAME=\"name\"><P>");
            out.println("<INPUT TYPE =\"SUBMIT\"><P>");
            out.println("</FORM>");
            out.println("</BODY>");
            out.println("</HTML>");
        } else {
            name = "Hello, " + name + "!";

            out.println("<HTML>");
            out.println("<HEAD>");
            out.println("<TITLE>" + name + "</TITLE>");
            out.println("</HEAD>");
            out.println("<BODY BGCOLOR=\"WHITE\">");
            out.println("<H1>" + name + "</H1>");
            out.println("</BODY>");
            out.println("</HTML>");
        }
    }
}

The main difference here is that instead of getting a title from the HTTP header, we are now attempting to call the getParameter method to obtain the value of a name that was entered on an HTML form. Like the getHeader method, getParameter is also called on a request object.

There is one important difference between these methods though. getHeader is used to obtain information that was passed as part of the header in the HTTP protocol. This header is usually not intended as a general information passing mechanism. getParameter is used to obtain information that was entered on an HTML form and passed by the browser to the servlet.

The information obtained from getParameter is usually intended to be application specific and passed by a user to the servlet for processing. In other words, getParameter is used to pass HTML form data to a servlet application. Therefore, you will usually see getParameter used more often than getHeader in most servlet applications.

The first time the servlet is executed, there is no value for name, so the logic in the above code prints an HTML form if it detects that the name string contains no value. If there is a name entered on an HTML form, then the original HelloBrowser HTML is displayed with the user's name replacing the browser type for this servlet.

The following is the raw HTML used to create the HTML form for name data entry.

<HTML>
<HEAD>
<TITLE>Please Enter Your Name</TITLE>
</HEAD>
<BODY BGCOLOR="WHITE">
<H1>Please Enter Your Name</H1>
<FORM>
Full Name:
<INPUT TYPE="TEXT" NAME="name"><P>
<INPUT TYPE ="SUBMIT"><P>
</FORM>
</BODY>
</HTML>

The HTML used here creates a simple form. In this case, the

tag delimits the contents of the form that has one INPUT tag indicating text should be entered in the field and another INPUT tag that represents a submit form button.

When no parameters are given to FORM, the GET method is used to post form data to the current form. Because the GET method is still used, we can continue to use the doGet method in our servlet to handle the form processing as well as the form display. The figure below illustrates how a browser would display the HTML form code given above.

Finally, when the HTML form is filled in by the user, and the submit button is pressed, the user's web browser submits the form data for processing by the servlet.

For example, if "Gunther" is placed in the name field, then the servlet will process the data and discover that there is data in the name field using the getParameter method on the request object. At this point, a new HTML page will be printed that greets "Gunther" and we are done. The figure below shows this.

NEXT


Gunther Birznieks contributes to JavaBoutique's Web/Networking column. Gunther currently works for Barclays Capital in London, one of the leading global investment banks in Europe and has previously worked as a senior computer scientist in the Human Genome Project. Gunther is also known for writing several books on Web Programming (Perl, CGI, Java) as well as for co-creating Extropia with Selena Sol. Extropia is one of the best known public domain web programming archives Email: gunther@extropia.com.

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.

 Microsoft Visual Studio 2010 Showcase
 Avaya Developer Showcase
 MSDN Spotlight
 PHP for Windows Showcase
XML error: undefined entity at line 39
advertisement
Receive Articles via our XML/RSS feed
Receive Articles via our XML/RSS feed

JavaBytes
Internet Cyclone
This powerful, easy-to-use, internet optimizer is for Windows 95, 98, ME, NT, 2000 and XP. It's designed to automatically optimize your Windows settings, boosting your Internet connection up to 200%.

Windows 7: From Beta to Final Code in One Year
Google Shows Off Chrome OS, Releases Source
Microsoft Shows Off Silverlight 4, IE9 Plans
Metasploit Expands Vulnerability Test Framework
HyperCard Reborn?
Fedora 12 Takes Aim at Linux Networking
Top Supercomputer Nearly Doubles in Speed
Fedora 12 Linux Tackles Virtualization
Apple Gives iPhone Developers App Status Tracker
Novell Sets OpenSUSE 11.2 Free

Creating Custom Export Filters for StarOffice with XSLT
WPF Wonders: Using DataTemplates
Crystal Reports Family Offers Options for Developers
Avaya Aura Session Manager video
Avaya Aura Overview video
Exploring HTML 5's Audio/Video Multimedia Support
Overriding Virtual Functions? Use C++0x Attributes to Avoid Bugs.
Understanding the Cloud Computing Security Vulnerabilities
Cisco and IBM Target a Greener World
Upgrade to Visual Studio 2010 with the Ultimate Offer

Advertising Info  |   Member Services  |   Contact Us  |   Help  |   Feedback  |   Site Map  |   Network Map  |   About

internet.commediabistro.comJusttechjobs.comGraphics.com

Search:

WebMediaBrands Corporate Info

Legal Notices, Licensing, Permissions, Privacy Policy.
Advertise | Newsletters | Shopping | E-mail Offers | Freelance Jobs