All Downloads are FREE. Search and download functionalities are using the official Maven repository.

javax.servlet.Servlet Maven / Gradle / Ivy

/*
 * Copyright (c) 1998-2018 Caucho Technology -- all rights reserved
 *
 * This file is part of Resin(R) Open Source
 *
 * Each copy or derived work must preserve the copyright notice and this
 * notice unmodified.
 *
 * Resin Open Source is free software; you can redistribute it and/or modify
 * it under the terms of the GNU General Public License as published by
 * the Free Software Foundation; either version 2 of the License, or
 * (at your option) any later version.
 *
 * Resin Open Source is distributed in the hope that it will be useful,
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE, or any warranty
 * of NON-INFRINGEMENT.  See the GNU General Public License for more
 * details.
 *
 * You should have received a copy of the GNU General Public License
 * along with Resin Open Source; if not, write to the
 *
 *   Free SoftwareFoundation, Inc.
 *   59 Temple Place, Suite 330
 *   Boston, MA 02111-1307  USA
 *
 * @author Scott Ferguson
 */

package javax.servlet;

import java.io.IOException;

/**
 * A servlet is any Java class with a null-arg constructor that
 * implements the Servlet API.
 *
 * 

Simple servlets should extend HttpServlet to create servlets. * *

Servlets that need full control should extend GenericServlet. * *

Location

* * Servlets are usually loaded from WEB-INF/classes under the application's * root. To add a servlet test.MyServlet, create the java file: *
/www/myweb/WEB-APP/classes/test/MyServlet.java
* *

Servlets can also live in the global classpath. * *

Configuration

* * Servlet configuration for Resin is in the resin.conf file. * *

 * <servlet servlet-name='hello'
 *          servlet-class='test.HelloServlet'
 *          load-on-startup>
 *   <init-param param1='value1'/>
 *   <init-param param2='value2'/>
 * </servlet>
 * 
* *

Dispatch

* * The servlet engine selects servlets based on the * servlet-mapping configuration. Servlets can use the * special 'invoker' servlet or they can be configured to execute directly. * *

To get a path info, your servlet needs to use a wildcard. In the * following example, /Hello will match the 'hello' servlet, but * /Hello/there will match the 'defaultServlet' servlet with a pathinfo * of /Hello/there. * *


 * <servlet-mapping url-pattern='/'
 *                  servlet-name='defaultServlet'/>
 *
 * <servlet-mapping url-pattern='/Hello'
 *                  servlet-name='hello'/>
 *
 * <servlet-mapping url-pattern='/servlet/*'
 *                  servlet-name='invoker'/>
 *
 * <servlet-mapping url-pattern='*.jsp'
 *                  servlet-name='com.caucho.jsp.JspServlet'/>
 * 
* *

Life cycle

* * Servlets are normally initialized when they are first loaded. You can * force loading on startup using the 'load-on-startup' attribute to the * servlet configuration. This is a useful technique for the equivalent * of the global.jsa file. * *

A servlet can count on having only one instance per * application (JVM) unless it implements SingleThreadedModel. * *

Servlet requests are handed by the service routine. * Since the servlet engine is multithreaded, multiple threads may call * service simultaneously. * *

When the application closes, the servlet engine will call * destroy. Note, applications always close and are restarted * whenever a servlet changes. So init and destroy * may be called many times while the server is still up. */ public interface Servlet { /** * Returns an information string about the servlet. */ public String getServletInfo(); /** * Initialize the servlet. ServletConfig contains servlet parameters * from the configuration file. GenericServlet will store the config * for later use. * * @param config information from the configuration file. */ public void init(ServletConfig config) throws ServletException; /** * Returns the servlet configuration, usually the same value as passed * to the init routine. */ public ServletConfig getServletConfig(); /** * Service a request. Since the servlet engine is multithreaded, * many threads may execute service simultaneously. Normally, * req and res will actually be * HttpServletRequest and HttpServletResponse * classes. * * @param req request information. Normally servlets will cast this * to HttpServletRequest * @param res response information. Normally servlets will cast this * to HttpServletRequest */ public void service(ServletRequest req, ServletResponse res) throws IOException, ServletException; /** * Called when the servlet shuts down. Servlets can use this to close * database connections, etc. Servlets generally only shutdown when * the application closes. */ public void destroy(); }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy