| 
 | Groovy 1.8.1 | |||||||
| FRAMES NO FRAMES | ||||||||
| SUMMARY: NESTED | FIELD | CONSTR | METHOD | DETAIL: FIELD | CONSTR | METHOD | |||||||
java.lang.Objectjavax.servlet.GenericServlet
javax.servlet.http.HttpServlet
groovy.servlet.AbstractHttpServlet
public abstract class AbstractHttpServlet extends HttpServlet
A base class dealing with common HTTP servlet API housekeeping aspects.
resource.name.regex = empty - defaults to null resource.name.replacement = empty - defaults to null resource.name.replace.all = true (default) | false means replaceFirst()Note: If you specify a regex, you have to specify a replacement string too! Otherwise an exception gets raised.
verbose = false(default) | trueIn order to support class-loading-troubles-debugging with Tomcat 4 or higher, you can log the class loader responsible for loading some classes. See GROOVY-861 for details. The servlet init parameter name is:
log.GROOVY861 = false(default) | trueIf you experience class-loading-troubles with Tomcat 4 (or higher) or any other servlet container using custom class loader setups, you can fallback to use (slower) reflection in Groovy's MetaClass implementation. Please contact the dev team with your problem! Thanks. The servlet init parameter name is:
reflection = false(default) | true
| Field Summary | |
|---|---|
| static String | CONTENT_TYPE_TEXT_HTMLContent type of the HTTP response. | 
| static String | INC_PATH_INFOServlet API include key name: path_info | 
| static String | INC_REQUEST_URI | 
| static String | INC_SERVLET_PATHServlet API include key name: servlet_path | 
| protected String | encodingEncoding to use, becomes charset part of contentType. | 
| protected boolean | reflectionMirrors the static value of the reflection flag in MetaClass. | 
| protected Matcher | resourceNameMatcherEither  | 
| protected boolean | resourceNameReplaceAllThe replace method to use on the matcher. | 
| protected String | resourceNameReplacementThe replacement used by the resource name matcher. | 
| protected ServletContext | servletContextServlet (or the web application) context. | 
| protected boolean | verboseControls almost all log output. | 
| Constructor Summary | |
| AbstractHttpServlet()Initializes all fields with default values. | |
| Method Summary | |
|---|---|
| URLConnection | getResourceConnection(String name)Interface method for ResourceContainer. | 
| protected String | getScriptUri(HttpServletRequest request)Returns the include-aware uri of the script or template file. | 
| protected File | getScriptUriAsFile(HttpServletRequest request)Parses the http request for the real script or template source file. | 
| void | init(ServletConfig config)Overrides the generic init method to set some debug flags. | 
| protected void | setVariables(ServletBinding binding)Override this method to set your variables to the Groovy binding. | 
| Methods inherited from class HttpServlet | |
|---|---|
| service, log, log, init, init, destroy, getInitParameter, getInitParameterNames, getServletName, getServletContext, getServletConfig, getServletInfo, wait, wait, wait, equals, toString, hashCode, getClass, notify, notifyAll | 
| Methods inherited from class GenericServlet | |
|---|---|
| log, log, init, init, destroy, service, getInitParameter, getInitParameterNames, getServletName, getServletContext, getServletConfig, getServletInfo, wait, wait, wait, equals, toString, hashCode, getClass, notify, notifyAll | 
| Field Detail | 
|---|
public static final String CONTENT_TYPE_TEXT_HTML
public static final String INC_PATH_INFO
public static final String INC_REQUEST_URI
public static final String INC_SERVLET_PATH
protected String encoding
protected boolean reflection
protected Matcher resourceNameMatcher
null or a compiled pattern matcher read from "resource.name.regex"
 and used in AbstractHttpServlet.getScriptUri.
     
        
protected boolean resourceNameReplaceAll
true - replaceAll(resourceNameReplacement); (default) false - replaceFirst(resourceNameReplacement);
protected String resourceNameReplacement
protected ServletContext servletContext
protected boolean verbose
| Constructor Detail | 
|---|
public AbstractHttpServlet()
| Method Detail | 
|---|
public URLConnection getResourceConnection(String name)
protected String getScriptUri(HttpServletRequest request)
request -  the http request to analyze
protected File getScriptUriAsFile(HttpServletRequest request)
request -  the http request to analyze
public void init(ServletConfig config)
config -  the servlet configuration provided by the container
protected void setVariables(ServletBinding binding)
All variables bound the binding are passed to the template source text, e.g. the HTML file, when the template is merged.
The binding provided by TemplateServlet does already include some default variables. As of this writing, they are (copied from ServletBinding):
And via implicit hard-coded keywords:
The binding also provides convenient methods:
Example binding all servlet context variables:
 class MyServlet extends TemplateServlet {
 
   protected void setVariables(ServletBinding binding) {
     // Bind a simple variable
     binding.setVariable("answer", new Long(42));
 
     // Bind all servlet context attributes...
     ServletContext context = (ServletContext) binding.getVariable("context");
     Enumeration enumeration = context.getAttributeNames();
     while (enumeration.hasMoreElements()) {
       String name = (String) enumeration.nextElement();
       binding.setVariable(name, context.getAttribute(name));
     }
   }
 
 }
 binding -  to be modified
Copyright © 2003-2010 The Codehaus. All rights reserved.