Class ServletHolder
java.lang.Object
org.eclipse.jetty.util.component.AbstractLifeCycle
org.eclipse.jetty.servlet.BaseHolder<javax.servlet.Servlet>
org.eclipse.jetty.servlet.Holder<javax.servlet.Servlet>
org.eclipse.jetty.servlet.ServletHolder
- All Implemented Interfaces:
Comparable<ServletHolder>, UserIdentity.Scope, Dumpable, LifeCycle
@ManagedObject("Servlet Holder")
public class ServletHolder
extends Holder<javax.servlet.Servlet>
implements UserIdentity.Scope, Comparable<ServletHolder>
Servlet Instance and Context Holder.
Holds the name, params and some state of a javax.servlet.Servlet instance. It implements the ServletConfig interface. This class will organise the loading of the servlet when needed or requested.
-
Nested Class Summary
Nested ClassesModifier and TypeClassDescriptionprotected classstatic enumprivate static classclassprivate static classprivate classprivate classstatic interfaceExperimental Wrapper mechanism for Servlet objects.static classNested classes/interfaces inherited from class Holder
Holder.HolderConfig, Holder.HolderRegistrationNested classes/interfaces inherited from class BaseHolder
BaseHolder.Wrapped<C>Nested classes/interfaces inherited from class AbstractLifeCycle
AbstractLifeCycle.AbstractLifeCycleListenerNested classes/interfaces inherited from interface Dumpable
Dumpable.DumpableContainerNested classes/interfaces inherited from interface LifeCycle
LifeCycle.Listener -
Field Summary
FieldsModifier and TypeFieldDescriptionprivate ServletHolder.Configprivate booleanprivate Stringprivate booleanprivate intprivate ServletHolder.JspContainerprivate javax.servlet.ServletRegistration.Dynamicprivate Stringprivate javax.servlet.Servletstatic final Stringstatic final Stringprivate static final Logger -
Constructor Summary
ConstructorsConstructorDescriptionConstructor .ServletHolder(Class<? extends javax.servlet.Servlet> servlet) Constructor for servlet class.ServletHolder(String name, Class<? extends javax.servlet.Servlet> servlet) Constructor for servlet class.ServletHolder(String name, javax.servlet.Servlet servlet) Constructor for servlet class.ServletHolder(javax.servlet.Servlet servlet) Constructor for existing servlet.ServletHolder(Source creator) Constructor . -
Method Summary
Modifier and TypeMethodDescriptionprotected voidappendPath(StringBuffer path, String element) Concatenate an element on to fully qualified classname.private voidCheck if there is a javax.servlet.annotation.ServletSecurity annotation on the servlet class.voidCheck to ensure class of servlet is acceptable.intComparator by init order.voidprivate voidvoiddoStart()voiddoStop()voiddump(Appendable out, String indent) Dump this object (and children) into an Appendable using the provided indent after any new lines.javax.servlet.ServletDeprecated.booleangetClassNameForJsp(String jsp) intgetNameOfJspClass(String jsp) javax.servlet.ServletRegistration.Dynamicjavax.servlet.ServletGet the servlet.javax.servlet.ServletGet the servlet instance (no initialization done).javax.servlet.UnavailableExceptiongetUserRoleLink(String name) get a user role link.voidhandle(Request baseRequest, javax.servlet.ServletRequest request, javax.servlet.ServletResponse response) Service a request with this servlet.inthashCode()voidDo any setup necessary after startingprotected voidprotected voidRegister a ServletRequestListener that will ensure tmp multipart files are deleted when the request goes out of scope.private voidbooleanbooleanprotected booleanprotected booleanisJspServlet(String classname) private voidprivate javax.servlet.ServletmakeUnavailable(javax.servlet.UnavailableException e) protected javax.servlet.Servletprivate voidpredestroyServlet(javax.servlet.Servlet servlet) protected voidprepare(Request baseRequest, javax.servlet.ServletRequest request, javax.servlet.ServletResponse response) Prepare to service a request.voidsetEnabled(boolean enabled) voidsetForcedPath(String forcedPath) voidsetInitOrder(int order) Set the initialize order.voidsetRunAsRole(String role) voidsetServlet(javax.servlet.Servlet servlet) voidsetUserRoleLink(String name, String link) Link a user role.toString()Methods inherited from class Holder
dump, getDisplayName, getInitParameter, getInitParameterNames, getInitParameters, getName, isAsyncSupported, setAsyncSupported, setClassName, setDisplayName, setHeldClass, setInitParameter, setInitParameters, setInstance, setNameMethods inherited from class BaseHolder
getClassName, getHeldClass, getInstance, getServletHandler, getSource, illegalStateIfContextStarted, isInstance, setServletHandler, unwrap, wrapMethods inherited from class AbstractLifeCycle
addLifeCycleListener, getState, getState, getStopTimeout, isFailed, isRunning, isStarted, isStarting, isStopped, isStopping, removeLifeCycleListener, setStopTimeout, start, stopMethods inherited from interface UserIdentity.Scope
getName
-
Field Details
-
LOG
-
_initOrder
private int _initOrder -
_initOnStartup
private boolean _initOnStartup -
_roleMap
-
_forcedPath
-
_runAsRole
-
_registration
private javax.servlet.ServletRegistration.Dynamic _registration -
_jspContainer
-
_servlet
private volatile javax.servlet.Servlet _servlet -
_config
-
_enabled
private boolean _enabled -
APACHE_SENTINEL_CLASS
- See Also:
-
JSP_GENERATED_PACKAGE_NAME
- See Also:
-
-
Constructor Details
-
ServletHolder
public ServletHolder()Constructor . -
ServletHolder
-
ServletHolder
public ServletHolder(javax.servlet.Servlet servlet) Constructor for existing servlet.- Parameters:
servlet- the servlet
-
ServletHolder
-
ServletHolder
Constructor for servlet class.- Parameters:
name- the servlet nameservlet- the servlet
-
ServletHolder
Constructor for servlet class.- Parameters:
servlet- the servlet class
-
-
Method Details
-
setServlet
public void setServlet(javax.servlet.Servlet servlet) -
getInitOrder
-
setInitOrder
public void setInitOrder(int order) Set the initialize order.Holders with order<0, are initialized on use. Those with order>=0 are initialized in increasing order when the handler is started.
- Parameters:
order- the servlet init order
-
compareTo
Comparator by init order.- Specified by:
compareToin interfaceComparable<ServletHolder>
-
equals
-
hashCode
-
setUserRoleLink
-
getUserRoleLink
-
getForcedPath
- Returns:
- Returns the forcedPath.
-
setForcedPath
- Parameters:
forcedPath- The forcedPath to set.
-
isEnabled
public boolean isEnabled() -
setEnabled
public void setEnabled(boolean enabled) -
doStart
- Overrides:
doStartin classBaseHolder<javax.servlet.Servlet>- Throws:
Exception
-
initialize
Description copied from class:BaseHolderDo any setup necessary after starting- Overrides:
initializein classBaseHolder<javax.servlet.Servlet>- Throws:
Exception- if unable to initialize
-
doStop
- Overrides:
doStopin classBaseHolder<javax.servlet.Servlet>- Throws:
Exception
-
destroyInstance
- Overrides:
destroyInstancein classHolder<javax.servlet.Servlet>
-
predestroyServlet
private void predestroyServlet(javax.servlet.Servlet servlet) -
getServlet
public javax.servlet.Servlet getServlet() throws javax.servlet.ServletExceptionGet the servlet.- Returns:
- The servlet
- Throws:
javax.servlet.ServletException- if unable to init the servlet on first use
-
getServletInstance
public javax.servlet.Servlet getServletInstance()Get the servlet instance (no initialization done).- Returns:
- The servlet or null
-
checkServletType
public void checkServletType() throws javax.servlet.UnavailableExceptionCheck to ensure class of servlet is acceptable.- Throws:
javax.servlet.UnavailableException- if Servlet class is not of typeServlet
-
isAvailable
public boolean isAvailable()- Returns:
- true if the holder is started and is not unavailable
-
checkInitOnStartup
private void checkInitOnStartup()Check if there is a javax.servlet.annotation.ServletSecurity annotation on the servlet class. If there is, then we force it to be loaded on startup, because all of the security constraints must be calculated as the container starts. -
initServlet
private void initServlet() throws javax.servlet.ServletException- Throws:
javax.servlet.ServletException
-
initJspServlet
-
initMultiPart
-
getContextHandler
- Specified by:
getContextHandlerin interfaceUserIdentity.Scope- Returns:
- The context handler that the identity is being considered within
-
getContextPath
- Specified by:
getContextPathin interfaceUserIdentity.Scope- Returns:
- The context path that the identity is being considered within
- See Also:
-
getRoleRefMap
- Specified by:
getRoleRefMapin interfaceUserIdentity.Scope- Returns:
- A map of role reference names that converts from names used by application code to names used by the context deployment.
- See Also:
-
getRunAsRole
-
setRunAsRole
-
prepare
protected void prepare(Request baseRequest, javax.servlet.ServletRequest request, javax.servlet.ServletResponse response) throws javax.servlet.ServletException, javax.servlet.UnavailableException Prepare to service a request.- Parameters:
baseRequest- the base requestrequest- the requestresponse- the response- Throws:
javax.servlet.ServletException- if unable to prepare the servletjavax.servlet.UnavailableException- if not available
-
ensureInstance
Deprecated.- Throws:
javax.servlet.ServletException
-
handle
public void handle(Request baseRequest, javax.servlet.ServletRequest request, javax.servlet.ServletResponse response) throws javax.servlet.ServletException, javax.servlet.UnavailableException, IOException Service a request with this servlet.- Parameters:
baseRequest- the base requestrequest- the requestresponse- the response- Throws:
javax.servlet.ServletException- if unable to process the servletjavax.servlet.UnavailableException- if servlet is unavailableIOException- if unable to process the request or response
-
isJspServlet
protected boolean isJspServlet() -
isJspServlet
-
detectJspContainer
private void detectJspContainer() -
getNameOfJspClass
-
getPackageOfJspClass
-
getJspPackagePrefix
- Returns:
- the package for all jsps
-
getClassNameForJsp
-
appendPath
Concatenate an element on to fully qualified classname.- Parameters:
path- the path under constructionelement- the element of the name to add
-
getRegistration
public javax.servlet.ServletRegistration.Dynamic getRegistration() -
newInstance
protected javax.servlet.Servlet newInstance() throws javax.servlet.ServletException, IllegalAccessException, InstantiationException, NoSuchMethodException, InvocationTargetException- Returns:
- the newly created Servlet instance
- Throws:
javax.servlet.ServletException- if unable to create a new instanceIllegalAccessException- if not allowed to create a new instanceInstantiationException- if creating new instance resulted in errorNoSuchMethodException- if creating new instance resulted in errorInvocationTargetException- If creating new instance throws an exception
-
dump
Description 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 interfaceDumpable- Overrides:
dumpin classBaseHolder<javax.servlet.Servlet>- Parameters:
out- The appendable to dump toindent- The indent to apply after any new lines.- Throws:
IOException- if unable to write to Appendable
-
toString