Class WebappClassLoaderBase
- java.lang.Object
- 
- java.lang.ClassLoader
- 
- java.security.SecureClassLoader
- 
- java.net.URLClassLoader
- 
- org.apache.catalina.loader.WebappClassLoaderBase
 
 
 
 
- 
- All Implemented Interfaces:
- java.io.Closeable,- java.lang.AutoCloseable,- Lifecycle,- WebappProperties,- InstrumentableClassLoader,- PermissionCheck
 - Direct Known Subclasses:
- ParallelWebappClassLoader,- WebappClassLoader
 
 public abstract class WebappClassLoaderBase extends java.net.URLClassLoader implements Lifecycle, InstrumentableClassLoader, WebappProperties, PermissionCheck Specialized web application class loader.This class loader is a full reimplementation of the URLClassLoaderfrom the JDK. It is designed to be fully compatible with a normalURLClassLoader, although its internal behavior may be completely different.IMPLEMENTATION NOTE - By default, this class loader follows the delegation model required by the specification. The bootstrap class loader will be queried first, then the local repositories, and only then delegation to the parent class loader will occur. This allows the web application to override any shared class except the classes from J2SE. Special handling is provided from the JAXP XML parser interfaces, the JNDI interfaces, and the classes from the servlet API, which are never loaded from the webapp repositories. The delegateproperty allows an application to modify this behavior to move the parent class loader ahead of the local repositories.IMPLEMENTATION NOTE - Due to limitations in Jasper compilation technology, any repository which contains classes from the servlet API will be ignored by the class loader. IMPLEMENTATION NOTE - The class loader generates source URLs which include the full JAR URL when a class is loaded from a JAR file, which allows setting security permission at the class level, even when a class is contained inside a JAR. IMPLEMENTATION NOTE - Local repositories are searched in the order they are added via the initial constructor. IMPLEMENTATION NOTE - No check for sealing violations or security is made unless a security manager is present. IMPLEMENTATION NOTE - As of 8.0, this class loader implements InstrumentableClassLoader, permitting web application classes to instrument other classes in the same web application. It does not permit instrumentation of system or container classes or classes in other web apps.- Author:
- Remy Maucherat, Craig R. McClanahan
 
- 
- 
Nested Class SummaryNested Classes Modifier and Type Class Description protected classWebappClassLoaderBase.PrivilegedFindClassByNameprotected static classWebappClassLoaderBase.PrivilegedGetClassLoaderprotected classWebappClassLoaderBase.PrivilegedJavaseGetResource- 
Nested classes/interfaces inherited from interface org.apache.catalina.LifecycleLifecycle.SingleUse
 
- 
 - 
Field SummaryFields Modifier and Type Field Description protected java.security.PermissionallPermissionDeprecated.Unused.protected booleandelegateShould this class loader delegate to the parent class loader before searching its own repositories (i.e. the usual Java2 delegation model)?protected java.util.HashMap<java.lang.String,java.security.PermissionCollection>loaderPCThe PermissionCollection for each CodeSource for a web application context.protected java.lang.ClassLoaderparentThe parent class loader.protected java.util.ArrayList<java.security.Permission>permissionListA list of read File Permission's required if this loader is for a web application context.protected java.util.Map<java.lang.String,ResourceEntry>resourceEntriesThe cache of ResourceEntry for classes and resources we have loaded, keyed by resource path, not binary name.protected WebResourceRootresourcesAssociated web resources for this webapp.protected java.lang.SecurityManagersecurityManagerInstance of the SecurityManager installed.protected static StringManagersmThe string manager for this package.- 
Fields inherited from interface org.apache.catalina.LifecycleAFTER_DESTROY_EVENT, AFTER_INIT_EVENT, AFTER_START_EVENT, AFTER_STOP_EVENT, BEFORE_DESTROY_EVENT, BEFORE_INIT_EVENT, BEFORE_START_EVENT, BEFORE_STOP_EVENT, CONFIGURE_START_EVENT, CONFIGURE_STOP_EVENT, PERIODIC_EVENT, START_EVENT, STOP_EVENT
 
- 
 - 
Constructor SummaryConstructors Modifier Constructor Description protectedWebappClassLoaderBase()Construct a new ClassLoader with no defined repositories and no parent ClassLoader.protectedWebappClassLoaderBase(java.lang.ClassLoader parent)Construct a new ClassLoader with no defined repositories and the given parent ClassLoader.
 - 
Method SummaryAll Methods Instance Methods Concrete Methods Deprecated Methods Modifier and Type Method Description voidaddLifecycleListener(LifecycleListener listener)Add a lifecycle event listener to this component.voidaddTransformer(java.lang.instrument.ClassFileTransformer transformer)Adds the specified class file transformer to this class loader.protected voidaddURL(java.net.URL url)booleancheck(java.security.Permission permission)Does this component have the given permission?protected voidcheckStateForClassLoading(java.lang.String className)protected voidcheckStateForResourceLoading(java.lang.String resource)protected voidclearReferences()Clear references.protected voidcopyStateWithoutTransformers(WebappClassLoaderBase base)voiddestroy()Prepare to discard the object.protected java.lang.Class<?>doDefineClass(java.lang.String name, byte[] b, int off, int len, java.security.ProtectionDomain protectionDomain)protected booleanfilter(java.lang.String name)Deprecated.Usefilter(String, boolean)This will be removed in Tomcat 9protected booleanfilter(java.lang.String name, boolean isClassName)Filter classes.java.lang.Class<?>findClass(java.lang.String name)Find the specified class in our local repositories, if possible.protected java.lang.Class<?>findClassInternal(java.lang.String name)Find specified class in local repositories.LifecycleListener[]findLifecycleListeners()Get the lifecycle listeners associated with this lifecycle.protected java.lang.Class<?>findLoadedClass0(java.lang.String name)Finds the class with the given name if it has previously been loaded and cached by this class loader, and return the Class object.java.net.URLfindResource(java.lang.String name)Find the specified resource in our local repository, and return aURLreferring to it, ornullif this resource cannot be found.java.util.Enumeration<java.net.URL>findResources(java.lang.String name)Return an enumeration ofURLsrepresenting all of the resources with the given name.booleangetClearReferencesHttpClientKeepAliveThread()booleangetClearReferencesLogFactoryRelease()booleangetClearReferencesObjectStreamClassCaches()booleangetClearReferencesRmiTargets()booleangetClearReferencesStopThreads()booleangetClearReferencesStopTimerThreads()booleangetClearReferencesThreadLocals()java.lang.StringgetContextName()booleangetDelegate()Return the "delegate first" flag for this class loader.java.lang.StringgetHostName()Returns a name for the logging system to use for the Host where the web application, if any, associated with the class loader is deployed.protected java.lang.ClassLoadergetJavaseClassLoader()protected java.security.PermissionCollectiongetPermissions(java.security.CodeSource codeSource)Get the Permissions for a CodeSource.java.net.URLgetResource(java.lang.String name)Find the resource with the given name.java.io.InputStreamgetResourceAsStream(java.lang.String name)Find the resource with the given name, and return an input stream that can be used for reading it.WebResourceRootgetResources()Deprecated.This will be removed in Tomcat 10.1.x onwardsjava.util.Enumeration<java.net.URL>getResources(java.lang.String name)java.lang.StringgetServiceName()Returns a name for the logging system to use for the Service where the Host, if any, associated with the class loader is deployed.booleangetSkipMemoryLeakChecksOnJvmShutdown()LifecycleStategetState()Obtain the current state of the source component.java.lang.StringgetStateName()Obtain a textual representation of the current component state.java.net.URL[]getURLs()java.lang.StringgetWebappName()Returns a name for the logging system to use for the web application, if any, associated with the class loader.booleanhasLoggingConfig()Enables JULI to determine if the web application includes a local configuration without JULI having to look for the file which it may not have permission to do when running under a SecurityManager.voidinit()Prepare the component for starting.protected booleanisPackageSealed(java.lang.String name, java.util.jar.Manifest man)Returns true if the specified package name is sealed according to the given manifest.java.lang.Class<?>loadClass(java.lang.String name)Load the class with the specified name.java.lang.Class<?>loadClass(java.lang.String name, boolean resolve)Load the class with the specified name, searching using the following algorithm until it finds and returns the class.booleanmodified()Have one or more classes or resources been modified so that a reload is appropriate?protected voidrefreshPolicy()Refresh the system policy file, to pick up eventual changes.voidremoveLifecycleListener(LifecycleListener listener)Remove a lifecycle event listener from this component.voidremoveTransformer(java.lang.instrument.ClassFileTransformer transformer)Removes the specified class file transformer from this class loader.voidsetClearReferencesHttpClientKeepAliveThread(boolean clearReferencesHttpClientKeepAliveThread)Set the clearReferencesHttpClientKeepAliveThread feature for this Context.voidsetClearReferencesLogFactoryRelease(boolean clearReferencesLogFactoryRelease)Set the clearReferencesLogFactoryRelease feature for this Context.voidsetClearReferencesObjectStreamClassCaches(boolean clearReferencesObjectStreamClassCaches)voidsetClearReferencesRmiTargets(boolean clearReferencesRmiTargets)voidsetClearReferencesStopThreads(boolean clearReferencesStopThreads)Set the clearReferencesStopThreads feature for this Context.voidsetClearReferencesStopTimerThreads(boolean clearReferencesStopTimerThreads)Set the clearReferencesStopTimerThreads feature for this Context.voidsetClearReferencesThreadLocals(boolean clearReferencesThreadLocals)voidsetDelegate(boolean delegate)Set the "delegate first" flag for this class loader.protected voidsetJavaseClassLoader(java.lang.ClassLoader classLoader)voidsetResources(WebResourceRoot resources)Set associated resources.voidsetSkipMemoryLeakChecksOnJvmShutdown(boolean skipMemoryLeakChecksOnJvmShutdown)voidstart()Start the class loader.voidstop()Stop the class loader.java.lang.StringtoString()- 
Methods inherited from class java.lang.ClassLoaderclearAssertionStatus, defineClass, defineClass, defineClass, defineClass, definePackage, findClass, findLibrary, findLoadedClass, findResource, findSystemClass, getClassLoadingLock, getDefinedPackage, getDefinedPackages, getName, getPackage, getPackages, getParent, getPlatformClassLoader, getSystemClassLoader, getSystemResource, getSystemResourceAsStream, getSystemResources, getUnnamedModule, isRegisteredAsParallelCapable, registerAsParallelCapable, resolveClass, resources, setClassAssertionStatus, setDefaultAssertionStatus, setPackageAssertionStatus, setSigners
 - 
Methods inherited from class java.lang.Objectclone, equals, finalize, getClass, hashCode, notify, notifyAll, wait, wait, wait
 - 
Methods inherited from interface org.apache.tomcat.InstrumentableClassLoadercopyWithoutTransformers
 
- 
 
- 
- 
- 
Field Detail- 
smprotected static final StringManager sm The string manager for this package.
 - 
resourcesprotected WebResourceRoot resources Associated web resources for this webapp.
 - 
resourceEntriesprotected final java.util.Map<java.lang.String,ResourceEntry> resourceEntries The cache of ResourceEntry for classes and resources we have loaded, keyed by resource path, not binary name. Path is used as the key since resources may be requested by binary name (classes) or path (other resources such as property files) and the mapping from binary name to path is unambiguous but the reverse mapping is ambiguous.
 - 
delegateprotected boolean delegate Should this class loader delegate to the parent class loader before searching its own repositories (i.e. the usual Java2 delegation model)? If set tofalse, this class loader will search its own repositories first, and delegate to the parent only if the class or resource is not found locally. Note that the default,false, is the behavior called for by the servlet specification.
 - 
permissionListprotected final java.util.ArrayList<java.security.Permission> permissionList A list of read File Permission's required if this loader is for a web application context.
 - 
loaderPCprotected final java.util.HashMap<java.lang.String,java.security.PermissionCollection> loaderPC The PermissionCollection for each CodeSource for a web application context.
 - 
securityManagerprotected final java.lang.SecurityManager securityManager Instance of the SecurityManager installed.
 - 
parentprotected final java.lang.ClassLoader parent The parent class loader.
 - 
allPermission@Deprecated protected final java.security.Permission allPermission Deprecated.Unused. This will be removed in Tomcat 9.All permission.
 
- 
 - 
Constructor Detail- 
WebappClassLoaderBaseprotected WebappClassLoaderBase() Construct a new ClassLoader with no defined repositories and no parent ClassLoader.
 - 
WebappClassLoaderBaseprotected WebappClassLoaderBase(java.lang.ClassLoader parent) Construct a new ClassLoader with no defined repositories and the given parent ClassLoader.Method is used via reflection - see WebappLoader.createClassLoader()- Parameters:
- parent- Our parent class loader
 
 
- 
 - 
Method Detail- 
getResources@Deprecated public WebResourceRoot getResources() Deprecated.This will be removed in Tomcat 10.1.x onwardsUnused. Always returnsnull.- Returns:
- associated resources.
 
 - 
setResourcespublic void setResources(WebResourceRoot resources) Set associated resources.- Parameters:
- resources- the resources from which the classloader will load the classes
 
 - 
getContextNamepublic java.lang.String getContextName() - Returns:
- the context name for this class loader.
 
 - 
getDelegatepublic boolean getDelegate() Return the "delegate first" flag for this class loader.- Returns:
- trueif the class lookup will delegate to the parent first. The default in Tomcat is- false.
 
 - 
setDelegatepublic void setDelegate(boolean delegate) Set the "delegate first" flag for this class loader. If this flag is true, this class loader delegates to the parent class loader before searching its own repositories, as in an ordinary (non-servlet) chain of Java class loaders. If set tofalse(the default), this class loader will search its own repositories first, and delegate to the parent only if the class or resource is not found locally, as per the servlet specification.- Parameters:
- delegate- The new "delegate first" flag
 
 - 
getClearReferencesRmiTargetspublic boolean getClearReferencesRmiTargets() 
 - 
setClearReferencesRmiTargetspublic void setClearReferencesRmiTargets(boolean clearReferencesRmiTargets) 
 - 
getClearReferencesStopThreadspublic boolean getClearReferencesStopThreads() - Returns:
- the clearReferencesStopThreads flag for this Context.
 
 - 
setClearReferencesStopThreadspublic void setClearReferencesStopThreads(boolean clearReferencesStopThreads) Set the clearReferencesStopThreads feature for this Context.- Parameters:
- clearReferencesStopThreads- The new flag value
 
 - 
getClearReferencesStopTimerThreadspublic boolean getClearReferencesStopTimerThreads() - Returns:
- the clearReferencesStopTimerThreads flag for this Context.
 
 - 
setClearReferencesStopTimerThreadspublic void setClearReferencesStopTimerThreads(boolean clearReferencesStopTimerThreads) Set the clearReferencesStopTimerThreads feature for this Context.- Parameters:
- clearReferencesStopTimerThreads- The new flag value
 
 - 
getClearReferencesLogFactoryReleasepublic boolean getClearReferencesLogFactoryRelease() - Returns:
- the clearReferencesLogFactoryRelease flag for this Context.
 
 - 
setClearReferencesLogFactoryReleasepublic void setClearReferencesLogFactoryRelease(boolean clearReferencesLogFactoryRelease) Set the clearReferencesLogFactoryRelease feature for this Context.- Parameters:
- clearReferencesLogFactoryRelease- The new flag value
 
 - 
getClearReferencesHttpClientKeepAliveThreadpublic boolean getClearReferencesHttpClientKeepAliveThread() - Returns:
- the clearReferencesHttpClientKeepAliveThread flag for this Context.
 
 - 
setClearReferencesHttpClientKeepAliveThreadpublic void setClearReferencesHttpClientKeepAliveThread(boolean clearReferencesHttpClientKeepAliveThread) Set the clearReferencesHttpClientKeepAliveThread feature for this Context.- Parameters:
- clearReferencesHttpClientKeepAliveThread- The new flag value
 
 - 
getClearReferencesObjectStreamClassCachespublic boolean getClearReferencesObjectStreamClassCaches() 
 - 
setClearReferencesObjectStreamClassCachespublic void setClearReferencesObjectStreamClassCaches(boolean clearReferencesObjectStreamClassCaches) 
 - 
getClearReferencesThreadLocalspublic boolean getClearReferencesThreadLocals() 
 - 
setClearReferencesThreadLocalspublic void setClearReferencesThreadLocals(boolean clearReferencesThreadLocals) 
 - 
getSkipMemoryLeakChecksOnJvmShutdownpublic boolean getSkipMemoryLeakChecksOnJvmShutdown() 
 - 
setSkipMemoryLeakChecksOnJvmShutdownpublic void setSkipMemoryLeakChecksOnJvmShutdown(boolean skipMemoryLeakChecksOnJvmShutdown) 
 - 
addTransformerpublic void addTransformer(java.lang.instrument.ClassFileTransformer transformer) Adds the specified class file transformer to this class loader. The transformer will then be able to modify the bytecode of any classes loaded by this class loader after the invocation of this method.- Specified by:
- addTransformerin interface- InstrumentableClassLoader
- Parameters:
- transformer- The transformer to add to the class loader
 
 - 
removeTransformerpublic void removeTransformer(java.lang.instrument.ClassFileTransformer transformer) Removes the specified class file transformer from this class loader. It will no longer be able to modify the byte code of any classes loaded by the class loader after the invocation of this method. However, any classes already modified by this transformer will remain transformed.- Specified by:
- removeTransformerin interface- InstrumentableClassLoader
- Parameters:
- transformer- The transformer to remove
 
 - 
copyStateWithoutTransformersprotected void copyStateWithoutTransformers(WebappClassLoaderBase base) 
 - 
modifiedpublic boolean modified() Have one or more classes or resources been modified so that a reload is appropriate?- Returns:
- trueif there's been a modification
 
 - 
toStringpublic java.lang.String toString() - Overrides:
- toStringin class- java.lang.Object
 
 - 
doDefineClassprotected final java.lang.Class<?> doDefineClass(java.lang.String name, byte[] b, int off, int len, java.security.ProtectionDomain protectionDomain)
 - 
findClasspublic java.lang.Class<?> findClass(java.lang.String name) throws java.lang.ClassNotFoundExceptionFind the specified class in our local repositories, if possible. If not found, throwClassNotFoundException.- Overrides:
- findClassin class- java.net.URLClassLoader
- Parameters:
- name- The binary name of the class to be loaded
- Throws:
- java.lang.ClassNotFoundException- if the class was not found
 
 - 
findResourcepublic java.net.URL findResource(java.lang.String name) Find the specified resource in our local repository, and return aURLreferring to it, ornullif this resource cannot be found.- Overrides:
- findResourcein class- java.net.URLClassLoader
- Parameters:
- name- Name of the resource to be found
 
 - 
findResourcespublic java.util.Enumeration<java.net.URL> findResources(java.lang.String name) throws java.io.IOExceptionReturn an enumeration ofURLsrepresenting all of the resources with the given name. If no resources with this name are found, return an empty enumeration.- Overrides:
- findResourcesin class- java.net.URLClassLoader
- Parameters:
- name- Name of the resources to be found
- Throws:
- java.io.IOException- if an input/output error occurs
 
 - 
getResourcepublic java.net.URL getResource(java.lang.String name) Find the resource with the given name. A resource is some data (images, audio, text, etc.) that can be accessed by class code in a way that is independent of the location of the code. The name of a resource is a "/"-separated path name that identifies the resource. If the resource cannot be found, returnnull.This method searches according to the following algorithm, returning as soon as it finds the appropriate URL. If the resource cannot be found, returns null.- If the delegateproperty is set totrue, call thegetResource()method of the parent class loader, if any.
- Call findResource()to find this resource in our locally defined repositories.
- Call the getResource()method of the parent class loader, if any.
 - Overrides:
- getResourcein class- java.lang.ClassLoader
- Parameters:
- name- Name of the resource to return a URL for
 
- If the 
 - 
getResourcespublic java.util.Enumeration<java.net.URL> getResources(java.lang.String name) throws java.io.IOException- Overrides:
- getResourcesin class- java.lang.ClassLoader
- Throws:
- java.io.IOException
 
 - 
getResourceAsStreampublic java.io.InputStream getResourceAsStream(java.lang.String name) Find the resource with the given name, and return an input stream that can be used for reading it. The search order is as described forgetResource(), after checking to see if the resource data has been previously cached. If the resource cannot be found, returnnull.- Overrides:
- getResourceAsStreamin class- java.net.URLClassLoader
- Parameters:
- name- Name of the resource to return an input stream for
 
 - 
loadClasspublic java.lang.Class<?> loadClass(java.lang.String name) throws java.lang.ClassNotFoundExceptionLoad the class with the specified name. This method searches for classes in the same manner asloadClass(String, boolean)withfalseas the second argument.- Overrides:
- loadClassin class- java.lang.ClassLoader
- Parameters:
- name- The binary name of the class to be loaded
- Throws:
- java.lang.ClassNotFoundException- if the class was not found
 
 - 
loadClasspublic java.lang.Class<?> loadClass(java.lang.String name, boolean resolve) throws java.lang.ClassNotFoundExceptionLoad the class with the specified name, searching using the following algorithm until it finds and returns the class. If the class cannot be found, returnsClassNotFoundException.- Call findLoadedClass(String)to check if the class has already been loaded. If it has, the sameClassobject is returned.
- If the delegateproperty is set totrue, call theloadClass()method of the parent class loader, if any.
- Call findClass()to find this class in our locally defined repositories.
- Call the loadClass()method of our parent class loader, if any.
 resolveflag istrue, this method will then callresolveClass(Class)on the resulting Class object.- Overrides:
- loadClassin class- java.lang.ClassLoader
- Parameters:
- name- The binary name of the class to be loaded
- resolve- If- truethen resolve the class
- Throws:
- java.lang.ClassNotFoundException- if the class was not found
 
- Call 
 - 
checkStateForClassLoadingprotected void checkStateForClassLoading(java.lang.String className) throws java.lang.ClassNotFoundException- Throws:
- java.lang.ClassNotFoundException
 
 - 
checkStateForResourceLoadingprotected void checkStateForResourceLoading(java.lang.String resource) throws java.lang.IllegalStateException- Throws:
- java.lang.IllegalStateException
 
 - 
getPermissionsprotected java.security.PermissionCollection getPermissions(java.security.CodeSource codeSource) Get the Permissions for a CodeSource. If this instance of WebappClassLoaderBase is for a web application context, add read FilePermission for the appropriate resources.- Overrides:
- getPermissionsin class- java.net.URLClassLoader
- Parameters:
- codeSource- where the code was loaded from
- Returns:
- PermissionCollection for CodeSource
 
 - 
checkpublic boolean check(java.security.Permission permission) Description copied from interface:PermissionCheckDoes this component have the given permission?- Specified by:
- checkin interface- PermissionCheck
- Parameters:
- permission- The permission to test
- Returns:
- falseif a SecurityManager is enabled and the component does not have the given permission, otherwise- true
 
 - 
getURLspublic java.net.URL[] getURLs() Note that list of URLs returned by this method may not be complete. The web application class loader accesses class loader resources via the WebResourceRootwhich supports the arbitrary mapping of additional files, directories and contents of JAR files under WEB-INF/classes. Any such resources will not be included in the URLs returned here.- Overrides:
- getURLsin class- java.net.URLClassLoader
 
 - 
addLifecycleListenerpublic void addLifecycleListener(LifecycleListener listener) Add a lifecycle event listener to this component.- Specified by:
- addLifecycleListenerin interface- Lifecycle
- Parameters:
- listener- The listener to add
 
 - 
findLifecycleListenerspublic LifecycleListener[] findLifecycleListeners() Get the lifecycle listeners associated with this lifecycle. If this Lifecycle has no listeners registered, a zero-length array is returned.- Specified by:
- findLifecycleListenersin interface- Lifecycle
- Returns:
- An array containing the life cycle listeners associated with this life cycle. If this component has no listeners registered, a zero-length array is returned.
 
 - 
removeLifecycleListenerpublic void removeLifecycleListener(LifecycleListener listener) Remove a lifecycle event listener from this component.- Specified by:
- removeLifecycleListenerin interface- Lifecycle
- Parameters:
- listener- The listener to remove
 
 - 
getStatepublic LifecycleState getState() Obtain the current state of the source component.
 - 
getStateNamepublic java.lang.String getStateName() Obtain a textual representation of the current component state. Useful for JMX. The format of this string may vary between point releases and should not be relied upon to determine component state. To determine component state, useLifecycle.getState().- Specified by:
- getStateNamein interface- Lifecycle
- Returns:
- The name of the current component state.
 
 - 
initpublic void init() Description copied from interface:LifecyclePrepare the component for starting. This method should perform any initialization required post object creation. The followingLifecycleEvents will be fired in the following order:- INIT_EVENT: On the successful completion of component initialization.
 
 - 
startpublic void start() throws LifecycleExceptionStart the class loader.- Specified by:
- startin interface- Lifecycle
- Throws:
- LifecycleException- if a lifecycle error occurs
 
 - 
stoppublic void stop() throws LifecycleExceptionStop the class loader.- Specified by:
- stopin interface- Lifecycle
- Throws:
- LifecycleException- if a lifecycle error occurs
 
 - 
destroypublic void destroy() Description copied from interface:LifecyclePrepare to discard the object. The followingLifecycleEvents will be fired in the following order:- DESTROY_EVENT: On the successful completion of component destruction.
 
 - 
getJavaseClassLoaderprotected java.lang.ClassLoader getJavaseClassLoader() 
 - 
setJavaseClassLoaderprotected void setJavaseClassLoader(java.lang.ClassLoader classLoader) 
 - 
clearReferencesprotected void clearReferences() Clear references.
 - 
findClassInternalprotected java.lang.Class<?> findClassInternal(java.lang.String name) Find specified class in local repositories.- Parameters:
- name- The binary name of the class to be loaded
- Returns:
- the loaded class, or null if the class isn't found
 
 - 
isPackageSealedprotected boolean isPackageSealed(java.lang.String name, java.util.jar.Manifest man)Returns true if the specified package name is sealed according to the given manifest.- Parameters:
- name- Path name to check
- man- Associated manifest
- Returns:
- trueif the manifest associated says it is sealed
 
 - 
findLoadedClass0protected java.lang.Class<?> findLoadedClass0(java.lang.String name) Finds the class with the given name if it has previously been loaded and cached by this class loader, and return the Class object. If this class has not been cached, returnnull.- Parameters:
- name- The binary name of the resource to return
- Returns:
- a loaded class
 
 - 
refreshPolicyprotected void refreshPolicy() Refresh the system policy file, to pick up eventual changes.
 - 
filterprotected boolean filter(java.lang.String name, boolean isClassName)Filter classes.- Parameters:
- name- class name
- isClassName-- trueif name is a class name,- falseif name is a resource name
- Returns:
- trueif the class should be filtered
 
 - 
filter@Deprecated protected boolean filter(java.lang.String name) Deprecated.Usefilter(String, boolean)This will be removed in Tomcat 9Filter classes.- Parameters:
- name- class name
- Returns:
- trueif the class should be filtered
 
 - 
addURLprotected void addURL(java.net.URL url) - Overrides:
- addURLin class- java.net.URLClassLoader
 
 - 
getWebappNamepublic java.lang.String getWebappName() Description copied from interface:WebappPropertiesReturns a name for the logging system to use for the web application, if any, associated with the class loader.- Specified by:
- getWebappNamein interface- WebappProperties
- Returns:
- The name to use for the web application or null if none is available.
 
 - 
getHostNamepublic java.lang.String getHostName() Description copied from interface:WebappPropertiesReturns a name for the logging system to use for the Host where the web application, if any, associated with the class loader is deployed.- Specified by:
- getHostNamein interface- WebappProperties
- Returns:
- The name to use for the Host where the web application is deployed or null if none is available.
 
 - 
getServiceNamepublic java.lang.String getServiceName() Description copied from interface:WebappPropertiesReturns a name for the logging system to use for the Service where the Host, if any, associated with the class loader is deployed.- Specified by:
- getServiceNamein interface- WebappProperties
- Returns:
- The name to use for the Service where the Host is deployed or null if none is available.
 
 - 
hasLoggingConfigpublic boolean hasLoggingConfig() Description copied from interface:WebappPropertiesEnables JULI to determine if the web application includes a local configuration without JULI having to look for the file which it may not have permission to do when running under a SecurityManager.- Specified by:
- hasLoggingConfigin interface- WebappProperties
- Returns:
- trueif the web application includes a logging configuration at the standard location of /WEB-INF/classes/logging.properties.
 
 
- 
 
-