public class ApplicationContext extends java.lang.Object implements ServletContext
ServletContext that represents a web application's execution environment. An
instance of this class is associated with each instance of StandardContext.| Modifier and Type | Field and Description |
|---|---|
protected java.util.Map<java.lang.String,java.lang.Object> |
attributes
The context attributes for this context.
|
protected static boolean |
GET_RESOURCE_REQUIRE_SLASH |
protected static boolean |
STRICT_SERVLET_COMPLIANCE |
ORDERED_LIBS, TEMPDIR| Constructor and Description |
|---|
ApplicationContext(StandardContext context)
Construct a new instance of this class, associated with the specified Context instance.
|
| Modifier and Type | Method and Description |
|---|---|
FilterRegistration.Dynamic |
addFilter(java.lang.String filterName,
java.lang.Class<? extends Filter> filterClass)
Add filter to context.
|
FilterRegistration.Dynamic |
addFilter(java.lang.String filterName,
Filter filter)
Add filter to context.
|
FilterRegistration.Dynamic |
addFilter(java.lang.String filterName,
java.lang.String className)
Add filter to context.
|
ServletRegistration.Dynamic |
addJspFile(java.lang.String jspName,
java.lang.String jspFile)
Add a JSP to the context.
|
void |
addListener(java.lang.Class<? extends java.util.EventListener> listenerClass)
TODO SERVLET3 - Add comments
|
void |
addListener(java.lang.String className)
TODO SERVLET3 - Add comments
|
<T extends java.util.EventListener> |
addListener(T t)
TODO SERVLET3 - Add comments
|
ServletRegistration.Dynamic |
addServlet(java.lang.String servletName,
java.lang.Class<? extends Servlet> servletClass)
Add servlet to the context.
|
ServletRegistration.Dynamic |
addServlet(java.lang.String servletName,
Servlet servlet)
Register a servlet instance for use in this ServletContext.
|
ServletRegistration.Dynamic |
addServlet(java.lang.String servletName,
java.lang.String className)
Register a servlet implementation for use in this ServletContext.
|
protected void |
clearAttributes()
Clear all application-created attributes.
|
<T extends Filter> |
createFilter(java.lang.Class<T> c)
Create a Filter instance using the given class.
|
<T extends java.util.EventListener> |
createListener(java.lang.Class<T> c)
TODO SERVLET3 - Add comments
|
<T extends Servlet> |
createServlet(java.lang.Class<T> c)
Create an Servlet instance using the given class.
|
void |
declareRoles(java.lang.String... roleNames)
Add to the declared roles for this ServletContext.
|
java.lang.Object |
getAttribute(java.lang.String name)
Returns the servlet container attribute with the given name, or
null if there is no attribute by
that name. |
java.util.Enumeration<java.lang.String> |
getAttributeNames()
Returns an
Enumeration containing the attribute names available within this servlet context. |
java.lang.ClassLoader |
getClassLoader()
Get the web application class loader associated with this ServletContext.
|
protected StandardContext |
getContext() |
ServletContext |
getContext(java.lang.String uri)
Returns a
ServletContext object that corresponds to a specified URL on the server. |
java.lang.String |
getContextPath()
Return the main path associated with this context.
|
java.util.Set<SessionTrackingMode> |
getDefaultSessionTrackingModes()
Obtains the default session tracking modes for this web application.
|
int |
getEffectiveMajorVersion()
Obtain the major version of the servlet specification for which this web application is implemented.
|
int |
getEffectiveMinorVersion()
Obtain the minor version of the servlet specification for which this web application is implemented.
|
java.util.Set<SessionTrackingMode> |
getEffectiveSessionTrackingModes()
Obtains the currently enabled session tracking modes for this web application.
|
protected ServletContext |
getFacade() |
FilterRegistration |
getFilterRegistration(java.lang.String filterName)
TODO SERVLET3 - Add comments
|
java.util.Map<java.lang.String,? extends FilterRegistration> |
getFilterRegistrations() |
java.lang.String |
getInitParameter(java.lang.String name)
Returns a
String containing the value of the named context-wide initialization parameter, or
null if the parameter does not exist. |
java.util.Enumeration<java.lang.String> |
getInitParameterNames()
Returns the names of the context's initialization parameters as an
Enumeration of
String objects, or an empty Enumeration if the context has no initialization
parameters. |
JspConfigDescriptor |
getJspConfigDescriptor() |
int |
getMajorVersion()
Returns the major version of the Java Servlet API that this servlet container supports.
|
java.lang.String |
getMimeType(java.lang.String file)
Return the MIME type of the specified file, or
null if the MIME type cannot be determined. |
int |
getMinorVersion()
Returns the minor version of the Servlet API that this servlet container supports.
|
RequestDispatcher |
getNamedDispatcher(java.lang.String name)
Return a
RequestDispatcher object that acts as a wrapper for the named servlet. |
java.lang.String |
getRealPath(java.lang.String path)
Returns a
String containing the real path for a given virtual path. |
java.lang.String |
getRequestCharacterEncoding()
Get the default character encoding for reading request bodies.
|
RequestDispatcher |
getRequestDispatcher(java.lang.String path)
Returns a
RequestDispatcher object that acts as a wrapper for the resource located at the given path. |
java.net.URL |
getResource(java.lang.String path)
Returns a URL to the resource that is mapped to a specified path.
|
java.io.InputStream |
getResourceAsStream(java.lang.String path)
Returns the resource located at the named path as an
InputStream object. |
java.util.Set<java.lang.String> |
getResourcePaths(java.lang.String path)
Returns a directory-like listing of all the paths to resources within the web application whose longest sub-path
matches the supplied path argument.
|
java.lang.String |
getResponseCharacterEncoding()
Get the default character encoding for writing response bodies.
|
java.lang.String |
getServerInfo()
Returns the name and version of the servlet container on which the servlet is running.
|
Servlet |
getServlet(java.lang.String name)
Deprecated.
|
java.lang.String |
getServletContextName()
Returns the name of this web application corresponding to this ServletContext as specified in the deployment
descriptor for this web application by the display-name element.
|
java.util.Enumeration<java.lang.String> |
getServletNames()
Deprecated.
|
ServletRegistration |
getServletRegistration(java.lang.String servletName)
Obtain the details of the named servlet.
|
java.util.Map<java.lang.String,? extends ServletRegistration> |
getServletRegistrations()
Obtain a Map of servlet names to servlet registrations for all servlets registered with this context.
|
java.util.Enumeration<Servlet> |
getServlets()
Deprecated.
|
SessionCookieConfig |
getSessionCookieConfig() |
int |
getSessionTimeout()
Get the default session timeout.
|
java.lang.String |
getVirtualServerName()
Get the primary name of the virtual host on which this context is deployed.
|
void |
log(java.lang.Exception exception,
java.lang.String message)
Deprecated.
|
void |
log(java.lang.String message)
Writes the specified message to a servlet log file, usually an event log.
|
void |
log(java.lang.String message,
java.lang.Throwable throwable)
Writes an explanatory message and a stack trace for a given
Throwable exception to the servlet log
file. |
void |
removeAttribute(java.lang.String name)
Removes the attribute with the given name from the servlet context.
|
void |
setAttribute(java.lang.String name,
java.lang.Object value)
Binds an object to a given attribute name in this servlet context.
|
boolean |
setInitParameter(java.lang.String name,
java.lang.String value)
Set the given initialisation parameter to the given value.
|
protected void |
setNewServletContextListenerAllowed(boolean allowed) |
void |
setRequestCharacterEncoding(java.lang.String encoding)
Set the default character encoding to use for reading request bodies.
|
void |
setResponseCharacterEncoding(java.lang.String encoding)
Set the default character encoding to use for writing response bodies.
|
void |
setSessionTimeout(int sessionTimeout)
Set the default session timeout.
|
void |
setSessionTrackingModes(java.util.Set<SessionTrackingMode> sessionTrackingModes)
Configures the available session tracking modes for this web application.
|
protected static final boolean STRICT_SERVLET_COMPLIANCE
protected static final boolean GET_RESOURCE_REQUIRE_SLASH
protected java.util.Map<java.lang.String,java.lang.Object> attributes
public ApplicationContext(StandardContext context)
context - The associated Context instancepublic java.lang.Object getAttribute(java.lang.String name)
javax.servlet.ServletContextnull if there is no attribute by
that name. An attribute allows a servlet container to give the servlet additional information not already
provided by this interface. See your server documentation for information about its attributes. A list of
supported attributes can be retrieved using getAttributeNames.
The attribute is returned as a java.lang.Object or some subclass. Attribute names should follow the
same convention as package names. The Java Servlet API specification reserves names matching java.*,
javax.*, and sun.*.
getAttribute in interface ServletContextname - a String specifying the name of the attributeObject containing the value of the attribute, or null if no attribute exists
matching the given nameServletContext.getAttributeNames()public java.util.Enumeration<java.lang.String> getAttributeNames()
javax.servlet.ServletContextEnumeration containing the attribute names available within this servlet context. Use the
ServletContext.getAttribute(java.lang.String) method with an attribute name to get the value of an attribute.getAttributeNames in interface ServletContextEnumeration of attribute namesServletContext.getAttribute(java.lang.String)public ServletContext getContext(java.lang.String uri)
javax.servlet.ServletContextServletContext object that corresponds to a specified URL on the server.
This method allows servlets to gain access to the context for various parts of the server, and as needed obtain
RequestDispatcher objects from the context. The given path must be begin with "/", is interpreted
relative to the server's document root and is matched against the context roots of other web applications hosted
on this container.
In a security conscious environment, the servlet container may return null for a given URL.
getContext in interface ServletContexturi - a String specifying the context path of another web application in the container.ServletContext object that corresponds to the named URL, or null if either none exists
or the container wishes to restrict this access.RequestDispatcherpublic java.lang.String getContextPath()
javax.servlet.ServletContextgetContextPath in interface ServletContextpublic java.lang.String getInitParameter(java.lang.String name)
javax.servlet.ServletContextString containing the value of the named context-wide initialization parameter, or
null if the parameter does not exist.
This method can make available configuration information useful to an entire "web application". For example, it can provide a web site administrator's email address or the name of a system that holds critical data.
getInitParameter in interface ServletContextname - a String containing the name of the parameter whose value is requestedString containing the value of the initialization parameterServletConfig.getInitParameter(java.lang.String)public java.util.Enumeration<java.lang.String> getInitParameterNames()
javax.servlet.ServletContextEnumeration of
String objects, or an empty Enumeration if the context has no initialization
parameters.getInitParameterNames in interface ServletContextEnumeration of String objects containing the names of the context's
initialization parametersServletConfig.getInitParameter(java.lang.String)public int getMajorVersion()
javax.servlet.ServletContextgetMajorVersion in interface ServletContextpublic int getMinorVersion()
javax.servlet.ServletContextgetMinorVersion in interface ServletContextpublic java.lang.String getMimeType(java.lang.String file)
null if the MIME type cannot be determined.getMimeType in interface ServletContextfile - Filename for which to identify a MIME typeString specifying the file's MIME typepublic RequestDispatcher getNamedDispatcher(java.lang.String name)
RequestDispatcher object that acts as a wrapper for the named servlet.getNamedDispatcher in interface ServletContextname - Name of the servlet for which a dispatcher is requestedRequestDispatcher object that acts as a wrapper for the named servlet, or
null if the ServletContext cannot return a RequestDispatcherRequestDispatcher,
ServletContext.getContext(java.lang.String),
ServletConfig.getServletName()public java.lang.String getRealPath(java.lang.String path)
javax.servlet.ServletContextString containing the real path for a given virtual path. For example, the path
"/index.html" returns the absolute file path on the server's filesystem would be served by a request for
"http://host/contextPath/index.html", where contextPath is the context path of this ServletContext..
The real path returned will be in a form appropriate to the computer and operating system on which the servlet
container is running, including the proper path separators. This method returns null if the servlet
container cannot translate the virtual path to a real path for any reason (such as when the content is being made
available from a .war archive).
getRealPath in interface ServletContextpath - a String specifying a virtual pathString specifying the real path, or null if the translation cannot be performedpublic RequestDispatcher getRequestDispatcher(java.lang.String path)
javax.servlet.ServletContextRequestDispatcher object that acts as a wrapper for the resource located at the given path. A
RequestDispatcher object can be used to forward a request to the resource or to include the resource
in a response. The resource can be dynamic or static.
The pathname must begin with a "/" and is interpreted as relative to the current context root. Use
getContext to obtain a RequestDispatcher for resources in foreign contexts. This method
returns null if the ServletContext cannot return a RequestDispatcher.
getRequestDispatcher in interface ServletContextpath - a String specifying the pathname to the resourceRequestDispatcher object that acts as a wrapper for the resource at the specified path, or
null if the ServletContext cannot return a RequestDispatcherRequestDispatcher,
ServletContext.getContext(java.lang.String)public java.net.URL getResource(java.lang.String path)
throws java.net.MalformedURLException
javax.servlet.ServletContext
This method allows the servlet container to make a resource available to servlets from any source. Resources can
be located on a local or remote file system, in a database, or in a .war file.
The servlet container must implement the URL handlers and URLConnection objects that are necessary
to access the resource.
This method returns null if no resource is mapped to the pathname.
Some containers may allow writing to the URL returned by this method using the methods of the URL class.
The resource content is returned directly, so be aware that requesting a .jsp page returns the JSP
source code. Use a RequestDispatcher instead to include results of an execution.
This method has a different purpose than java.lang.Class.getResource, which looks up resources based
on a class loader. This method does not use class loaders.
getResource in interface ServletContextpath - a String specifying the path to the resourcenull if there is no resource at that pathjava.net.MalformedURLException - if the pathname is not given in the correct formpublic java.io.InputStream getResourceAsStream(java.lang.String path)
javax.servlet.ServletContextInputStream object.
The data in the InputStream can be of any type or length. The path must be specified according to
the rules given in getResource. This method returns null if no resource exists at the
specified path.
Meta-information such as content length and content type that is available via getResource method is
lost when using this method.
The servlet container must implement the URL handlers and URLConnection objects necessary to access
the resource.
This method is different from java.lang.Class.getResourceAsStream, which uses a class loader. This
method allows servlet containers to make a resource available to a servlet from any location, without using a
class loader.
getResourceAsStream in interface ServletContextpath - a String specifying the path to the resourceInputStream returned to the servlet, or null if no resource exists at the
specified pathpublic java.util.Set<java.lang.String> getResourcePaths(java.lang.String path)
javax.servlet.ServletContextgetResourcePaths in interface ServletContextpath - the partial path used to match the resources, which must start with a /public java.lang.String getServerInfo()
javax.servlet.ServletContext
The form of the returned string is servername/versionnumber. For example, the JavaServer Web
Development Kit may return the string JavaServer Web Dev Kit/1.0.
The servlet container may return other optional information after the primary string in parentheses, for example,
JavaServer Web Dev Kit/1.0 (JDK 1.1.6; Windows NT 4.0 x86).
getServerInfo in interface ServletContextString containing at least the servlet container name and version number@Deprecated public Servlet getServlet(java.lang.String name)
javax.servlet.ServletContextServletContext. In this
version, this method always returns null and remains only to preserve binary compatibility. This
method will be permanently removed in a future version of the Java Servlet API.
In lieu of this method, servlets can share information using the ServletContext class and can
perform shared business logic by invoking methods on common non-servlet classes.
getServlet in interface ServletContextname - Not usednullpublic java.lang.String getServletContextName()
javax.servlet.ServletContextgetServletContextName in interface ServletContext@Deprecated public java.util.Enumeration<java.lang.String> getServletNames()
javax.servlet.ServletContextEnumeration of all the servlet names
known to this context. In this version, this method always returns an empty Enumeration and remains
only to preserve binary compatibility. This method will be permanently removed in a future version of the Java
Servlet API.getServletNames in interface ServletContext@Deprecated public java.util.Enumeration<Servlet> getServlets()
javax.servlet.ServletContextEnumeration of all the servlets known to
this servlet context. In this version, this method always returns an empty enumeration and remains only to
preserve binary compatibility. This method will be permanently removed in a future version of the Java Servlet
API.getServlets in interface ServletContextpublic void log(java.lang.String message)
javax.servlet.ServletContextlog in interface ServletContextmessage - a String specifying the message to be written to the log file@Deprecated
public void log(java.lang.Exception exception,
java.lang.String message)
javax.servlet.ServletContextlog in interface ServletContextexception - The exception to logmessage - The message to log with the exceptionpublic void log(java.lang.String message,
java.lang.Throwable throwable)
javax.servlet.ServletContextThrowable exception to the servlet log
file. The name and type of the servlet log file is specific to the servlet container, usually an event log.log in interface ServletContextmessage - a String that describes the error or exceptionthrowable - the Throwable error or exceptionpublic void removeAttribute(java.lang.String name)
javax.servlet.ServletContextServletContext.getAttribute(java.lang.String) to retrieve the attribute's value will return null.
If listeners are configured on the ServletContext the container notifies them accordingly.
removeAttribute in interface ServletContextname - a String specifying the name of the attribute to be removedpublic void setAttribute(java.lang.String name,
java.lang.Object value)
javax.servlet.ServletContext
If listeners are configured on the ServletContext the container notifies them accordingly.
If a null value is passed, the effect is the same as calling removeAttribute().
Attribute names should follow the same convention as package names. The Java Servlet API specification reserves
names matching java.*, javax.*, and sun.*.
setAttribute in interface ServletContextname - a String specifying the name of the attributevalue - an Object representing the attribute to be boundpublic FilterRegistration.Dynamic addFilter(java.lang.String filterName, java.lang.String className)
javax.servlet.ServletContextaddFilter in interface ServletContextfilterName - Name of filter to addclassName - Name of filter classnull if the filter has already been fully defined, else a
FilterRegistration.Dynamic object that can be used to further configure the
filterpublic FilterRegistration.Dynamic addFilter(java.lang.String filterName, Filter filter)
javax.servlet.ServletContextaddFilter in interface ServletContextfilterName - Name of filter to addfilter - Filter to addnull if the filter has already been fully defined, else a
FilterRegistration.Dynamic object that can be used to further configure the
filterpublic FilterRegistration.Dynamic addFilter(java.lang.String filterName, java.lang.Class<? extends Filter> filterClass)
javax.servlet.ServletContextaddFilter in interface ServletContextfilterName - Name of filter to addfilterClass - Class of filter to addnull if the filter has already been fully defined, else a
FilterRegistration.Dynamic object that can be used to further configure the
filterpublic <T extends Filter> T createFilter(java.lang.Class<T> c) throws ServletException
javax.servlet.ServletContextcreateFilter in interface ServletContextT - The type for the given classc - The the class for which an instance should be createdServletException - If the Filter instance cannot be createdpublic FilterRegistration getFilterRegistration(java.lang.String filterName)
javax.servlet.ServletContextgetFilterRegistration in interface ServletContextfilterName - TODOpublic ServletRegistration.Dynamic addServlet(java.lang.String servletName, java.lang.String className)
javax.servlet.ServletContextaddServlet in interface ServletContextservletName - The name of the servlet to registerclassName - The implementation class for the servletpublic ServletRegistration.Dynamic addServlet(java.lang.String servletName, Servlet servlet)
javax.servlet.ServletContextaddServlet in interface ServletContextservletName - The name of the servlet to registerservlet - The Servlet instance to registerpublic ServletRegistration.Dynamic addServlet(java.lang.String servletName, java.lang.Class<? extends Servlet> servletClass)
javax.servlet.ServletContextaddServlet in interface ServletContextservletName - Name of servlet to addservletClass - Class of servlet to addnull if the servlet has already been fully defined, else a
ServletRegistration.Dynamic object that can be used to further configure the
servletpublic ServletRegistration.Dynamic addJspFile(java.lang.String jspName, java.lang.String jspFile)
javax.servlet.ServletContextaddJspFile in interface ServletContextjspName - The servlet name under which this JSP file should be registeredjspFile - The path, relative to the web application root, for the JSP file to be used for this servletServletRegistration.Dynamic object that can be used to further configure the
servletpublic <T extends Servlet> T createServlet(java.lang.Class<T> c) throws ServletException
javax.servlet.ServletContextcreateServlet in interface ServletContextT - The type for the given classc - The the class for which an instance should be createdServletException - If the servlet instance cannot be created.public ServletRegistration getServletRegistration(java.lang.String servletName)
javax.servlet.ServletContextgetServletRegistration in interface ServletContextservletName - The name of the Servlet of interestnull if no Servlet has been registered
with the given namepublic java.util.Set<SessionTrackingMode> getDefaultSessionTrackingModes()
javax.servlet.ServletContextSessionTrackingMode.URL
is always supported, SessionTrackingMode.COOKIE is supported unless the cookies attribute
has been set to false for the context and SessionTrackingMode.SSL is supported if at least
one of the connectors used by this context has the attribute secure set to true.getDefaultSessionTrackingModes in interface ServletContextpublic java.util.Set<SessionTrackingMode> getEffectiveSessionTrackingModes()
javax.servlet.ServletContextgetEffectiveSessionTrackingModes in interface ServletContextServletContext.setSessionTrackingModes(Set) if one was previously set, else return the
defaultspublic SessionCookieConfig getSessionCookieConfig()
getSessionCookieConfig in interface ServletContextpublic void setSessionTrackingModes(java.util.Set<SessionTrackingMode> sessionTrackingModes)
javax.servlet.ServletContextsetSessionTrackingModes in interface ServletContextsessionTrackingModes - The session tracking modes to use for this web applicationpublic boolean setInitParameter(java.lang.String name,
java.lang.String value)
javax.servlet.ServletContextsetInitParameter in interface ServletContextname - Name of initialisation parametervalue - Value for initialisation parametertrue if the call succeeds or false if the call fails because an initialisation
parameter with the same name has already been setpublic void addListener(java.lang.Class<? extends java.util.EventListener> listenerClass)
javax.servlet.ServletContextaddListener in interface ServletContextlistenerClass - TODOpublic void addListener(java.lang.String className)
javax.servlet.ServletContextaddListener in interface ServletContextclassName - TODOpublic <T extends java.util.EventListener> void addListener(T t)
javax.servlet.ServletContextaddListener in interface ServletContextT - TODOt - TODOpublic <T extends java.util.EventListener> T createListener(java.lang.Class<T> c)
throws ServletException
javax.servlet.ServletContextcreateListener in interface ServletContextT - TODOc - TODOServletException - TODOpublic void declareRoles(java.lang.String... roleNames)
javax.servlet.ServletContextdeclareRoles in interface ServletContextroleNames - The roles to addpublic java.lang.ClassLoader getClassLoader()
javax.servlet.ServletContextgetClassLoader in interface ServletContextpublic int getEffectiveMajorVersion()
javax.servlet.ServletContextgetEffectiveMajorVersion in interface ServletContextpublic int getEffectiveMinorVersion()
javax.servlet.ServletContextgetEffectiveMinorVersion in interface ServletContextpublic java.util.Map<java.lang.String,? extends FilterRegistration> getFilterRegistrations()
getFilterRegistrations in interface ServletContextpublic JspConfigDescriptor getJspConfigDescriptor()
getJspConfigDescriptor in interface ServletContextpublic java.util.Map<java.lang.String,? extends ServletRegistration> getServletRegistrations()
javax.servlet.ServletContextgetServletRegistrations in interface ServletContextpublic java.lang.String getVirtualServerName()
javax.servlet.ServletContextgetVirtualServerName in interface ServletContextpublic int getSessionTimeout()
javax.servlet.ServletContextgetSessionTimeout in interface ServletContextpublic void setSessionTimeout(int sessionTimeout)
javax.servlet.ServletContextsetSessionTimeout in interface ServletContextsessionTimeout - The new default session timeout in minutes.public java.lang.String getRequestCharacterEncoding()
javax.servlet.ServletContextgetRequestCharacterEncoding in interface ServletContextnull if no default has been specifiedpublic void setRequestCharacterEncoding(java.lang.String encoding)
javax.servlet.ServletContextsetRequestCharacterEncoding in interface ServletContextencoding - The name of the character encoding to usepublic java.lang.String getResponseCharacterEncoding()
javax.servlet.ServletContextgetResponseCharacterEncoding in interface ServletContextnull if no default has been specifiedpublic void setResponseCharacterEncoding(java.lang.String encoding)
javax.servlet.ServletContextsetResponseCharacterEncoding in interface ServletContextencoding - The name of the character encoding to useprotected StandardContext getContext()
protected void clearAttributes()
protected ServletContext getFacade()
protected void setNewServletContextListenerAllowed(boolean allowed)
Copyright © 2000-2024 Apache Software Foundation.
Apache Tomcat, Tomcat, Apache, the Apache Tomcat logo and the Apache logo are either registered trademarks or trademarks of the Apache Software Foundation.