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

javax.servlet.GenericServlet 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.util.Enumeration;
import java.util.logging.Logger;

/**
 * GenericServlet is a convenient abstract class for defining Servlets.
 * Servlets which need more control than HttpServlet can extend
 * GenericServlet.
 *
 * 

In addition, GenericServlet implements ServletConfig to make * it easier to get configuration information. * *

Servlet configuration looks like the following: * *


 * <servlet servlet-name='myservlet'
 *          servlet-class='test.MyServlet'>
 *   <init-param param1='value1'/>
 *   <init-param param2='value2'/>
 * </servlet>
 * 
*/ public abstract class GenericServlet implements Servlet, ServletConfig, java.io.Serializable { private static final Logger log = Logger.getLogger(GenericServlet.class.getName()); private transient ServletConfig _config; /** * Initialize the servlet. Most servlets should override the zero * parameter init() instead. * * @param config the servlet's configuration */ public void init(ServletConfig config) throws ServletException { _config = config; // log("init"); init(); } /** * Initialize the servlet. Servlets should override this method * if they need any initialization like opening pooled * database connections. */ public void init() throws ServletException { } /** * Returns this servlet's configuration. */ public ServletConfig getServletConfig() { return _config; } /** * Returns the servlet name for this configuration. For example, * 'myservlet' in the following configuration: * *

   * <servlet servlet-name='myservlet'
   *          servlet-class='test.MyServlet'/>
   * 
*/ public String getServletName() { ServletConfig config = getServletConfig(); return config != null ? config.getServletName() : getClass().getName(); } /** * Returns an initialization parameter. Initialization parameters * are defined in the servlet configuration (in resin.conf) as follows: * *

   * <servlet servlet-name='myservlet'
   *          servlet-class='test.MyServlet'>
   *   <init-param param1='value1'/>
   *   <init-param param2='value2'/>
   * </servlet>
   * 
* * @param name of the parameter * @return the init parameter value */ public String getInitParameter(String name) { ServletConfig config = getServletConfig(); return config != null ? config.getInitParameter(name) : null; } /** * Enumerates all the initialization parameter. */ public Enumeration getInitParameterNames() { ServletConfig config = getServletConfig(); return config != null ? config.getInitParameterNames() : null; } /** * Returns the application (servlet context) that the servlet * belongs to. The application provides several useful methods, e.g. * including other files, forwarding, and translating physical paths. */ public ServletContext getServletContext() { ServletConfig config = getServletConfig(); return config != null ? config.getServletContext() : null; } /** * Returns a string describing the servlet. */ public String getServletInfo() { return ""; } /** * Logs an error message in the application's log. */ public void log(String message) { log.config(getServletName() + ": " + message); } /** * Logs an error message and an exception trace in the application's log. */ public void log(String message, Throwable cause) { ServletContext app = getServletContext(); if (app != null) app.log(getClass().getName() + ": " + message, cause); } /** * Called when the servlet (and the application) shuts down. */ public void destroy() { // log("destroy"); } public String toString() { return getClass().getSimpleName() + "[" + getServletContext() + "]"; } }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy