|
The question of whether to override service( ) vs doGet( )/doPost( ) of a servlet has come up, and thought I'd try to clear this up. On the client side unless an action like "POST" is explicitly issued, "GET" will be the default. But that does not mean a doPost( ) or doGet( ) will be necessarily invoked in the target servlet. To understand why, it is important to understand the subclass relationship between a "GenericServlet" (base class) and the "HttpServlet" (subclass of GenericServlet). The heart of the GenericServlet is the service( ) method which you override to get anything useful done - there is no doGet( ) or doPost( ). Contrast this with the HttpServlet, which overrides the service ( ) method which merely decodes the incoming HttpRequest to decide whether it is for a GET, POST, or other and then calls the appropriate method: doGet( ), doPost( ), or other method. The service( ) method in the HttpRequest is rendered to nothing more than a router to the appropriate method. Most people routinely code their servlets as HttpServlet's, which may be okay with them since they have access to a wider set of api's and avoid learning the limitations GenericServlet's. For such folks, the only option in their world is to override doGet( ) or doPost( ). But there is nothing stopping folks from having their HttpRequests be targetted to a GenericServlet if they want to, in which case they must override the service( ) method to get any useful work done - there is no doPost( ) or doGet( ) involved. If there is a GET embedded in the incoming HttpRequest, the GenericServlet pays no attention to it. Those who want to eke better performance might want to use a lightweight GenericServlet over an HttpServlet. So if there are any samples out there that show the service( ) method being overriden, I suspect it is in the context of a GenericServlet. If so, there is nothing flaky about it as that is the only way. How do JSPs fit into this picture? When a JSP is compiled, you will find the service( ) method gets generated in the source. So it is a hybrid of sorts because it is an HttpServlet with just a service( ) method implemented. So GETs or POSTs that make their way to a JSP from other servlets, all get funneled to the same service( ) method. JSPs can get away with this because no one ever subclasses or overrides the JSP itself. Art "Joe Pluta" <joepluta@plutabrothers.com>@midrange.com on 02/08/2001 10:18:48 AM Please respond to JAVA400-L@midrange.com Sent by: owner-java400-l@midrange.com To: <JAVA400-L@midrange.com> cc: Fax to: Subject: RE: Servlet question, WAS 3.5.2 Frances, this is very interesting and enlightening information. I've often wondered about this. I had always assume that the method invoked by HttpServlet is based on the type of HTTP request. However, I had also assumed that a direct link to a servlet using the <a href=...> technique caused the browser to issue an HTTP GET. Is this incorrect?? Similarly, what happens with a JSP forward? What type of "request" is forwarded? Wouldn't it be the same as the request that originally invoked the servlet doing the forwarding? I suppose I ought to add my usual addendum: "And if you know of links to any more information on this subject, please feel free to let me know" <grin>. Specifically, I'd love some documents on the internals of the interactions between browsers, application servers and servlets. The Javadoc is good for implementation, but doesn't really tell me much about the internals. Joe ---------- Original Message ---------------------------------- From: "Frances Stewart" <francess@us.ibm.com> Reply-To: JAVA400-L@midrange.com Date: Thu, 8 Feb 2001 09:38:25 -0600 > It is not necessarily incorrect to override the service() method. It depends on how you plan on the servlet being invoked. If the servlet will only be invoked as the result of a <FORM METHOD="post" ACTION=.../> or <FORM METHOD="get" ACTION=.../>, etc. tag, then you should not override service() and you should implement doGet and doPost. However, if your servlet will be invoked from a JSP using forward, or if you will invoke the servlet directly from an HTML tag such as <a href ="http://as400service.ibm.com/servlet/EstimatorServlet">Workload Estimator</a>, you will need to implement the service() method. There are two classes, GenericServlet and HttpServlet. HttpServlet extends GenericServlet and adds the doXXX methods which add functionality for invoking the servlet from an HTML page. The Javadoc for both classes can be seen at http://java.sun.com:80/products/servlet/2.3/javadoc/index.html. +--- | This is the JAVA/400 Mailing List! | To submit a new message, send your mail to JAVA400-L@midrange.com. | To subscribe to this list send email to JAVA400-L-SUB@midrange.com. | To unsubscribe from this list send email to JAVA400-L-UNSUB@midrange.com. | Questions should be directed to the list owner: joe@zappie.net +--- +--- | This is the JAVA/400 Mailing List! | To submit a new message, send your mail to JAVA400-L@midrange.com. | To subscribe to this list send email to JAVA400-L-SUB@midrange.com. | To unsubscribe from this list send email to JAVA400-L-UNSUB@midrange.com. | Questions should be directed to the list owner: joe@zappie.net +---
As an Amazon Associate we earn from qualifying purchases.
This mailing list archive is Copyright 1997-2025 by midrange.com and David Gibbs as a compilation work. Use of the archive is restricted to research of a business or technical nature. Any other uses are prohibited. Full details are available on our policy page. If you have questions about this, please contact [javascript protected email address].
Operating expenses for this site are earned using the Amazon Associate program and Google Adsense.