Class WebAppContext
- All Implemented Interfaces:
- WebAppClassLoader.Context, AliasCheck, Deployable, Handler, Handler.Container, Handler.Singleton, Request.Handler, Attributes, ClassVisibilityChecker, Container, Destroyable, Dumpable, Dumpable.DumpableContainer, LifeCycle, Invocable
The WebAppContext handler is an extension of ContextHandler that
coordinates the construction and configuration of nested handlers:
ConstraintSecurityHandler, SessionHandler
and ServletHandler.
The handlers are configured by pluggable configuration classes, with
the default being  WebXmlConfiguration and
JettyWebXmlConfiguration.
- 
Nested Class SummaryNested ClassesNested classes/interfaces inherited from class ServletContextHandlerServletContextHandler.ContextStatus, ServletContextHandler.JspConfig, ServletContextHandler.JspPropertyGroup, ServletContextHandler.ServletContainerInitializerCaller, ServletContextHandler.ServletContainerInitializerStarter, ServletContextHandler.ServletContextApi, ServletContextHandler.ServletContextScopeListener, ServletContextHandler.ServletRequestInfo, ServletContextHandler.ServletResponseInfo, ServletContextHandler.ServletScopedContext, ServletContextHandler.TagLibNested classes/interfaces inherited from class ContextHandlerContextHandler.Availability, ContextHandler.ContextScopeListener, ContextHandler.ScopedContextNested classes/interfaces inherited from class Handler.AbstractHandler.Abstract.NonBlockingNested classes/interfaces inherited from class AbstractLifeCycleAbstractLifeCycle.AbstractLifeCycleListener, AbstractLifeCycle.StopExceptionNested classes/interfaces inherited from interface AttributesAttributes.Layer, Attributes.Lazy, Attributes.Mapped, Attributes.Synthetic, Attributes.WrapperNested classes/interfaces inherited from interface ContainerContainer.InheritedListener, Container.ListenerNested classes/interfaces inherited from interface DumpableDumpable.DumpableContainerNested classes/interfaces inherited from interface HandlerHandler.Abstract, Handler.AbstractContainer, Handler.Collection, Handler.Container, Handler.Sequence, Handler.Singleton, Handler.WrapperNested classes/interfaces inherited from interface InvocableInvocable.Callable, Invocable.InvocationType, Invocable.ReadyTask, Invocable.TaskNested classes/interfaces inherited from interface LifeCycleLifeCycle.ListenerNested classes/interfaces inherited from interface Request.HandlerRequest.Handler.AbortException
- 
Field SummaryFieldsModifier and TypeFieldDescriptionstatic final ClassMatcherDeprecated, for removal: This API element is subject to removal in a future version.static final ClassMatcherDeprecated, for removal: This API element is subject to removal in a future version.static final StringDeprecated, for removal: This API element is subject to removal in a future version.useWebAppClassLoading.HIDDEN_CLASSES_ATTRIBUTEinstead.static final StringDeprecated, for removal: This API element is subject to removal in a future version.useWebAppClassLoading.PROTECTED_CLASSES_ATTRIBUTEinstead.static final StringFields inherited from class ServletContextHandler__environment, _contextStatus, _jspConfig, _objFactory, _options, _securityHandler, _servletHandler, _sessionHandler, DEFAULT_LISTENER_TYPE_INDEX, DEFAULT_MAX_FORM_CONTENT_SIZE, DEFAULT_MAX_FORM_KEYS, ENVIRONMENT, EXTENDED_LISTENER_TYPE_INDEX, MAX_FORM_CONTENT_SIZE_KEY, MAX_FORM_KEYS_KEY, NO_SECURITY, NO_SESSIONS, SECURITY, SERVLET_LISTENER_TYPES, SESSIONSFields inherited from class ContextHandlerCROSS_CONTEXT_ATTRIBUTE, MANAGED_ATTRIBUTESFields inherited from interface AttributesNULLFields inherited from interface DeployableATTRIBUTE_PREFIX, CONFIGURATION_CLASSES, CONTAINER_SCAN_JARS, CONTEXT_HANDLER_CLASS, CONTEXT_PATH, DEFAULTS_DESCRIPTOR, EE_ENVIRONMENT_NAME_PATTERN, ENVIRONMENT, ENVIRONMENT_COMPARATOR, ENVIRONMENT_XML, EXTRACT_WARS, PARENT_LOADER_PRIORITY, SCI_EXCLUSION_PATTERN, SCI_ORDER, TEMP_DIR, WAR, WEBINF_SCAN_JARSFields inherited from interface Invocable__nonBlocking, NOOP
- 
Constructor SummaryConstructorsConstructorDescriptionWebAppContext(String webApp, String contextPath) WebAppContext(String contextPath, SessionHandler sessionHandler, SecurityHandler securityHandler, ServletHandler servletHandler, ErrorHandler errorHandler, int options) WebAppContext(SessionHandler sessionHandler, SecurityHandler securityHandler, ServletHandler servletHandler, ErrorHandler errorHandler) WebAppContext(Resource webApp, String contextPath) 
- 
Method SummaryModifier and TypeMethodDescriptionvoidaddConfiguration(Configuration... configuration) voidaddHiddenClassMatcher(ClassMatcher hiddenClasses) Add a ClassMatcher for hidden (server) classes by combining with any existing matcher.voidaddOverrideDescriptor(String overrideDescriptor) The override descriptor is a web.xml format file that is applied to the context after the standard WEB-INF/web.xmlvoidaddProtectedClassMatcher(ClassMatcher protectedClasses) Add a ClassMatcher for protected (system) classes by combining with any existing matcher.static voidaddServerClasses(Server server, String... patterns) Deprecated, for removal: This API element is subject to removal in a future version.voidaddServerClassMatcher(ClassMatcher serverClasses) Deprecated, for removal: This API element is subject to removal in a future version.static voidaddSystemClasses(Server server, String... patterns) Deprecated, for removal: This API element is subject to removal in a future version.voidaddSystemClassMatcher(ClassMatcher systemClasses) Deprecated, for removal: This API element is subject to removal in a future version.protected voidPrevent the temp directory from being deleted during the normal stop sequence, and require thatContextHandler.cleanupAfterStop()is explicitly called after the webapp classloader is closedbooleanprotected ClassLoaderconfigureClassLoader(ClassLoader loader) Configure the contextClassLoader, potentially wrapping it.protected voidCreate the temporary directory.voiddestroy()Destroys the managed Destroyable beans in the reverse order they were added.protected voiddoStart()Starts the managed lifecycle beans in the order they were added.voiddump(Appendable out, String indent) Dump this object (and children) into an Appendable using the provided indent after any new lines.protected StringCreate a canonical name for a context temp directory.<T> TgetConfiguration(Class<? extends T> configClass) String[]static WebAppContextThe default descriptor is a web.xml format file that is applied to the context before the standard WEB-INF/web.xmlString[]The override descriptor is a web.xml format file that is applied to the context after the standard WEB-INF/web.xmlAn override descriptor is a web.xml format file that is applied to the context after the standard WEB-INF/web.xmlString[]getResource(String pathInContext) Attempt to get a Resource from the Context.getResourceAlias(String path) protected ResourceIf the webapp has no baseresource yet, use the war to make the temp directory name.String[]Deprecated, for removal: This API element is subject to removal in a future version.Deprecated, for removal: This API element is subject to removal in a future version.String[]Deprecated, for removal: This API element is subject to removal in a future version.Deprecated, for removal: This API element is subject to removal in a future version.Get an exception that caused the webapp to be unavailablegetWar()voidinitializeDefaults(Map<String, String> properties) booleanbooleanIs the context Automatically configured.booleanbooleanbooleanbooleanbooleanbooleanisHiddenClass(Class<?> clazz) Is the class a Hidden (Server) Class.booleanisHiddenResource(String name, URL url) booleanbooleanbooleanisProtectedClass(Class<?> clazz) Is the class a Protected (System) Class.booleanisProtectedResource(String name, URL url) booleanisServerClass(Class<?> clazz) Deprecated, for removal: This API element is subject to removal in a future version.booleanisSystemClass(Class<?> clazz) Deprecated, for removal: This API element is subject to removal in a future version.booleanprotected voidprotected voidGenerate a reasonable name for the temp directory because one has not been explicitly configured by the user withContextHandler.setTempDirectory(File).protected ConfigurationsvoidvoidPre configure the web application.voidremoveConfiguration(Class<? extends Configuration>... configurations) voidremoveConfiguration(Configuration... configurations) booleanremoveEventListener(EventListener listener) Remove an event listener.removeResourceAlias(String alias) voidsetAllowDuplicateFragmentNames(boolean allowDuplicateFragmentNames) voidsetClassLoader(ClassLoader classLoader) TheClassLoaderto set as thethread's context classloaderwhen the thread executing this handler enters the scope of this context.voidsetConfigurationClasses(String[] configurations) voidsetConfigurationClasses(List<String> configurations) voidsetConfigurationDiscovered(boolean discovered) Set the configuration discovery mode.voidsetConfigurations(Configuration[] configurations) voidsetConfigurations(Configurations configurations) voidsetContextPath(String contextPath) voidsetContextWhiteList(String... contextWhiteList) Set the context white list In certain circumstances you want may want to deny access of one webapp from another when you may not fully trust the webapp.voidsetCopyWebDir(boolean copy) voidsetCopyWebInf(boolean copyWebInf) voidsetDefaultContextPath(String contextPath) voidsetDefaultsDescriptor(String defaultsDescriptor) The default descriptor is a web.xml format file that is applied to the context before the standard WEB-INF/web.xmlvoidsetDescriptor(String descriptor) Set the web.xml descriptor to use.voidsetDisplayName(String servletContextName) voidsetDistributable(boolean distributable) voidsetExtraClasspath(String extraClasspath) Set the Extra ClassPath via delimited String.voidsetExtraClasspath(List<Resource> extraClasspath) voidsetExtractWAR(boolean extractWAR) voidsetHiddenClassMatcher(ClassMatcher hiddenClasses) Set the hidden (server) classes patterns.voidsetLogUrlOnStart(boolean logOnStart) Sets whether or not the web app name and URL is logged on startupvoidsetOverrideDescriptor(String overrideDescriptor) The override descriptor is a web.xml format file that is applied to the context after the standard WEB-INF/web.xmlvoidsetOverrideDescriptors(List<String> overrideDescriptors) The override descriptor is a web.xml format file that is applied to the context after the standard WEB-INF/web.xmlvoidsetParentLoaderPriority(boolean java2compliant) voidsetPermissions(PermissionCollection permissions) voidsetProtectedClassMatcher(ClassMatcher protectedClasses) Set the protected (system) classes patterns.voidsetResourceAlias(String alias, String uri) Set Resource Alias.voidsetResourceAliases(Map<String, String> map) voidSet theServerto associate to thisHandler.voidsetServerClassMatcher(ClassMatcher serverClasses) Deprecated, for removal: This API element is subject to removal in a future version.setServletSecurity(jakarta.servlet.ServletRegistration.Dynamic registration, jakarta.servlet.ServletSecurityElement servletSecurityElement) Delegate for ServletRegistration.Dynamic.setServletSecurity methodvoidsetSystemClassMatcher(ClassMatcher systemClasses) Deprecated, for removal: This API element is subject to removal in a future version.voidsetThrowUnavailableOnStartupException(boolean throwIfStartupException) voidSet the war of the webapp.voidsetWarResource(Resource war) Set the war of the webapp as aResource.protected voidFinish constructing handlers and link them together.protected voidContinue thestartContext()before callingsuper.startContext().protected voidprotected voidContinue thestopContext()before callingsuper.stopContext().toString()Methods inherited from class ServletContextHandleraddEventListener, addFilter, addFilter, addFilter, addFilter, addLocaleEncoding, addProgrammaticListener, addRoles, addServlet, addServlet, addServlet, addServlet, addServletContainerInitializer, addServletContainerInitializer, addServletContainerInitializer, callContextDestroyed, callContextInitialized, contextDestroyed, contextInitialized, doStop, dynamicHolderAdded, getContext, getContextPathEncoded, getCurrentServletContext, getCurrentServletContextHandler, getDefaultRequestCharacterEncoding, getDefaultResponseCharacterEncoding, getDefaultSecurityHandlerClass, getInitParameter, getInitParameterNames, getInitParams, getInvocationType, getLocaleEncoding, getLocaleEncoding, getLocaleEncodings, getLogger, getMaxFormContentSize, getMaxFormKeys, getObjectFactory, getRequestContextPath, getResourcePaths, getSecurityHandler, getServletContext, getServletContext, getServletContextHandler, getServletContextHandler, getServletHandler, getSessionHandler, getWelcomeFiles, handleByContextHandler, insertHandler, isDurableListener, isProgrammaticListener, isUsingSecurityManager, loadClass, newContext, newResource, newResource, newResource, newSecurityHandler, newServletContextRequest, newServletHandler, newSessionHandler, notifyEnterScope, notifyExitScope, requestDestroyed, requestInitialized, setDefaultRequestCharacterEncoding, setDefaultResponseCharacterEncoding, setDefaultSecurityHandlerClass, setHandler, setInitParameter, setLogger, setMaxFormContentSize, setMaxFormKeys, setSecurityHandler, setServletHandler, setSessionHandler, setTempDirectory, setUsingSecurityManager, setWelcomeFiles, wrapRequest, wrapResponseMethods inherited from class ContextHandleraddAliasCheck, addVirtualHosts, checkAlias, checkVirtualHost, clearAliasChecks, clearAttributes, enterScope, exitScope, getAliasChecks, getAllowNullPathInContext, getAttribute, getAttributeNameSet, getBaseName, getBaseResource, getClassLoader, getClassPath, getContextHandler, getContextPath, getCrossContextHandler, getCurrentContext, getCurrentContext, getCurrentContextHandler, getDisplayName, getErrorHandler, getMimeTypes, getProtectedTargets, getTempDirectory, getVirtualHosts, handle, handleMovedPermanently, handleUnavailable, isAvailable, isCrossContextDispatchSupported, isProtectedTarget, isTempDirectoryPersistent, removeAttribute, removeVirtualHosts, setAliasChecks, setAllowNullPathInContext, setAttribute, setAvailable, setBaseResource, setBaseResourceAsPath, setBaseResourceAsString, setCrossContextDispatchSupported, setErrorHandler, setProtectedTargets, setTempDirectoryPersistent, setVirtualHostsMethods inherited from class Handler.WrappergetHandlerMethods inherited from class Handler.AbstractContainerfindContainerOf, getDescendant, getDescendants, isDynamic, setDynamicMethods inherited from class Handler.AbstractgetServerMethods inherited from class ContainerLifeCycleaddBean, addBean, addManaged, contains, dump, dump, dumpObjects, dumpStdErr, getBean, getBeans, getBeans, getContainedBeans, getContainedBeans, installBean, installBean, isAuto, isManaged, isUnmanaged, manage, removeBean, removeBeans, setBeans, start, stop, unmanage, updateBean, updateBean, updateBeans, updateBeansMethods inherited from class AbstractLifeCyclegetEventListeners, getState, getState, isFailed, isRunning, isStarted, isStarting, isStopped, isStopping, setEventListeners, start, stopMethods inherited from class Objectclone, equals, finalize, getClass, hashCode, notify, notifyAll, wait, wait, waitMethods inherited from interface AttributesasAttributeMap, equals, hashCodeMethods inherited from interface ContainergetCachedBeans, getEventListenersMethods inherited from interface Dumpable.DumpableContainerisDumpableMethods inherited from interface Handler.ContainergetContainer, getDescendant, getDescendants, getDescendantsMethods inherited from interface Handler.SingletongetHandlers, getTail, setHandlerMethods inherited from interface LifeCycleisFailed, isRunning, isStarted, isStarting, isStopped, isStopping, start, stopMethods inherited from interface WebAppClassLoader.ContextisServerResource, isSystemResource, newResource
- 
Field Details- 
WEB_DEFAULTS_XML- See Also:
 
- 
SERVER_SYS_CLASSESDeprecated, for removal: This API element is subject to removal in a future version.useWebAppClassLoading.PROTECTED_CLASSES_ATTRIBUTEinstead.- See Also:
 
- 
SERVER_SRV_CLASSESDeprecated, for removal: This API element is subject to removal in a future version.useWebAppClassLoading.HIDDEN_CLASSES_ATTRIBUTEinstead.- See Also:
 
- 
__dftSystemClassesDeprecated, for removal: This API element is subject to removal in a future version.
- 
__dftServerClassesDeprecated, for removal: This API element is subject to removal in a future version.
 
- 
- 
Constructor Details- 
WebAppContextpublic WebAppContext()
- 
WebAppContext
- 
WebAppContext
- 
WebAppContextpublic WebAppContext(SessionHandler sessionHandler, SecurityHandler securityHandler, ServletHandler servletHandler, ErrorHandler errorHandler) - Parameters:
- sessionHandler- SessionHandler for this web app
- securityHandler- SecurityHandler for this web app
- servletHandler- ServletHandler for this web app
- errorHandler- ErrorHandler for this web app
 
- 
WebAppContextpublic WebAppContext(String contextPath, SessionHandler sessionHandler, SecurityHandler securityHandler, ServletHandler servletHandler, ErrorHandler errorHandler, int options) - Parameters:
- contextPath- the context path
- sessionHandler- SessionHandler for this web app
- securityHandler- SecurityHandler for this web app
- servletHandler- ServletHandler for this web app
- errorHandler- ErrorHandler for this web app
- options- the options (- ServletContextHandler.SESSIONSand/or- ServletContextHandler.SECURITY)
 
 
- 
- 
Method Details- 
getCurrentWebAppContext
- 
initializeDefaults- Specified by:
- initializeDefaultsin interface- Deployable
 
- 
isContextPathDefaultpublic boolean isContextPathDefault()
- 
setContextPath- Overrides:
- setContextPathin class- ServletContextHandler
- Parameters:
- contextPath- The _contextPath to set.
 
- 
setDefaultContextPath
- 
setDisplayName- Overrides:
- setDisplayNamein class- ContextHandler
- Parameters:
- servletContextName- The servletContextName to set.
 
- 
setResourceAlias
- 
getResourceAliases
- 
setResourceAliases
- 
getResourceAlias
- 
removeResourceAlias
- 
setClassLoaderDescription copied from class:ContextHandlerTheClassLoaderto set as thethread's context classloaderwhen the thread executing this handler enters the scope of this context.- Overrides:
- setClassLoaderin class- ContextHandler
- Parameters:
- classLoader- the- ClassLoaderor- nullto avoid changing the thread's context classloader.
 
- 
getResourceFactory
- 
getResourceDescription copied from class:ServletContextHandlerAttempt to get a Resource from the Context.- Overrides:
- getResourcein class- ServletContextHandler
- Parameters:
- pathInContext- the path within the base resource to attempt to get
- Returns:
- the resource, or null if not available.
- Throws:
- MalformedURLException- if unable to form a Resource from the provided path
 
- 
isConfigurationDiscoveredpublic boolean isConfigurationDiscovered()Is the context Automatically configured.- Returns:
- true if configuration discovery.
 
- 
setConfigurationDiscoveredpublic void setConfigurationDiscovered(boolean discovered) Set the configuration discovery mode. If configuration discovery is set to true, then the JSR315 servlet 3.0 discovered configuration features are enabled. These are:- Web Fragments
- META-INF/resource directories
 - Parameters:
- discovered- true if configuration discovery is enabled for automatic configuration from the context
 
- 
preConfigurePre configure the web application.The method is normally called from AbstractLifeCycle.start(). It performs the discovery of the configurations to be applied to this context, specifically:- Instantiate the Configurationinstances with a call toloadConfigurations().
- Instantiates a classloader (if one is not already set)
- Calls the Configuration.preConfigure(WebAppContext)method of all Configuration instances.
 - Throws:
- Exception- if unable to pre configure
 
- Instantiate the 
- 
configureClassLoaderConfigure the contextClassLoader, potentially wrapping it.- Parameters:
- loader- The loader initially set on this context by- setClassLoader(ClassLoader)
- Returns:
- Either the configured loader, or a new ClassLoaderthat uses the loader.
 
- 
createTempDirectoryprotected void createTempDirectory()Description copied from class:ContextHandlerCreate the temporary directory. If the directory exists, but is not persistent, then it is first deleted and then recreated. Once created, this method is a noop if called again before stopping the context. - Overrides:
- createTempDirectoryin class- ContextHandler
 
- 
configure
- 
postConfigure
- 
doStartDescription copied from class:ContainerLifeCycleStarts the managed lifecycle beans in the order they were added.- Overrides:
- doStartin class- ServletContextHandler
- Throws:
- Exception- If there was a problem starting. Will cause a transition to FAILED state
 
- 
destroypublic void destroy()Description copied from class:ContainerLifeCycleDestroys the managed Destroyable beans in the reverse order they were added.- Specified by:
- destroyin interface- Destroyable
- Overrides:
- destroyin class- ContextHandler
 
- 
getConfigurationClasses@ManagedAttribute(value="configuration classes used to configure webapp", readonly=true) public String[] getConfigurationClasses()- Returns:
- Returns the configurations.
 
- 
getConfigurations- Returns:
- Returns the configurations.
 
- 
getDefaultsDescriptor@ManagedAttribute(value="default web.xml deascriptor applied before standard web.xml", readonly=true) public String getDefaultsDescriptor()The default descriptor is a web.xml format file that is applied to the context before the standard WEB-INF/web.xml- Returns:
- Returns the defaultsDescriptor.
 
- 
getOverrideDescriptorThe override descriptor is a web.xml format file that is applied to the context after the standard WEB-INF/web.xml- Returns:
- Returns the Override Descriptor.
 
- 
getOverrideDescriptors@ManagedAttribute(value="web.xml deascriptors applied after standard web.xml", readonly=true) public List<String> getOverrideDescriptors()An override descriptor is a web.xml format file that is applied to the context after the standard WEB-INF/web.xml- Returns:
- Returns the Override Descriptor list
 
- 
getPermissions- Specified by:
- getPermissionsin interface- WebAppClassLoader.Context
- Returns:
- Returns the permissions.
 
- 
setHiddenClassMatcherSet the hidden (server) classes patterns.These classes/packages are used to implement the server and are hidden from the context. If the context needs to load these classes, it must have its own copy of them in WEB-INF/lib or WEB-INF/classes. - Parameters:
- hiddenClasses- the server classes pattern
 
- 
setProtectedClassMatcherSet the protected (system) classes patterns.These classes/packages are provided by the JVM and cannot be replaced by classes of the same name from WEB-INF, regardless of the value of setParentLoaderPriority(boolean).- Parameters:
- protectedClasses- the system classes pattern
 
- 
addHiddenClassMatcherAdd a ClassMatcher for hidden (server) classes by combining with any existing matcher.- Parameters:
- hiddenClasses- The class matcher of patterns to add to the server ClassMatcher
 
- 
addProtectedClassMatcherAdd a ClassMatcher for protected (system) classes by combining with any existing matcher.- Parameters:
- protectedClasses- The class matcher of patterns to add to the system ClassMatcher
 
- 
getProtectedClassMatcher- Returns:
- The ClassMatcher used to match System (protected) classes
 
- 
getHiddenClassMatcher- Returns:
- The ClassMatcher used to match Server (hidden) classes
 
- 
getProtectedClasses@ManagedAttribute(value="classes and packages protected by context classloader", readonly=true) public String[] getProtectedClasses()
- 
getHiddenClasses@ManagedAttribute(value="classes and packages hidden by the context classloader", readonly=true) public String[] getHiddenClasses()
- 
isHiddenClassDescription copied from interface:ClassVisibilityCheckerIs the class a Hidden (Server) Class. A Server class is a class that is part of the implementation of the server and is NOT visible to a web application. The web application may provide its own implementation of the class, to be loaded from WEB-INF/lib or WEB-INF/classes- Specified by:
- isHiddenClassin interface- ClassVisibilityChecker
- Parameters:
- clazz- The fully qualified name of the class.
- Returns:
- True if the class is a server class.
 
- 
isProtectedClassDescription copied from interface:ClassVisibilityCheckerIs the class a Protected (System) Class. A System class is a class that is visible to a web application, but that cannot be overridden by the contents of WEB-INF/lib or WEB-INF/classes- Specified by:
- isProtectedClassin interface- ClassVisibilityChecker
- Parameters:
- clazz- The fully qualified name of the class.
- Returns:
- True if the class is a system class.
 
- 
isHiddenResource- Specified by:
- isHiddenResourcein interface- WebAppClassLoader.Context
 
- 
isProtectedResource- Specified by:
- isProtectedResourcein interface- WebAppClassLoader.Context
 
- 
setServerClassMatcher@Deprecated(since="12.0.8", forRemoval=true) public void setServerClassMatcher(ClassMatcher serverClasses) Deprecated, for removal: This API element is subject to removal in a future version.
- 
setSystemClassMatcher@Deprecated(since="12.0.8", forRemoval=true) public void setSystemClassMatcher(ClassMatcher systemClasses) Deprecated, for removal: This API element is subject to removal in a future version.
- 
addServerClassMatcher@Deprecated(since="12.0.8", forRemoval=true) public void addServerClassMatcher(ClassMatcher serverClasses) Deprecated, for removal: This API element is subject to removal in a future version.
- 
addSystemClassMatcher@Deprecated(since="12.0.8", forRemoval=true) public void addSystemClassMatcher(ClassMatcher systemClasses) Deprecated, for removal: This API element is subject to removal in a future version.
- 
getSystemClassMatcherDeprecated, for removal: This API element is subject to removal in a future version.
- 
getServerClassMatcherDeprecated, for removal: This API element is subject to removal in a future version.
- 
getSystemClassesDeprecated, for removal: This API element is subject to removal in a future version.
- 
getServerClassesDeprecated, for removal: This API element is subject to removal in a future version.
- 
isServerClassDeprecated, for removal: This API element is subject to removal in a future version.Description copied from interface:ClassVisibilityCheckerIs the class a Server Class. A Server class is a class that is part of the implementation of the server and is NOT visible to a web application. The web application may provide its own implementation of the class, to be loaded from WEB-INF/lib or WEB-INF/classes- Specified by:
- isServerClassin interface- ClassVisibilityChecker
- Parameters:
- clazz- The fully qualified name of the class.
- Returns:
- True if the class is a server class.
 
- 
isSystemClassDeprecated, for removal: This API element is subject to removal in a future version.Description copied from interface:ClassVisibilityCheckerIs the class a System Class. A System class is a class that is visible to a web application, but that cannot be overridden by the contents of WEB-INF/lib or WEB-INF/classes- Specified by:
- isSystemClassin interface- ClassVisibilityChecker
- Parameters:
- clazz- The fully qualified name of the class.
- Returns:
- True if the class is a system class.
 
- 
setServer
- 
getWar- Returns:
- Returns the war as a file or URL string (Resource).
The war may be different to the @link ContextHandler.getBaseResource()if the war has been expanded and/or copied.
 
- 
getWebInf- Throws:
- IOException
 
- 
isDistributable- Returns:
- Returns the distributable.
 
- 
isExtractWAR- Returns:
- Returns the extractWAR.
 
- 
isCopyWebDir@ManagedAttribute(value="webdir copied on deploy (allows hot replacement on windows)", readonly=true) public boolean isCopyWebDir()- Returns:
- True if the webdir is copied (to allow hot replacement of jars on windows)
 
- 
isCopyWebInfpublic boolean isCopyWebInf()- Returns:
- True if the web-inf lib and classes directories are copied (to allow hot replacement of jars on windows)
 
- 
isParentLoaderPriority@ManagedAttribute(value="parent classloader given priority", readonly=true) public boolean isParentLoaderPriority()- Specified by:
- isParentLoaderPriorityin interface- WebAppClassLoader.Context
- Returns:
- True if the classloader should delegate first to the parent classloader (standard java behaviour) or false if the classloader should first try to load from WEB-INF/lib or WEB-INF/classes (servlet spec recommendation). Default is false or can be set by the system property org.eclipse.jetty.server.webapp.parentLoaderPriority
 
- 
loadConfigurationsprotected void loadConfigurations()
- 
newConfigurations
- 
newServletContextApi- Overrides:
- newServletContextApiin class- ServletContextHandler
 
- 
toString- Overrides:
- toStringin class- ContextHandler
 
- 
dumpDescription copied from interface:DumpableDump this object (and children) into an Appendable using the provided indent after any new lines. The indent should not be applied to the first object dumped.- Specified by:
- dumpin interface- Dumpable
- Overrides:
- dumpin class- ServletContextHandler
- Parameters:
- out- The appendable to dump to
- indent- The indent to apply after any new lines.
- Throws:
- IOException- if unable to write to Appendable
 
- 
setConfigurationClasses- Parameters:
- configurations- The configuration class names. If setConfigurations is not called these classes are used to create a configurations array.
 
- 
setConfigurationClasses
- 
setConfigurations- Parameters:
- configurations- The configurations to set.
 
- 
setConfigurations- Parameters:
- configurations- The configurations to set.
 
- 
addConfiguration
- 
getConfiguration
- 
removeConfiguration
- 
removeConfiguration
- 
setDefaultsDescriptorThe default descriptor is a web.xml format file that is applied to the context before the standard WEB-INF/web.xml- Parameters:
- defaultsDescriptor- The defaultsDescriptor to set.
 
- 
setOverrideDescriptorThe override descriptor is a web.xml format file that is applied to the context after the standard WEB-INF/web.xml- Parameters:
- overrideDescriptor- The overrideDescritpor to set.
 
- 
setOverrideDescriptors
- 
addOverrideDescriptorThe override descriptor is a web.xml format file that is applied to the context after the standard WEB-INF/web.xml- Parameters:
- overrideDescriptor- The overrideDescriptor (file or URL) to add.
 
- 
getDescriptor- Returns:
- the web.xml descriptor to use. If set to null, WEB-INF/web.xml is used if it exists.
 
- 
setDescriptorSet the web.xml descriptor to use. If set to null, WEB-INF/web.xml is used if it exists..- Parameters:
- descriptor- the web.xml descriptor to use. If set to null, WEB-INF/web.xml is used if it exists.
 
- 
setDistributablepublic void setDistributable(boolean distributable) - Parameters:
- distributable- The distributable to set.
 
- 
removeEventListenerDescription copied from interface:ContainerRemove an event listener.- Specified by:
- removeEventListenerin interface- Container
- Specified by:
- removeEventListenerin interface- LifeCycle
- Overrides:
- removeEventListenerin class- ServletContextHandler
- Parameters:
- listener- the listener to remove
- Returns:
- true if the listener was removed
- See Also:
 
- 
setExtractWARpublic void setExtractWAR(boolean extractWAR) - Parameters:
- extractWAR- True if war files are extracted
 
- 
setCopyWebDirpublic void setCopyWebDir(boolean copy) - Parameters:
- copy- True if the webdir is copied (to allow hot replacement of jars)
 
- 
setCopyWebInfpublic void setCopyWebInf(boolean copyWebInf) - Parameters:
- copyWebInf- True if the web-inf lib and classes directories are copied (to allow hot replacement of jars on windows)
 
- 
setParentLoaderPrioritypublic void setParentLoaderPriority(boolean java2compliant) - Parameters:
- java2compliant- True if the classloader should delegate first to the parent classloader (standard java behaviour) or false if the classloader should first try to load from WEB-INF/lib or WEB-INF/classes (servlet spec recommendation). Default is false or can be set by the system property org.eclipse.jetty.server.webapp.parentLoaderPriority
 
- 
setPermissions- Parameters:
- permissions- The permissions to set.
 
- 
setContextWhiteListSet the context white list In certain circumstances you want may want to deny access of one webapp from another when you may not fully trust the webapp. Setting this white list will enable a check when a servlet calledServletContextHandler.Context#getContext(String), validating that the uriInPath for the given webapp has been declaratively allows access to the context.- Parameters:
- contextWhiteList- the whitelist of contexts
 
- 
setWarSet the war of the webapp. From this value aContextHandler.setBaseResource(Resource)value is computed byWebInfConfiguration, which may be changed from the war URI by unpacking and/or copying.- Parameters:
- war- The war to set as a file name or URL.
 
- 
setWarResource
- 
getExtraClasspath@ManagedAttribute(value="extra classpath for context classloader", readonly=true) public List<Resource> getExtraClasspath()- Specified by:
- getExtraClasspathin interface- WebAppClassLoader.Context
- Returns:
- Comma or semicolon separated path of filenames or URLs pointing to directories or jar files. Directories should end with '/'.
 
- 
setExtraClasspathSet the Extra ClassPath via delimited String.This is a convenience method for setExtraClasspath(List)- Parameters:
- extraClasspath- Comma or semicolon separated path of filenames or URLs pointing to directories or jar files. Directories should end with '/'.
- See Also:
 
- 
setExtraClasspath
- 
isLogUrlOnStartpublic boolean isLogUrlOnStart()
- 
setLogUrlOnStartpublic void setLogUrlOnStart(boolean logOnStart) Sets whether or not the web app name and URL is logged on startup- Parameters:
- logOnStart- whether or not the log message is created
 
- 
isAllowDuplicateFragmentNamespublic boolean isAllowDuplicateFragmentNames()
- 
setAllowDuplicateFragmentNamespublic void setAllowDuplicateFragmentNames(boolean allowDuplicateFragmentNames) 
- 
startContextDescription copied from class:ServletContextHandlerFinish constructing handlers and link them together.- Overrides:
- startContextin class- ServletContextHandler
- Throws:
- Exception
 
- 
stopContext- Overrides:
- stopContextin class- ServletContextHandler
- Throws:
- Exception
 
- 
startWebappContinue thestartContext()before callingsuper.startContext().- Throws:
- Exception- If there was a problem starting
 
- 
stopWebappContinue thestopContext()before callingsuper.stopContext().- Throws:
- Exception- If there was a problem stopping
 
- 
cleanupAfterStopPrevent the temp directory from being deleted during the normal stop sequence, and require thatContextHandler.cleanupAfterStop()is explicitly called after the webapp classloader is closed- Overrides:
- cleanupAfterStopin class- ContextHandler
- Throws:
- Exception
 
- 
setServletSecuritypublic Set<String> setServletSecurity(jakarta.servlet.ServletRegistration.Dynamic registration, jakarta.servlet.ServletSecurityElement servletSecurityElement) Description copied from class:ServletContextHandlerDelegate for ServletRegistration.Dynamic.setServletSecurity method- Overrides:
- setServletSecurityin class- ServletContextHandler
- Parameters:
- registration- ServletRegistration.Dynamic instance that setServletSecurity was called on
- servletSecurityElement- new security info
- Returns:
- the set of exact URL mappings currently associated with the registration that are also present in the web.xml security constraints and thus will be unaffected by this call.
 
- 
getMetaData
- 
makeTempDirectoryDescription copied from class:ContextHandlerGenerate a reasonable name for the temp directory because one has not been explicitly configured by the user withContextHandler.setTempDirectory(File). The directory may also be created, if it is not persistent. If it is persistent it will be created as necessary byContextHandler.createTempDirectory()later during the startup of the context.- Overrides:
- makeTempDirectoryin class- ContextHandler
- Throws:
- Exception- IllegalStateException if the parent tmp directory does not exist, or IOException if the child tmp directory cannot be created.
 
- 
getCanonicalNameForTmpDirDescription copied from class:ContextHandlerCreate a canonical name for a context temp directory.The form of the name is: "jetty-"+host+"-"+port+"-"+resourceBase+"-_"+context+"-"+virtualhost+"-"+randomdigits+".dir" host and port uniquely identify the server context and virtual host uniquely identify the context randomdigits ensure every tmp directory is unique- Overrides:
- getCanonicalNameForTmpDirin class- ContextHandler
- Returns:
- the canonical name for the context temp directory
 
- 
getResourceForTempDirNameIf the webapp has no baseresource yet, use the war to make the temp directory name.- Overrides:
- getResourceForTempDirNamein class- ContextHandler
- Returns:
- the baseresource if non null, or the war
 
- 
addServerClasses@Deprecated(since="12.0.8", forRemoval=true) public static void addServerClasses(Server server, String... patterns) Deprecated, for removal: This API element is subject to removal in a future version.Add a Server Class pattern to use for all WebAppContexts.- Parameters:
- server- The- Serverinstance to add classes to
- patterns- the patterns to use
- See Also:
 
- 
addSystemClasses@Deprecated(since="12.0.8", forRemoval=true) public static void addSystemClasses(Server server, String... patterns) Deprecated, for removal: This API element is subject to removal in a future version.Add a System Class pattern to use for all WebAppContexts.- Parameters:
- server- The- Serverinstance to add classes to
- patterns- the patterns to use
- See Also:
 
 
- 
WebAppClassLoading.DEFAULT_HIDDEN_CLASSES