Package org.apache.catalina.core
Class StandardWrapper
- java.lang.Object
-
- org.apache.catalina.util.LifecycleBase
-
- org.apache.catalina.util.LifecycleMBeanBase
-
- org.apache.catalina.core.ContainerBase
-
- org.apache.catalina.core.StandardWrapper
-
- All Implemented Interfaces:
ServletConfig,MBeanRegistration,NotificationBroadcaster,NotificationEmitter,Container,JmxEnabled,Lifecycle,Wrapper
- Direct Known Subclasses:
Tomcat.ExistingStandardWrapper
public class StandardWrapper extends ContainerBase implements ServletConfig, Wrapper, NotificationEmitter
Standard implementation of the Wrapper interface that represents an individual servlet definition. No child Containers are allowed, and the parent Container must be a Context.- Author:
- Craig R. McClanahan, Remy Maucherat
-
-
Nested Class Summary
-
Nested classes/interfaces inherited from class org.apache.catalina.core.ContainerBase
ContainerBase.ContainerBackgroundProcessor, ContainerBase.ContainerBackgroundProcessorMonitor, ContainerBase.PrivilegedAddChild
-
Nested classes/interfaces inherited from interface org.apache.catalina.Lifecycle
Lifecycle.SingleUse
-
-
Field Summary
Fields Modifier and Type Field Description protected booleanasyncSupportedAsync supportprotected longavailableThe date and time at which this servlet will become available (in milliseconds since the epoch), or zero if the servlet is available.protected NotificationBroadcasterSupportbroadcasterThe broadcaster that sends j2ee notifications.protected intclassLoadTimeprotected static Class<?>[]classTypeStatic class array used when the SecurityManager is turned on andServlet.initis invoked.protected AtomicIntegercountAllocatedThe count of allocations that are currently active.protected static String[]DEFAULT_SERVLET_METHODSprotected booleanenabledEnabledprotected StandardWrapperFacadefacadeThe facade associated with this wrapper.protected ServletinstanceThe (single) possibly uninitialized instance of this servlet.protected booleaninstanceInitializedFlag that indicates if this instance has been initializedprotected booleanisJspServletTrue if this StandardWrapper is for the JspServletprotected ObjectNamejspMonitorONThe ObjectName of the JSP monitoring mbeanprotected intloadOnStartupThe load-on-startup order value (negative value means load on first call) for this servlet.protected longloadTimeprotected ArrayList<String>mappingsMappings associated with the wrapper.protected MultipartConfigElementmultipartConfigElementMultipart configprotected MBeanNotificationInfo[]notificationInfoprotected 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 StringrunAsThe run-as identity for this servlet.protected longsequenceNumberThe notification sequence number.protected StringservletClassThe fully qualified servlet class name for this servlet.protected booleanswallowOutputShould we swallow System.outprotected org.apache.catalina.core.StandardWrapperValveswValveprotected longunloadDelayWait time for servlet unload in ms.protected booleanunloadingAre we unloading our servlet instance at the moment?-
Fields inherited from class org.apache.catalina.core.ContainerBase
accessLog, backgroundProcessorDelay, backgroundProcessorFuture, children, cluster, listeners, logger, logName, monitorFuture, name, parent, parentClassLoader, pipeline, sm, startChildren, startStopExecutor, support
-
Fields inherited from interface org.apache.catalina.Container
ADD_CHILD_EVENT, ADD_VALVE_EVENT, REMOVE_CHILD_EVENT, REMOVE_VALVE_EVENT
-
Fields inherited from interface org.apache.catalina.Lifecycle
AFTER_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
-
Fields inherited from interface org.apache.catalina.Wrapper
ADD_MAPPING_EVENT, REMOVE_MAPPING_EVENT
-
-
Constructor Summary
Constructors Constructor Description StandardWrapper()Create a new StandardWrapper component with the default basic Valve.
-
Method Summary
All Methods Static Methods Instance Methods Concrete Methods Deprecated Methods Modifier and Type Method Description voidaddChild(Container child)Refuse to add a child Container, because Wrappers are the lowest level of the Container hierarchy.voidaddInitParameter(String name, String value)Add a new servlet initialization parameter for this servlet.voidaddMapping(String mapping)Add a mapping associated with the Wrapper.voidaddNotificationListener(NotificationListener listener, NotificationFilter filter, Object object)Add a JMX-NotificationListenervoidaddSecurityReference(String name, String link)Add a new security role reference record to the set of records for this servlet.Servletallocate()Allocate an initialized instance of this Servlet that is ready to have itsservice()method called.voidbackgroundProcess()Execute a periodic task, such as reloading, etc.voiddeallocate(Servlet servlet)Decrement the allocation count for this servlet.StringfindInitParameter(String name)Return the value for the specified initialization parameter name, if any; otherwise returnnull.String[]findInitParameters()Return the names of all defined initialization parameters for this servlet.String[]findMappings()Return the mappings associated with this wrapper.StringfindSecurityReference(String name)Return the security role link for the specified security role reference name, if any; otherwise returnnull.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)longgetAvailable()Return the available date/time for this servlet, in milliseconds since the epoch.intgetClassLoadTime()intgetCountAllocated()intgetErrorCount()Deprecated.The return type will change to long in Tomcat 11 onwards.StringgetInitParameter(String name)Returns aStringcontaining the value of the named initialization parameter, ornullif the parameter does not exist.Enumeration<String>getInitParameterNames()Returns the names of the servlet's initialization parameters as anEnumerationofStringobjects, or an emptyEnumerationif the servlet has no initialization parameters.intgetLoadOnStartup()StringgetLoadOnStartupString()longgetLoadTime()longgetMaxTime()longgetMinTime()MultipartConfigElementgetMultipartConfigElement()MBeanNotificationInfo[]getNotificationInfo()Get JMX Broadcaster Infoprotected StringgetObjectNameKeyProperties()Allow sub-classes to specify the key properties component of theObjectNamethat will be used to register this component.longgetProcessingTime()intgetRequestCount()Deprecated.The return type will change to long in Tomcat 11 onwards.static ThrowablegetRootCause(ServletException e)Extract the root cause from a servlet exception.StringgetRunAs()ServletgetServlet()StringgetServletClass()ServletContextgetServletContext()Returns a reference to theServletContextin which the caller is executing.String[]getServletMethods()Gets the names of the methods supported by the underlying servlet.StringgetServletName()Returns the name of this servlet instance.voidincrementErrorCount()Increment the error count used for monitoring.booleanisAsyncSupported()Does the associated Servlet support async processing?booleanisEnabled()Is the associated Servlet enabled?booleanisOverridable()Is the Servlet overridable by a ServletContainerInitializer?booleanisUnavailable()voidload()Load and initialize an instance of this servlet, if there is not already at least one initialized instance.ServletloadServlet()Load and initialize an instance of this servlet, if there is not already an initialized instance.voidremoveInitParameter(String name)Remove the specified initialization parameter from this servlet.voidremoveMapping(String mapping)Remove a mapping associated with the wrapper.voidremoveNotificationListener(NotificationListener listener)Remove a JMX-NotificationListenervoidremoveNotificationListener(NotificationListener listener, NotificationFilter filter, Object object)Remove a JMX notificationListenervoidremoveSecurityReference(String name)Remove any security role reference for the specified role name.voidsetAsyncSupported(boolean asyncSupported)Set the async support for the associated Servlet.voidsetAvailable(long available)Set the available date/time for this servlet, in milliseconds since the epoch.voidsetEnabled(boolean enabled)Sets the enabled attribute for the associated servlet.voidsetLoadOnStartup(int value)Set the load-on-startup order value (negative value means load on first call).voidsetLoadOnStartupString(String value)Set the load-on-startup order value from a (possibly null) string.voidsetMultipartConfigElement(MultipartConfigElement multipartConfigElement)Set the multi-part configuration for the associated Servlet.voidsetOverridable(boolean overridable)Sets the overridable attribute for this Servlet.voidsetParent(Container container)Set the parent Container of this Wrapper, but only if it is a Context.voidsetRunAs(String runAs)Set the run-as identity for this servlet.voidsetServlet(Servlet servlet)Set the associated servlet instance.voidsetServletClass(String servletClass)Set the fully qualified servlet class name for this servlet.voidsetServletName(String name)Set the name of this servlet.protected voidstartInternal()Start this component and implement the requirements ofLifecycleBase.startInternal().protected voidstopInternal()Stop this component and implement the requirements ofLifecycleBase.stopInternal().voidunavailable(UnavailableException unavailable)Process an UnavailableException, marking this servlet as unavailable for the specified amount of time.voidunload()Unload all initialized instances of this servlet, after calling thedestroy()method for each instance.-
Methods inherited from class org.apache.catalina.core.ContainerBase
addContainerListener, addPropertyChangeListener, addValve, destroyInternal, findChild, findChildren, findContainerListeners, fireContainerEvent, getAccessLog, getBackgroundProcessorDelay, getCatalinaBase, getCatalinaHome, getChildren, getCluster, getClusterInternal, getDomainInternal, getLogger, getLogName, getMBeanKeyProperties, getName, getParent, getParentClassLoader, getPipeline, getRealm, getRealmInternal, getStartChildren, getStartStopThreads, initInternal, logAccess, removeChild, removeContainerListener, removePropertyChangeListener, setBackgroundProcessorDelay, setCluster, setName, setParentClassLoader, setRealm, setStartChildren, setStartStopThreads, threadStart, threadStop, toString
-
Methods inherited from class org.apache.catalina.util.LifecycleMBeanBase
getDomain, getObjectName, postDeregister, postRegister, preDeregister, preRegister, register, setDomain, unregister, unregister
-
Methods inherited from class org.apache.catalina.util.LifecycleBase
addLifecycleListener, destroy, findLifecycleListeners, fireLifecycleEvent, getState, getStateName, getThrowOnFailure, init, removeLifecycleListener, setState, setState, setThrowOnFailure, start, stop
-
Methods inherited from class java.lang.Object
clone, equals, finalize, getClass, hashCode, notify, notifyAll, wait, wait, wait
-
Methods inherited from interface org.apache.catalina.Container
addContainerListener, addPropertyChangeListener, findChild, findChildren, findContainerListeners, fireContainerEvent, getAccessLog, getBackgroundProcessorDelay, getCatalinaBase, getCatalinaHome, getCluster, getDomain, getLogger, getLogName, getMBeanKeyProperties, getName, getObjectName, getParent, getParentClassLoader, getPipeline, getRealm, getStartStopThreads, logAccess, removeChild, removeContainerListener, removePropertyChangeListener, setBackgroundProcessorDelay, setCluster, setName, setParentClassLoader, setRealm, setStartStopThreads
-
Methods inherited from interface org.apache.catalina.Lifecycle
addLifecycleListener, destroy, findLifecycleListeners, getState, getStateName, init, removeLifecycleListener, start, stop
-
-
-
-
Field Detail
-
DEFAULT_SERVLET_METHODS
protected static final String[] DEFAULT_SERVLET_METHODS
-
available
protected long available
The date and time at which this servlet will become available (in milliseconds since the epoch), or zero if the servlet is available. If this value equals Long.MAX_VALUE, the unavailability of this servlet is considered permanent.
-
broadcaster
protected final NotificationBroadcasterSupport broadcaster
The broadcaster that sends j2ee notifications.
-
countAllocated
protected final AtomicInteger countAllocated
The count of allocations that are currently active.
-
facade
protected final StandardWrapperFacade facade
The facade associated with this wrapper.
-
instance
protected volatile Servlet instance
The (single) possibly uninitialized instance of this servlet.
-
instanceInitialized
protected volatile boolean instanceInitialized
Flag that indicates if this instance has been initialized
-
loadOnStartup
protected int loadOnStartup
The load-on-startup order value (negative value means load on first call) for this servlet.
-
parameters
protected HashMap<String,String> parameters
The initialization parameters for this servlet, keyed by parameter name.
-
references
protected HashMap<String,String> references
The security role references for this servlet, keyed by role name used in the servlet. The corresponding value is the role name of the web application itself.
-
runAs
protected String runAs
The run-as identity for this servlet.
-
sequenceNumber
protected long sequenceNumber
The notification sequence number.
-
servletClass
protected String servletClass
The fully qualified servlet class name for this servlet.
-
unloading
protected volatile boolean unloading
Are we unloading our servlet instance at the moment?
-
unloadDelay
protected long unloadDelay
Wait time for servlet unload in ms.
-
isJspServlet
protected boolean isJspServlet
True if this StandardWrapper is for the JspServlet
-
jspMonitorON
protected ObjectName jspMonitorON
The ObjectName of the JSP monitoring mbean
-
swallowOutput
protected boolean swallowOutput
Should we swallow System.out
-
swValve
protected org.apache.catalina.core.StandardWrapperValve swValve
-
loadTime
protected long loadTime
-
classLoadTime
protected int classLoadTime
-
multipartConfigElement
protected MultipartConfigElement multipartConfigElement
Multipart config
-
asyncSupported
protected boolean asyncSupported
Async support
-
enabled
protected boolean enabled
Enabled
-
classType
protected static Class<?>[] classType
Static class array used when the SecurityManager is turned on andServlet.initis invoked.
-
notificationInfo
protected MBeanNotificationInfo[] notificationInfo
-
-
Method Detail
-
isOverridable
public boolean isOverridable()
Description copied from interface:WrapperIs the Servlet overridable by a ServletContainerInitializer?- Specified by:
isOverridablein interfaceWrapper- Returns:
trueif the Servlet can be overridden in a ServletContainerInitializer
-
setOverridable
public void setOverridable(boolean overridable)
Description copied from interface:WrapperSets the overridable attribute for this Servlet.- Specified by:
setOverridablein interfaceWrapper- Parameters:
overridable- the new value
-
getAvailable
public long getAvailable()
Return the available date/time for this servlet, in milliseconds since the epoch. If this date/time is Long.MAX_VALUE, it is considered to mean that unavailability is permanent and any request for this servlet will return an SC_NOT_FOUND error. If this date/time is in the future, any request for this servlet will return an SC_SERVICE_UNAVAILABLE error. If it is zero, the servlet is currently available.- Specified by:
getAvailablein interfaceWrapper- Returns:
- the available date/time for this servlet, in milliseconds since the epoch. If this date/time is in the future, any request for this servlet will return an SC_SERVICE_UNAVAILABLE error. If it is zero, the servlet is currently available. A value equal to Long.MAX_VALUE is considered to mean that unavailability is permanent.
-
setAvailable
public void setAvailable(long available)
Set the available date/time for this servlet, in milliseconds since the epoch. If this date/time is Long.MAX_VALUE, it is considered to mean that unavailability is permanent and any request for this servlet will return an SC_NOT_FOUND error. If this date/time is in the future, any request for this servlet will return an SC_SERVICE_UNAVAILABLE error.- Specified by:
setAvailablein interfaceWrapper- Parameters:
available- The new available date/time
-
getCountAllocated
public int getCountAllocated()
- Returns:
- the number of active allocations of this servlet.
-
getLoadOnStartup
public int getLoadOnStartup()
- Specified by:
getLoadOnStartupin interfaceWrapper- Returns:
- the load-on-startup order value (negative value means load on first call).
-
setLoadOnStartup
public void setLoadOnStartup(int value)
Set the load-on-startup order value (negative value means load on first call).- Specified by:
setLoadOnStartupin interfaceWrapper- Parameters:
value- New load-on-startup value
-
setLoadOnStartupString
public void setLoadOnStartupString(String value)
Set the load-on-startup order value from a (possibly null) string. Per the specification, any missing or non-numeric value is converted to a zero, so that this servlet will still be loaded at startup time, but in an arbitrary order.- Parameters:
value- New load-on-startup value
-
getLoadOnStartupString
public String getLoadOnStartupString()
- Returns:
- the load-on-startup value that was parsed
-
setParent
public void setParent(Container container)
Set the parent Container of this Wrapper, but only if it is a Context.- Specified by:
setParentin interfaceContainer- Overrides:
setParentin classContainerBase- Parameters:
container- Proposed parent Container
-
getRunAs
public String getRunAs()
-
setRunAs
public void setRunAs(String runAs)
Set the run-as identity for this servlet.
-
getServletClass
public String getServletClass()
- Specified by:
getServletClassin interfaceWrapper- Returns:
- the fully qualified servlet class name for this servlet.
-
setServletClass
public void setServletClass(String servletClass)
Set the fully qualified servlet class name for this servlet.- Specified by:
setServletClassin interfaceWrapper- Parameters:
servletClass- Servlet class name
-
setServletName
public void setServletName(String name)
Set the name of this servlet. This is an alias for the normalContainer.setName()method, and complements thegetServletName()method required by theServletConfiginterface.- Parameters:
name- The new name of this servlet
-
isUnavailable
public boolean isUnavailable()
- Specified by:
isUnavailablein interfaceWrapper- Returns:
trueif the Servlet has been marked unavailable.
-
getServletMethods
public String[] getServletMethods() throws ServletException
Description copied from interface:WrapperGets the names of the methods supported by the underlying servlet. This is the same set of methods included in the Allow response header in response to an OPTIONS request method processed by the underlying servlet.- Specified by:
getServletMethodsin interfaceWrapper- Returns:
- Array of names of the methods supported by the underlying servlet
- Throws:
ServletException- If the target servlet cannot be loaded
-
getServlet
public Servlet getServlet()
- Specified by:
getServletin interfaceWrapper- Returns:
- the associated servlet instance.
-
setServlet
public void setServlet(Servlet servlet)
Set the associated servlet instance.- Specified by:
setServletin interfaceWrapper- Parameters:
servlet- The associated Servlet
-
backgroundProcess
public void backgroundProcess()
Execute a periodic task, such as reloading, etc. This method will be invoked inside the classloading context of this container. Unexpected throwables will be caught and logged.- Specified by:
backgroundProcessin interfaceContainer- Overrides:
backgroundProcessin classContainerBase
-
getRootCause
public static Throwable getRootCause(ServletException e)
Extract the root cause from a servlet exception.- Parameters:
e- The servlet exception- Returns:
- the root cause of the Servlet exception
-
addChild
public void addChild(Container child)
Refuse to add a child Container, because Wrappers are the lowest level of the Container hierarchy.- Specified by:
addChildin interfaceContainer- Overrides:
addChildin classContainerBase- Parameters:
child- Child container to be added
-
addInitParameter
public void addInitParameter(String name, String value)
Add a new servlet initialization parameter for this servlet.- Specified by:
addInitParameterin interfaceWrapper- Parameters:
name- Name of this initialization parameter to addvalue- Value of this initialization parameter to add
-
addMapping
public void addMapping(String mapping)
Add a mapping associated with the Wrapper.- Specified by:
addMappingin interfaceWrapper- Parameters:
mapping- The new wrapper mapping
-
addSecurityReference
public void addSecurityReference(String name, String link)
Add a new security role reference record to the set of records for this servlet.- Specified by:
addSecurityReferencein interfaceWrapper- Parameters:
name- Role name used within this servletlink- Role name used within the web application
-
allocate
public Servlet allocate() throws ServletException
Allocate an initialized instance of this Servlet that is ready to have itsservice()method called.- Specified by:
allocatein interfaceWrapper- Returns:
- a new Servlet instance
- Throws:
ServletException- if the servlet init() method threw an exceptionServletException- if a loading error occurs
-
deallocate
public void deallocate(Servlet servlet) throws ServletException
Decrement the allocation count for this servlet.- Specified by:
deallocatein interfaceWrapper- Parameters:
servlet- The servlet to be returned- Throws:
ServletException- if a deallocation error occurs
-
findInitParameter
public String findInitParameter(String name)
Return the value for the specified initialization parameter name, if any; otherwise returnnull.- Specified by:
findInitParameterin interfaceWrapper- Parameters:
name- Name of the requested initialization parameter- Returns:
- the value for the specified initialization parameter name,
if any; otherwise return
null.
-
findInitParameters
public String[] findInitParameters()
Return the names of all defined initialization parameters for this servlet.- Specified by:
findInitParametersin interfaceWrapper- Returns:
- the names of all defined initialization parameters for this servlet.
-
findMappings
public String[] findMappings()
Return the mappings associated with this wrapper.- Specified by:
findMappingsin interfaceWrapper- Returns:
- the mappings associated with this wrapper.
-
findSecurityReference
public String findSecurityReference(String name)
Return the security role link for the specified security role reference name, if any; otherwise returnnull.- Specified by:
findSecurityReferencein interfaceWrapper- Parameters:
name- Security role reference used within this servlet- Returns:
- the security role link for the specified security role
reference name, if any; otherwise return
null.
-
findSecurityReferences
public String[] findSecurityReferences()
Return the set of security role reference names associated with this servlet, if any; otherwise return a zero-length array.- Specified by:
findSecurityReferencesin interfaceWrapper- Returns:
- the set of security role reference names associated with this servlet, if any; otherwise return a zero-length array.
-
load
public void load() throws ServletExceptionLoad and initialize an instance of this servlet, if there is not already at least one initialized instance. This can be used, for example, to load servlets that are marked in the deployment descriptor to be loaded at server startup time.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.- Specified by:
loadin interfaceWrapper- Throws:
ServletException- if the servlet init() method threw an exceptionServletException- if some other loading problem occurs
-
loadServlet
public Servlet loadServlet() throws ServletException
Load and initialize an instance of this servlet, if there is not already an initialized instance. This can be used, for example, to load servlets that are marked in the deployment descriptor to be loaded at server startup time.- Returns:
- the loaded Servlet instance
- Throws:
ServletException- for a Servlet load error
-
removeInitParameter
public void removeInitParameter(String name)
Remove the specified initialization parameter from this servlet.- Specified by:
removeInitParameterin interfaceWrapper- Parameters:
name- Name of the initialization parameter to remove
-
removeMapping
public void removeMapping(String mapping)
Remove a mapping associated with the wrapper.- Specified by:
removeMappingin interfaceWrapper- Parameters:
mapping- The pattern to remove
-
removeSecurityReference
public void removeSecurityReference(String name)
Remove any security role reference for the specified role name.- Specified by:
removeSecurityReferencein interfaceWrapper- Parameters:
name- Security role used within this servlet to be removed
-
unavailable
public void unavailable(UnavailableException unavailable)
Process an UnavailableException, marking this servlet as unavailable for the specified amount of time.- Specified by:
unavailablein interfaceWrapper- Parameters:
unavailable- The exception that occurred, ornullto mark this servlet as permanently unavailable
-
unload
public void unload() throws ServletExceptionUnload all initialized instances of this servlet, after calling thedestroy()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.- Specified by:
unloadin interfaceWrapper- Throws:
ServletException- if an exception is thrown by the destroy() method
-
getInitParameter
public String getInitParameter(String name)
Description copied from interface:jakarta.servlet.ServletConfigReturns aStringcontaining the value of the named initialization parameter, ornullif the parameter does not exist.- Specified by:
getInitParameterin interfaceServletConfig- Parameters:
name- Name of the initialization parameter to retrieve- Returns:
- the initialization parameter value for the specified name, if any; otherwise return
null.
-
getInitParameterNames
public Enumeration<String> getInitParameterNames()
Description copied from interface:jakarta.servlet.ServletConfigReturns the names of the servlet's initialization parameters as anEnumerationofStringobjects, or an emptyEnumerationif the servlet has no initialization parameters.- Specified by:
getInitParameterNamesin interfaceServletConfig- Returns:
- the set of initialization parameter names defined for this servlet. If none are defined, an empty Enumeration is returned.
-
getServletContext
public ServletContext getServletContext()
Description copied from interface:jakarta.servlet.ServletConfigReturns a reference to theServletContextin which the caller is executing.- Specified by:
getServletContextin interfaceServletConfig- Returns:
- the servlet context with which this servlet is associated.
- See Also:
ServletContext
-
getServletName
public String getServletName()
Description copied from interface:jakarta.servlet.ServletConfigReturns the name of this servlet instance. The name may be provided via server administration, assigned in the web application deployment descriptor, or for an unregistered (and thus unnamed) servlet instance it will be the servlet's class name.- Specified by:
getServletNamein interfaceServletConfig- Returns:
- the name of this servlet.
-
getProcessingTime
public long getProcessingTime()
-
getMaxTime
public long getMaxTime()
-
getMinTime
public long getMinTime()
-
getRequestCount
@Deprecated public int getRequestCount()
Deprecated.The return type will change to long in Tomcat 11 onwards. Callers of this method should switch to storing the result of calls to this method in a long value rather than an int.Returns the number of requests processed by the wrapper.- Returns:
- the number of requests processed by the wrapper.
-
getErrorCount
@Deprecated public int getErrorCount()
Deprecated.The return type will change to long in Tomcat 11 onwards. Callers of this method should switch to storing the result of calls to this method in a long value rather than an int.Returns the number of requests processed by the wrapper that resulted in an error.- Returns:
- the number of requests processed by the wrapper that resulted in an error.
-
incrementErrorCount
public void incrementErrorCount()
Increment the error count used for monitoring.- Specified by:
incrementErrorCountin interfaceWrapper
-
getLoadTime
public long getLoadTime()
-
getClassLoadTime
public int getClassLoadTime()
-
getMultipartConfigElement
public MultipartConfigElement getMultipartConfigElement()
- Specified by:
getMultipartConfigElementin interfaceWrapper- Returns:
- the multi-part configuration for the associated Servlet. If no
multi-part configuration has been defined, then
nullwill be returned.
-
setMultipartConfigElement
public void setMultipartConfigElement(MultipartConfigElement multipartConfigElement)
Description copied from interface:WrapperSet the multi-part configuration for the associated Servlet. To clear the multi-part configuration specifynullas the new value.- Specified by:
setMultipartConfigElementin interfaceWrapper- Parameters:
multipartConfigElement- The configuration associated with the Servlet
-
isAsyncSupported
public boolean isAsyncSupported()
Description copied from interface:WrapperDoes the associated Servlet support async processing? Defaults tofalse.- Specified by:
isAsyncSupportedin interfaceWrapper- Returns:
trueif the Servlet supports async
-
setAsyncSupported
public void setAsyncSupported(boolean asyncSupported)
Description copied from interface:WrapperSet the async support for the associated Servlet.- Specified by:
setAsyncSupportedin interfaceWrapper- Parameters:
asyncSupported- the new value
-
isEnabled
public boolean isEnabled()
Description copied from interface:WrapperIs the associated Servlet enabled? Defaults totrue.
-
setEnabled
public void setEnabled(boolean enabled)
Description copied from interface:WrapperSets the enabled attribute for the associated servlet.- Specified by:
setEnabledin interfaceWrapper- Parameters:
enabled- the new value
-
startInternal
protected void startInternal() throws LifecycleExceptionStart this component and implement the requirements ofLifecycleBase.startInternal().- Overrides:
startInternalin classContainerBase- Throws:
LifecycleException- if this component detects a fatal error that prevents this component from being used
-
stopInternal
protected void stopInternal() throws LifecycleExceptionStop this component and implement the requirements ofLifecycleBase.stopInternal().- Overrides:
stopInternalin classContainerBase- Throws:
LifecycleException- if this component detects a fatal error that prevents this component from being used
-
getObjectNameKeyProperties
protected String getObjectNameKeyProperties()
Description copied from class:LifecycleMBeanBaseAllow sub-classes to specify the key properties component of theObjectNamethat will be used to register this component.- Specified by:
getObjectNameKeyPropertiesin classLifecycleMBeanBase- Returns:
- The string representation of the key properties component of the
desired
ObjectName
-
removeNotificationListener
public void removeNotificationListener(NotificationListener listener, NotificationFilter filter, Object object) throws ListenerNotFoundException
Remove a JMX notificationListener
-
getNotificationInfo
public MBeanNotificationInfo[] getNotificationInfo()
Get JMX Broadcaster Info- Specified by:
getNotificationInfoin interfaceNotificationBroadcaster- See Also:
NotificationBroadcaster.getNotificationInfo()
-
addNotificationListener
public void addNotificationListener(NotificationListener listener, NotificationFilter filter, Object object) throws IllegalArgumentException
Add a JMX-NotificationListener
-
removeNotificationListener
public void removeNotificationListener(NotificationListener listener) throws ListenerNotFoundException
Remove a JMX-NotificationListener- Specified by:
removeNotificationListenerin interfaceNotificationBroadcaster- Throws:
ListenerNotFoundException- See Also:
NotificationBroadcaster.removeNotificationListener(javax.management.NotificationListener)
-
-