public class StandardWrapper extends ContainerBase implements ServletConfig, Wrapper, NotificationEmitter
ContainerBase.ContainerBackgroundProcessor, ContainerBase.PrivilegedAddChildLifecycle.SingleUse| Modifier and Type | Field and Description | 
|---|---|
| protected boolean | asyncSupportedAsync support | 
| protected long | availableThe date and time at which this servlet will become available (in
 milliseconds since the epoch), or zero if the servlet is available. | 
| protected NotificationBroadcasterSupport | broadcasterThe broadcaster that sends j2ee notifications. | 
| protected int | classLoadTime | 
| protected static Class<?>[] | classTypeStatic class array used when the SecurityManager is turned on and
  Servlet.initis invoked. | 
| protected static Class<?>[] | classTypeUsedInServiceDeprecated.  | 
| protected AtomicInteger | countAllocatedThe count of allocations that are currently active (even if they
 are for the same instance, as will be true on a non-STM servlet). | 
| protected static String[] | DEFAULT_SERVLET_METHODS | 
| protected boolean | enabledEnabled | 
| protected StandardWrapperFacade | facadeThe facade associated with this wrapper. | 
| protected static String | infoThe descriptive information string for this implementation. | 
| protected Servlet | instanceThe (single) possibly uninitialized instance of this servlet. | 
| protected boolean | instanceInitializedFlag that indicates if this instance has been initialized | 
| protected Stack<Servlet> | instancePoolStack containing the STM instances. | 
| protected InstanceSupport | instanceSupportThe support object for our instance listeners. | 
| protected boolean | isJspServletTrue if this StandardWrapper is for the JspServlet | 
| protected ObjectName | jspMonitorONThe ObjectName of the JSP monitoring mbean | 
| protected int | loadOnStartupThe load-on-startup order value (negative value means load on
 first call) for this servlet. | 
| protected long | loadTime | 
| protected ArrayList<String> | mappingsMappings associated with the wrapper. | 
| protected int | maxInstancesMaximum number of STM instances. | 
| protected MultipartConfigElement | multipartConfigElementMultipart config | 
| protected int | nInstancesNumber of instances currently loaded for a STM servlet. | 
| protected MBeanNotificationInfo[] | notificationInfo | 
| protected HashMap<String,String> | parametersThe initialization parameters for this servlet, keyed by
 parameter name. | 
| protected HashMap<String,String> | referencesThe security role references for this servlet, keyed by role name
 used in the servlet. | 
| protected String | runAsThe run-as identity for this servlet. | 
| protected long | sequenceNumberThe notification sequence number. | 
| protected String | servletClassThe fully qualified servlet class name for this servlet. | 
| protected boolean | singleThreadModelDoes this servlet implement the SingleThreadModel interface? | 
| protected boolean | swallowOutputShould we swallow System.out | 
| protected org.apache.catalina.core.StandardWrapperValve | swValve | 
| protected long | unloadDelayWait time for servlet unload in ms. | 
| protected boolean | unloadingAre we unloading our servlet instance at the moment? | 
accessLog, backgroundProcessorDelay, children, cluster, listeners, loader, logger, logName, manager, name, parent, parentClassLoader, pipeline, resources, sm, startChildren, startStopExecutor, supportmserverADD_MAPPING_EVENT, REMOVE_MAPPING_EVENTADD_CHILD_EVENT, ADD_MAPPER_EVENT, ADD_VALVE_EVENT, REMOVE_CHILD_EVENT, REMOVE_MAPPER_EVENT, REMOVE_VALVE_EVENTAFTER_DESTROY_EVENT, AFTER_INIT_EVENT, AFTER_START_EVENT, AFTER_STOP_EVENT, BEFORE_DESTROY_EVENT, BEFORE_INIT_EVENT, BEFORE_START_EVENT, BEFORE_STOP_EVENT, CONFIGURE_START_EVENT, CONFIGURE_STOP_EVENT, PERIODIC_EVENT, START_EVENT, STOP_EVENT| Constructor and Description | 
|---|
| StandardWrapper()Create a new StandardWrapper component with the default basic Valve. | 
| Modifier and Type | Method and Description | 
|---|---|
| void | addChild(Container child)Refuse to add a child Container, because Wrappers are the lowest level
 of the Container hierarchy. | 
| void | addInitParameter(String name,
                String value)Add a new servlet initialization parameter for this servlet. | 
| void | addInstanceListener(InstanceListener listener)Add a new listener interested in InstanceEvents. | 
| void | addMapping(String mapping)Add a mapping associated with the Wrapper. | 
| void | addNotificationListener(NotificationListener listener,
                       NotificationFilter filter,
                       Object object) | 
| void | addSecurityReference(String name,
                    String link)Add a new security role reference record to the set of records for
 this servlet. | 
| Servlet | allocate()Allocate an initialized instance of this Servlet that is ready to have
 its  service()method called. | 
| void | backgroundProcess()Execute a periodic task, such as reloading, etc. | 
| void | deallocate(Servlet servlet)Return this previously allocated servlet to the pool of available
 instances. | 
| String | findInitParameter(String name)Return the value for the specified initialization parameter name,
 if any; otherwise return  null. | 
| String[] | findInitParameters()Return the names of all defined initialization parameters for this
 servlet. | 
| Wrapper | findMappingObject()Deprecated.  | 
| String[] | findMappings()Return the mappings associated with this wrapper. | 
| String | findSecurityReference(String name)Return the security role link for the specified security role
 reference name, if any; otherwise return  null. | 
| String[] | findSecurityReferences()Return the set of security role reference names associated with
 this servlet, if any; otherwise return a zero-length array. | 
| protected Method[] | getAllDeclaredMethods(Class<?> c) | 
| long | getAvailable()Return the available date/time for this servlet, in milliseconds since
 the epoch. | 
| int | getClassLoadTime() | 
| int | getCountAllocated()Return the number of active allocations of this servlet, even if they
 are all for the same instance (as will be true for servlets that do
 not implement  SingleThreadModel. | 
| int | getErrorCount() | 
| String | getInfo()Return descriptive information about this Container implementation and
 the corresponding version number, in the format
  <description>/<version>. | 
| String | getInitParameter(String name)Return the initialization parameter value for the specified name,
 if any; otherwise return  null. | 
| Enumeration<String> | getInitParameterNames()Return the set of initialization parameter names defined for this
 servlet. | 
| InstanceSupport | getInstanceSupport()Return the InstanceSupport object for this Wrapper instance. | 
| int | getLoadOnStartup()Return the load-on-startup order value (negative value means
 load on first call). | 
| String | getLoadOnStartupString() | 
| long | getLoadTime() | 
| int | getMaxInstances()Return maximum number of instances that will be allocated when a single
 thread model servlet is used. | 
| long | getMaxTime() | 
| long | getMinTime() | 
| MultipartConfigElement | getMultipartConfigElement() | 
| MBeanNotificationInfo[] | getNotificationInfo() | 
| protected String | getObjectNameKeyProperties()Allow sub-classes to specify the key properties component of the
  ObjectNamethat will be used to register this component. | 
| long | getProcessingTime() | 
| int | getRequestCount() | 
| static Throwable | getRootCause(ServletException e)Extract the root cause from a servlet exception. | 
| String | getRunAs()Return the run-as identity for this servlet. | 
| Servlet | getServlet()Return the associated servlet instance. | 
| String | getServletClass()Return the fully qualified servlet class name for this servlet. | 
| ServletContext | getServletContext()Return the servlet context with which this servlet is associated. | 
| String[] | getServletMethods()Gets the names of the methods supported by the underlying servlet. | 
| String | getServletName()Return the name of this servlet. | 
| void | incrementErrorCount()Increment the error count used for monitoring. | 
| boolean | isAsyncSupported()Does the associated Servlet support async processing? | 
| protected boolean | isContainerProvidedServlet(String classname)Return  trueif the specified class name represents a
 container provided servlet class that should be loaded by the
 server class loader. | 
| boolean | isEnabled()Is the associated Servlet enabled? | 
| boolean | isEventProvider()Deprecated.  | 
| boolean | isOverridable()Is the Servlet overridable by a ServletContainerInitializer? | 
| Boolean | isSingleThreadModel()Does the servlet class represented by this component implement the
  SingleThreadModelinterface? | 
| boolean | isStateManageable()JSR 77. | 
| boolean | isStatisticsProvider()Deprecated.  | 
| boolean | isUnavailable()Is this servlet currently unavailable? | 
| void | load()Load and initialize an instance of this servlet, if there is not already
 at least one initialized instance. | 
| Servlet | loadServlet()Load and initialize an instance of this servlet, if there is not already
 at least one initialized instance. | 
| void | removeInitParameter(String name)Remove the specified initialization parameter from this servlet. | 
| void | removeInstanceListener(InstanceListener listener)Remove a listener no longer interested in InstanceEvents. | 
| void | removeMapping(String mapping)Remove a mapping associated with the wrapper. | 
| void | removeNotificationListener(NotificationListener listener)Remove a JMX-NotificationListener | 
| void | removeNotificationListener(NotificationListener listener,
                          NotificationFilter filter,
                          Object object) | 
| void | removeSecurityReference(String name)Remove any security role reference for the specified role name. | 
| void | servletSecurityAnnotationScan()This method is no longer used. | 
| void | setAsyncSupported(boolean asyncSupported)Set the async support for the associated Servlet. | 
| void | setAvailable(long available)Set the available date/time for this servlet, in milliseconds since the
 epoch. | 
| void | setEnabled(boolean enabled)Sets the enabled attribute for the associated servlet. | 
| void | setErrorCount(int errorCount)Deprecated.  | 
| void | setLoadOnStartup(int value)Set the load-on-startup order value (negative value means
 load on first call). | 
| void | setLoadOnStartupString(String value)Set the load-on-startup order value from a (possibly null) string. | 
| void | setLoadTime(long loadTime)Deprecated.  | 
| void | setMaxInstances(int maxInstances)Set the maximum number of instances that will be allocated when a single
 thread model servlet is used. | 
| void | setMaxTime(long maxTime)Deprecated.  | 
| void | setMinTime(long minTime)Deprecated.  | 
| void | setMultipartConfigElement(MultipartConfigElement multipartConfigElement)Set the multi-part configuration for the associated Servlet. | 
| void | setOverridable(boolean overridable)Sets the overridable attribute for this Servlet. | 
| void | setParent(Container container)Set the parent Container of this Wrapper, but only if it is a Context. | 
| void | setProcessingTime(long processingTime)Deprecated.  | 
| void | setRequestCount(int requestCount)Deprecated.  | 
| void | setRunAs(String runAs)Set the run-as identity for this servlet. | 
| void | setServlet(Servlet servlet)Set the associated servlet instance. | 
| void | setServletClass(String servletClass)Set the fully qualified servlet class name for this servlet. | 
| void | setServletName(String name)Set the name of this servlet. | 
| void | setServletSecurityAnnotationScanRequired(boolean b)This method is no longer used. | 
| protected void | startInternal()Start this component and implement the requirements
 of  LifecycleBase.startInternal(). | 
| protected void | stopInternal()Stop this component and implement the requirements
 of  LifecycleBase.stopInternal(). | 
| String | toString()Return a String representation of this component. | 
| void | unavailable(UnavailableException unavailable)Process an UnavailableException, marking this servlet as unavailable
 for the specified amount of time. | 
| void | unload()Unload all initialized instances of this servlet, after calling the
  destroy()method for each instance. | 
addContainerListener, addPropertyChangeListener, addValve, destroyInternal, findChild, findChildren, findContainerListeners, fireContainerEvent, getAccessLog, getBackgroundProcessorDelay, getChildren, getCluster, getClusterInternal, getDomainInternal, getLoader, getLoaderInternal, getLogger, getManager, getManagerInternal, getMappingObject, getName, getParent, getParentClassLoader, getPipeline, getRealm, getRealmInternal, getResources, getResourcesInternal, getStartChildren, getStartStopThreads, initInternal, invoke, logAccess, logName, removeChild, removeContainerListener, removePropertyChangeListener, setBackgroundProcessorDelay, setCluster, setLoader, setManager, setName, setParentClassLoader, setRealm, setResources, setStartChildren, setStartStopThreads, threadStart, threadStopgetDomain, getObjectName, postDeregister, postRegister, preDeregister, preRegister, register, setDomain, unregisteraddLifecycleListener, destroy, findLifecycleListeners, fireLifecycleEvent, getState, getStateName, getThrowOnFailure, init, removeLifecycleListener, setState, setState, setThrowOnFailure, start, stopclone, equals, finalize, getClass, hashCode, notify, notifyAll, wait, wait, waitaddContainerListener, addPropertyChangeListener, findChild, findChildren, findContainerListeners, fireContainerEvent, getAccessLog, getBackgroundProcessorDelay, getCluster, getLoader, getLogger, getManager, getMappingObject, getName, getObjectName, getParent, getParentClassLoader, getPipeline, getRealm, getResources, getStartStopThreads, invoke, logAccess, removeChild, removeContainerListener, removePropertyChangeListener, setBackgroundProcessorDelay, setCluster, setLoader, setManager, setName, setParentClassLoader, setRealm, setResources, setStartStopThreadsaddLifecycleListener, destroy, findLifecycleListeners, getState, getStateName, init, removeLifecycleListener, start, stopprotected static final String[] DEFAULT_SERVLET_METHODS
protected long available
protected NotificationBroadcasterSupport broadcaster
protected AtomicInteger countAllocated
protected StandardWrapperFacade facade
protected static final String info
protected volatile Servlet instance
protected volatile boolean instanceInitialized
protected InstanceSupport instanceSupport
protected int loadOnStartup
protected HashMap<String,String> parameters
protected HashMap<String,String> references
protected String runAs
protected long sequenceNumber
protected String servletClass
protected volatile boolean singleThreadModel
protected volatile boolean unloading
protected int maxInstances
protected int nInstances
protected long unloadDelay
protected boolean isJspServlet
protected ObjectName jspMonitorON
protected boolean swallowOutput
protected org.apache.catalina.core.StandardWrapperValve swValve
protected long loadTime
protected int classLoadTime
protected MultipartConfigElement multipartConfigElement
protected boolean asyncSupported
protected boolean enabled
protected static Class<?>[] classType
Servlet.init is invoked.@Deprecated protected static Class<?>[] classTypeUsedInService
Servlet.service  is invoked.protected MBeanNotificationInfo[] notificationInfo
public StandardWrapper()
public boolean isOverridable()
WrapperisOverridable in interface Wrappertrue if the Servlet can be overridden in a ServletContainerInitializerpublic void setOverridable(boolean overridable)
WrappersetOverridable in interface Wrapperoverridable - the new valuepublic long getAvailable()
getAvailable in interface Wrapperpublic void setAvailable(long available)
setAvailable in interface Wrapperavailable - The new available date/timepublic int getCountAllocated()
SingleThreadModel.public String getInfo()
<description>/<version>.getInfo in interface ContainergetInfo in class ContainerBase<description>/<version>.public InstanceSupport getInstanceSupport()
public int getLoadOnStartup()
getLoadOnStartup in interface Wrapperpublic void setLoadOnStartup(int value)
setLoadOnStartup in interface Wrappervalue - New load-on-startup valuepublic void setLoadOnStartupString(String value)
value - New load-on-startup valuepublic String getLoadOnStartupString()
public int getMaxInstances()
public void setMaxInstances(int maxInstances)
maxInstances - New value of maxInstancespublic void setParent(Container container)
setParent in interface ContainersetParent in class ContainerBasecontainer - Proposed parent Containerpublic String getRunAs()
public void setRunAs(String runAs)
public String getServletClass()
getServletClass in interface Wrapperpublic void setServletClass(String servletClass)
setServletClass in interface WrapperservletClass - Servlet class namepublic void setServletName(String name)
Container.setName() method, and complements the
 getServletName() method required by the
 ServletConfig interface.name - The new name of this servletpublic Boolean isSingleThreadModel()
SingleThreadModel interface? This can only be determined
 once the class is loaded. Calling this method will not trigger loading
 the class since that may cause the application to behave unexpectedly.null if the class has not been loaded, otherwise true if the servlet does implement SingleThreadModel and
         false if it does not.public boolean isUnavailable()
isUnavailable in interface Wrappertrue if this Servlet is currently unavailable.public String[] getServletMethods() throws ServletException
getServletMethods in interface WrapperServletException - If the target servlet cannot be loadedpublic Servlet getServlet()
getServlet in interface Wrapperpublic void setServlet(Servlet servlet)
setServlet in interface Wrapperservlet - The associated Servletpublic void setServletSecurityAnnotationScanRequired(boolean b)
setServletSecurityAnnotationScanRequired in interface Wrapperb - Unused.public void backgroundProcess()
backgroundProcess in interface ContainerbackgroundProcess in class ContainerBasepublic static Throwable getRootCause(ServletException e)
e - The servlet exceptionpublic void addChild(Container child)
addChild in interface ContaineraddChild in class ContainerBasechild - Child container to be addedpublic void addInitParameter(String name, String value)
addInitParameter in interface Wrappername - Name of this initialization parameter to addvalue - Value of this initialization parameter to addpublic void addInstanceListener(InstanceListener listener)
addInstanceListener in interface Wrapperlistener - The new listenerpublic void addMapping(String mapping)
addMapping in interface Wrappermapping - The new wrapper mappingpublic void addSecurityReference(String name, String link)
addSecurityReference in interface Wrappername - Role name used within this servletlink - Role name used within the web applicationpublic Servlet allocate() throws ServletException
service() method called.  If the servlet class does
 not implement SingleThreadModel, the (only) initialized
 instance may be returned immediately.  If the servlet class implements
 SingleThreadModel, the Wrapper implementation must ensure
 that this instance is not allocated again until it is deallocated by a
 call to deallocate().allocate in interface WrapperServletException - if the servlet init() method threw
  an exceptionServletException - if a loading error occurspublic void deallocate(Servlet servlet) throws ServletException
deallocate in interface Wrapperservlet - The servlet to be returnedServletException - if a deallocation error occurspublic String findInitParameter(String name)
null.findInitParameter in interface Wrappername - Name of the requested initialization parameternull.public String[] findInitParameters()
findInitParameters in interface Wrapperpublic String[] findMappings()
findMappings in interface Wrapperpublic String findSecurityReference(String name)
null.findSecurityReference in interface Wrappername - Security role reference used within this servletnull.public String[] findSecurityReferences()
findSecurityReferences in interface Wrapper@Deprecated public Wrapper findMappingObject()
public void load()
          throws ServletException
 IMPLEMENTATION NOTE:  Servlets whose classnames begin with
 org.apache.catalina. (so-called "container" servlets)
 are loaded by the same classloader that loaded this class, rather than
 the classloader for the current web application.
 This gives such classes access to Catalina internals, which are
 prevented for classes loaded for web applications.
load in interface WrapperServletException - if the servlet init() method threw
  an exceptionServletException - if some other loading problem occurspublic Servlet loadServlet() throws ServletException
ServletExceptionpublic void servletSecurityAnnotationScan()
                                   throws ServletException
servletSecurityAnnotationScan in interface WrapperServletException - Never thrownpublic void removeInitParameter(String name)
removeInitParameter in interface Wrappername - Name of the initialization parameter to removepublic void removeInstanceListener(InstanceListener listener)
removeInstanceListener in interface Wrapperlistener - The listener to removepublic void removeMapping(String mapping)
removeMapping in interface Wrappermapping - The pattern to removepublic void removeSecurityReference(String name)
removeSecurityReference in interface Wrappername - Security role used within this servlet to be removedpublic String toString()
public void unavailable(UnavailableException unavailable)
unavailable in interface Wrapperunavailable - The exception that occurred, or null
  to mark this servlet as permanently unavailablepublic void unload()
            throws ServletException
destroy() method for each instance.  This can be used,
 for example, prior to shutting down the entire servlet engine, or
 prior to reloading all of the classes from the Loader associated with
 our Loader's repository.unload in interface WrapperServletException - if an exception is thrown by the
  destroy() methodpublic String getInitParameter(String name)
null.getInitParameter in interface ServletConfigname - Name of the initialization parameter to retrieveString containing the value of the initialization
         parameterpublic Enumeration<String> getInitParameterNames()
getInitParameterNames in interface ServletConfigEnumeration of String objects
         containing the names of the servlet's initialization parameterspublic ServletContext getServletContext()
getServletContext in interface ServletConfigServletContext object, used by the caller to interact
         with its servlet containerServletContextpublic String getServletName()
getServletName in interface ServletConfigpublic long getProcessingTime()
@Deprecated public void setProcessingTime(long processingTime)
public long getMaxTime()
@Deprecated public void setMaxTime(long maxTime)
public long getMinTime()
@Deprecated public void setMinTime(long minTime)
public int getRequestCount()
@Deprecated public void setRequestCount(int requestCount)
public int getErrorCount()
@Deprecated public void setErrorCount(int errorCount)
public void incrementErrorCount()
incrementErrorCount in interface Wrapperpublic long getLoadTime()
@Deprecated public void setLoadTime(long loadTime)
public int getClassLoadTime()
public MultipartConfigElement getMultipartConfigElement()
getMultipartConfigElement in interface Wrappernull will be
 returned.public void setMultipartConfigElement(MultipartConfigElement multipartConfigElement)
Wrappernull as the new value.setMultipartConfigElement in interface WrappermultipartConfigElement - The configuration associated with the Servletpublic boolean isAsyncSupported()
Wrapperfalse.isAsyncSupported in interface Wrappertrue if the Servlet supports asyncpublic void setAsyncSupported(boolean asyncSupported)
WrappersetAsyncSupported in interface WrapperasyncSupported - the new valuepublic boolean isEnabled()
Wrappertrue.public void setEnabled(boolean enabled)
WrappersetEnabled in interface Wrapperenabled - the new valueprotected boolean isContainerProvidedServlet(String classname)
true if the specified class name represents a
 container provided servlet class that should be loaded by the
 server class loader.classname - Name of the class to be checkedprotected void startInternal()
                      throws LifecycleException
LifecycleBase.startInternal().startInternal in class ContainerBaseLifecycleException - if this component detects a fatal error
  that prevents this component from being usedprotected void stopInternal()
                     throws LifecycleException
LifecycleBase.stopInternal().stopInternal in class ContainerBaseLifecycleException - if this component detects a fatal error
  that prevents this component from being usedprotected String getObjectNameKeyProperties()
LifecycleMBeanBaseObjectName that will be used to register this component.getObjectNameKeyProperties in class LifecycleMBeanBaseObjectNamepublic boolean isStateManageable()
public void removeNotificationListener(NotificationListener listener, NotificationFilter filter, Object object) throws ListenerNotFoundException
removeNotificationListener in interface NotificationEmitterListenerNotFoundExceptionpublic MBeanNotificationInfo[] getNotificationInfo()
getNotificationInfo in interface NotificationBroadcasterpublic void addNotificationListener(NotificationListener listener, NotificationFilter filter, Object object) throws IllegalArgumentException
addNotificationListener in interface NotificationBroadcasterIllegalArgumentExceptionpublic void removeNotificationListener(NotificationListener listener) throws ListenerNotFoundException
removeNotificationListener in interface NotificationBroadcasterListenerNotFoundExceptionNotificationBroadcaster.removeNotificationListener(javax.management.NotificationListener)@Deprecated public boolean isEventProvider()
@Deprecated public boolean isStatisticsProvider()
Copyright © 2000-2020 Apache Software Foundation. All Rights Reserved.