| 
 | |||||||||
| PREV CLASS NEXT CLASS | FRAMES NO FRAMES | ||||||||
| SUMMARY: NESTED | FIELD | CONSTR | METHOD | DETAIL: FIELD | CONSTR | METHOD | ||||||||
java.lang.Objectjava.lang.ClassLoader
java.security.SecureClassLoader
java.net.URLClassLoader
org.apache.catalina.loader.WebappClassLoader
public class WebappClassLoader
Specialized web application class loader.
 This class loader is a full reimplementation of the 
 URLClassLoader from the JDK. It is desinged to be fully
 compatible with a normal URLClassLoader, although its internal
 behavior may be completely different.
 
IMPLEMENTATION NOTE - This class loader faithfully follows the delegation model recommended in the specification. The system 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 repository.
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 and/or any subsequent
 calls to addRepository() or addJar().
 
IMPLEMENTATION NOTE - No check for sealing violations or security is made unless a security manager is present.
| Nested Class Summary | |
|---|---|
| protected  class | WebappClassLoader.PrivilegedFindResource | 
| protected  class | WebappClassLoader.PrivilegedGetClassLoader | 
| Field Summary | |
|---|---|
| protected  java.security.Permission | allPermissionAll permission. | 
| protected  boolean | delegateShould this class loader delegate to the parent class loader before searching its own repositories (i.e. the usual Java2 delegation model)? | 
| static boolean | ENABLE_CLEAR_REFERENCES | 
| protected  java.io.File[] | filesRepositories translated as path in the work directory (for Jasper originally), but which is used to generate fake URLs should getURLs be called. | 
| protected  boolean | hasExternalRepositoriesHas external repositories. | 
| protected  java.util.jar.JarFile[] | jarFilesThe list of JARs, in the order they should be searched for locally loaded classes or resources. | 
| protected  java.lang.String[] | jarNamesThe list of JARs, in the order they should be searched for locally loaded classes or resources. | 
| protected  java.lang.String | jarPathThe path which will be monitored for added Jar files. | 
| protected  java.io.File[] | jarRealFilesThe list of JARs, in the order they should be searched for locally loaded classes or resources. | 
| protected  long | lastJarAccessedLast time a JAR was accessed. | 
| protected  long[] | lastModifiedDatesThe list of JARs last modified dates, in the order they should be searched for locally loaded classes or resources. | 
| protected  java.io.File | loaderDirPath where resources loaded from JARs will be extracted. | 
| protected  java.util.HashMap | loaderPCThe PermissionCollection for each CodeSource for a web application context. | 
| protected static Log | log | 
| protected  boolean | needConvertneed conversion for properties files | 
| protected  java.util.HashMap | notFoundResourcesThe list of not found resources. | 
| protected static java.lang.String[] | packageTriggersSet of package names which are not allowed to be loaded from a webapp class loader without delegating first. | 
| protected  java.lang.ClassLoader | parentThe parent class loader. | 
| protected  java.lang.String[] | pathsThe list of resources which should be checked when checking for modifications. | 
| protected  java.util.ArrayList | permissionListA list of read File and Jndi Permission's required if this loader is for a web application context. | 
| protected  java.lang.String[] | repositoriesThe list of local repositories, in the order they should be searched for locally loaded classes or resources. | 
| protected  java.net.URL[] | repositoryURLsRepositories URLs, used to cache the result of getURLs. | 
| protected  java.util.HashMap | resourceEntriesThe cache of ResourceEntry for classes and resources we have loaded, keyed by resource name. | 
| protected  javax.naming.directory.DirContext | resourcesAssociated directory context giving access to the resources in this webapp. | 
| protected  java.lang.SecurityManager | securityManagerInstance of the SecurityManager installed. | 
| protected static StringManager | smThe string manager for this package. | 
| protected  boolean | startedHas this component been started? | 
| protected  java.lang.ClassLoader | systemThe system class loader. | 
| protected static java.lang.String[] | triggersThe set of trigger classes that will cause a proposed repository not to be added if this class is visible to the class loader that loaded this factory class. | 
| Fields inherited from interface org.apache.catalina.Lifecycle | 
|---|
| AFTER_START_EVENT, AFTER_STOP_EVENT, BEFORE_START_EVENT, BEFORE_STOP_EVENT, DESTROY_EVENT, INIT_EVENT, PERIODIC_EVENT, START_EVENT, STOP_EVENT | 
| Constructor Summary | |
|---|---|
| WebappClassLoader()Construct a new ClassLoader with no defined repositories and no parent ClassLoader. | |
| WebappClassLoader(java.lang.ClassLoader parent)Construct a new ClassLoader with no defined repositories and no parent ClassLoader. | |
| Method Summary | |
|---|---|
|  void | addLifecycleListener(LifecycleListener listener)Add a lifecycle event listener to this component. | 
|  void | addPermission(java.security.Permission permission)If there is a Java SecurityManager create a Permission. | 
|  void | addPermission(java.lang.String path)If there is a Java SecurityManager create a read FilePermission or JndiPermission for the file directory path. | 
|  void | addPermission(java.net.URL url)If there is a Java SecurityManager create a read FilePermission or JndiPermission for URL. | 
|  void | addRepository(java.lang.String repository)Add a new repository to the set of places this ClassLoader can look for classes to be loaded. | 
| protected  void | addURL(java.net.URL url)Add the specified URL to the classloader. | 
| protected  void | clearReferences()Clear references. | 
|  void | closeJARs(boolean force)Used to periodically signal to the classloader to release JAR resources. | 
| protected static void | deleteDir(java.io.File dir)Delete the specified directory, including all of its contents and subdirectories recursively. | 
| protected  boolean | filter(java.lang.String name)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. | 
| protected  java.io.InputStream | findLoadedResource(java.lang.String name)Finds the resource with the given name if it has previously been loaded and cached by this class loader, and return an input stream to the resource data. | 
|  java.lang.String[] | findRepositories()Return a String array of the current repositories for this class loader. | 
|  java.net.URL | findResource(java.lang.String name)Find the specified resource in our local repository, and return a URLrefering to it, ornullif this resource
 cannot be found. | 
| protected  ResourceEntry | findResourceInternal(java.io.File file,
                     java.lang.String path)Find specified resource in local repositories. | 
| protected  ResourceEntry | findResourceInternal(java.lang.String name,
                     java.lang.String path)Find specified resource in local repositories. | 
|  java.util.Enumeration | findResources(java.lang.String name)Return an enumeration of URLsrepresenting all of the
 resources with the given name. | 
|  boolean | getAntiJARLocking() | 
|  boolean | getDelegate()Return the "delegate first" flag for this class loader. | 
|  java.lang.String | getJarPath()Return the JAR path. | 
| protected  java.security.PermissionCollection | getPermissions(java.security.CodeSource codeSource)Get the Permissions for a CodeSource. | 
|  java.net.URL | getResource(java.lang.String name)Find the resource with the given name. | 
|  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. | 
|  javax.naming.directory.DirContext | getResources()Get associated resources. | 
| protected  java.net.URL | getURI(java.io.File file)Get URL. | 
| protected  java.net.URL | getURL(java.io.File file,
       boolean encoded)Get URL. | 
|  java.net.URL[] | getURLs()Returns the search path of URLs for loading classes and resources. | 
| protected  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. | 
|  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. | 
| protected  boolean | loadedByThisOrChild(java.lang.Class clazz)Determine whether a class was loaded by this class loader or one of its child class loaders. | 
|  boolean | modified()Have one or more classes or resources been modified so that a reload is appropriate? | 
| protected  void | nullInstance(java.lang.Object instance) | 
| protected  boolean | openJARs()Used to periodically signal to the classloader to release JAR resources. | 
| protected  void | refreshPolicy()Refresh the system policy file, to pick up eventual changes. | 
|  void | removeLifecycleListener(LifecycleListener listener)Remove a lifecycle event listener from this component. | 
|  void | setAntiJARLocking(boolean antiJARLocking) | 
|  void | setDelegate(boolean delegate)Set the "delegate first" flag for this class loader. | 
|  void | setJarPath(java.lang.String jarPath)Change the Jar path. | 
| protected  void | setParentClassLoader(java.lang.ClassLoader pcl)Utility method for use in subclasses. | 
|  void | setResources(javax.naming.directory.DirContext resources)Set associated resources. | 
|  void | setWorkDir(java.io.File workDir)Change the work directory. | 
|  void | start()Start the class loader. | 
|  void | stop()Stop the class loader. | 
|  java.lang.String | toString()Render a String representation of this object. | 
| protected  boolean | validate(java.lang.String name)Validate a classname. | 
| protected  boolean | validateJarFile(java.io.File jarfile)Check the specified JAR file, and return trueif it does
 not contain any of the trigger classes. | 
| Methods inherited from class java.net.URLClassLoader | 
|---|
| definePackage, newInstance, newInstance | 
| Methods inherited from class java.security.SecureClassLoader | 
|---|
| defineClass, defineClass | 
| Methods inherited from class java.lang.ClassLoader | 
|---|
| clearAssertionStatus, defineClass, defineClass, defineClass, defineClass, definePackage, findLibrary, findLoadedClass, findSystemClass, getPackage, getPackages, getParent, getResources, getSystemClassLoader, getSystemResource, getSystemResourceAsStream, getSystemResources, resolveClass, setClassAssertionStatus, setDefaultAssertionStatus, setPackageAssertionStatus, setSigners | 
| Methods inherited from class java.lang.Object | 
|---|
| clone, equals, finalize, getClass, hashCode, notify, notifyAll, wait, wait, wait | 
| Field Detail | 
|---|
protected static Log log
public static final boolean ENABLE_CLEAR_REFERENCES
protected static final java.lang.String[] triggers
protected static final java.lang.String[] packageTriggers
protected static final StringManager sm
protected javax.naming.directory.DirContext resources
protected java.util.HashMap resourceEntries
protected java.util.HashMap notFoundResources
protected boolean delegate
false,
 this class loader will search its own repositories first, and
 delegate to the parent only if the class or resource is not
 found locally.
protected long lastJarAccessed
protected java.lang.String[] repositories
protected java.net.URL[] repositoryURLs
protected java.io.File[] files
protected java.util.jar.JarFile[] jarFiles
protected java.io.File[] jarRealFiles
protected java.lang.String jarPath
protected java.lang.String[] jarNames
protected long[] lastModifiedDates
protected java.lang.String[] paths
protected java.util.ArrayList permissionList
protected java.io.File loaderDir
protected java.util.HashMap loaderPC
protected java.lang.SecurityManager securityManager
protected java.lang.ClassLoader parent
protected java.lang.ClassLoader system
protected boolean started
protected boolean hasExternalRepositories
protected boolean needConvert
protected java.security.Permission allPermission
| Constructor Detail | 
|---|
public WebappClassLoader()
public WebappClassLoader(java.lang.ClassLoader parent)
| Method Detail | 
|---|
public javax.naming.directory.DirContext getResources()
public void setResources(javax.naming.directory.DirContext resources)
public boolean getDelegate()
public void setDelegate(boolean delegate)
delegate - The new "delegate first" flagpublic boolean getAntiJARLocking()
public void setAntiJARLocking(boolean antiJARLocking)
antiJARLocking - The antiJARLocking to set.public void addPermission(java.lang.String path)
path - file directory pathpublic void addPermission(java.net.URL url)
url - URL for a file or directory on local systempublic void addPermission(java.security.Permission permission)
permission - The permissionpublic java.lang.String getJarPath()
public void setJarPath(java.lang.String jarPath)
public void setWorkDir(java.io.File workDir)
protected void setParentClassLoader(java.lang.ClassLoader pcl)
public void addRepository(java.lang.String repository)
addRepository in interface Reloaderrepository - Name of a source of classes to be loaded, such as a
  directory pathname, a JAR file pathname, or a ZIP file pathname
java.lang.IllegalArgumentException - if the specified repository is
  invalid or does not existpublic java.lang.String[] findRepositories()
findRepositories in interface Reloaderpublic boolean modified()
modified in interface Reloaderpublic java.lang.String toString()
toString in class java.lang.Objectprotected void addURL(java.net.URL url)
addURL in class java.net.URLClassLoader
public java.lang.Class findClass(java.lang.String name)
                          throws java.lang.ClassNotFoundException
ClassNotFoundException.
findClass in class java.net.URLClassLoadername - Name of the class to be loaded
java.lang.ClassNotFoundException - if the class was not foundpublic java.net.URL findResource(java.lang.String name)
URL refering to it, or null if this resource
 cannot be found.
findResource in class java.net.URLClassLoadername - Name of the resource to be found
public java.util.Enumeration findResources(java.lang.String name)
                                    throws java.io.IOException
URLs representing all of the
 resources with the given name.  If no resources with this name are
 found, return an empty enumeration.
findResources in class java.net.URLClassLoadername - Name of the resources to be found
java.io.IOException - if an input/output error occurspublic java.net.URL getResource(java.lang.String name)
null.
 
 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.
 
delegate property is set to true,
     call the getResource() method of the parent class
     loader, if any.findResource() to find this resource in our
     locally defined repositories.getResource() method of the parent class
     loader, if any.
getResource in class java.lang.ClassLoadername - Name of the resource to return a URL forpublic java.io.InputStream getResourceAsStream(java.lang.String name)
getResource(), after checking to see if the resource
 data has been previously cached.  If the resource cannot be found,
 return null.
getResourceAsStream in class java.lang.ClassLoadername - Name of the resource to return an input stream for
public java.lang.Class loadClass(java.lang.String name)
                          throws java.lang.ClassNotFoundException
loadClass(String, boolean)
 with false as the second argument.
loadClass in class java.lang.ClassLoadername - Name of the class to be loaded
java.lang.ClassNotFoundException - if the class was not found
public java.lang.Class loadClass(java.lang.String name,
                                 boolean resolve)
                          throws java.lang.ClassNotFoundException
ClassNotFoundException.
 findLoadedClass(String) to check if the
     class has already been loaded.  If it has, the same
     Class object is returned.delegate property is set to true,
     call the loadClass() method of the parent class
     loader, if any.findClass() to find this class in our locally
     defined repositories.loadClass() method of our parent
     class loader, if any.resolve flag is true, this method will then
 call resolveClass(Class) on the resulting Class object.
loadClass in class java.lang.ClassLoadername - Name of the class to be loadedresolve - If true then resolve the class
java.lang.ClassNotFoundException - if the class was not foundprotected java.security.PermissionCollection getPermissions(java.security.CodeSource codeSource)
getPermissions in class java.net.URLClassLoadercodeSource - where the code was loaded from
public java.net.URL[] getURLs()
getURLs in class java.net.URLClassLoaderpublic void addLifecycleListener(LifecycleListener listener)
addLifecycleListener in interface Lifecyclelistener - The listener to addpublic LifecycleListener[] findLifecycleListeners()
findLifecycleListeners in interface Lifecyclepublic void removeLifecycleListener(LifecycleListener listener)
removeLifecycleListener in interface Lifecyclelistener - The listener to remove
public void start()
           throws LifecycleException
start in interface LifecycleLifecycleException - if a lifecycle error occurs
public void stop()
          throws LifecycleException
stop in interface LifecycleLifecycleException - if a lifecycle error occurspublic void closeJARs(boolean force)
protected void clearReferences()
protected void nullInstance(java.lang.Object instance)
protected boolean loadedByThisOrChild(java.lang.Class clazz)
protected boolean openJARs()
protected java.lang.Class findClassInternal(java.lang.String name)
                                     throws java.lang.ClassNotFoundException
java.lang.ClassNotFoundException
protected ResourceEntry findResourceInternal(java.io.File file,
                                             java.lang.String path)
protected ResourceEntry findResourceInternal(java.lang.String name,
                                             java.lang.String path)
protected boolean isPackageSealed(java.lang.String name,
                                  java.util.jar.Manifest man)
protected java.io.InputStream findLoadedResource(java.lang.String name)
null.
name - Name of the resource to returnprotected java.lang.Class findLoadedClass0(java.lang.String name)
null.
name - Name of the resource to returnprotected void refreshPolicy()
protected boolean filter(java.lang.String name)
name - class name
protected boolean validate(java.lang.String name)
name - class name
protected boolean validateJarFile(java.io.File jarfile)
                           throws java.io.IOException
true if it does
 not contain any of the trigger classes.
jarfile - The JAR file to be checked
java.io.IOException - if an input/output error occurs
protected java.net.URL getURL(java.io.File file,
                              boolean encoded)
                       throws java.net.MalformedURLException
java.net.MalformedURLException
protected java.net.URL getURI(java.io.File file)
                       throws java.net.MalformedURLException
java.net.MalformedURLExceptionprotected static void deleteDir(java.io.File dir)
dir - File object representing the directory to be deleted| 
 | |||||||||
| PREV CLASS NEXT CLASS | FRAMES NO FRAMES | ||||||||
| SUMMARY: NESTED | FIELD | CONSTR | METHOD | DETAIL: FIELD | CONSTR | METHOD | ||||||||