Class ServletHolder
java.lang.Object
org.eclipse.jetty.util.component.AbstractLifeCycle
org.eclipse.jetty.ee10.servlet.BaseHolder<jakarta.servlet.Servlet>
org.eclipse.jetty.ee10.servlet.Holder<jakarta.servlet.Servlet>
org.eclipse.jetty.ee10.servlet.ServletHolder
- All Implemented Interfaces:
Comparable<ServletHolder>, Dumpable, LifeCycle
@ManagedObject("Servlet Holder")
public class ServletHolder
extends Holder<jakarta.servlet.Servlet>
implements Comparable<ServletHolder>
Servlet Instance and Context Holder.
Holds the name, params and some state of a jakarta.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 enumclassstatic interfaceExperimental Wrapper mechanism for Servlet objects.static classNested classes/interfaces inherited from class Holder
Holder.HolderConfig, Holder.HolderRegistrationNested classes/interfaces inherited from class AbstractLifeCycle
AbstractLifeCycle.AbstractLifeCycleListener, AbstractLifeCycle.StopExceptionNested classes/interfaces inherited from interface Dumpable
Dumpable.DumpableContainerNested classes/interfaces inherited from interface LifeCycle
LifeCycle.Listener -
Field Summary
Fields -
Constructor Summary
ConstructorsConstructorDescriptionConstructor .ServletHolder(jakarta.servlet.Servlet servlet) Constructor for existing servlet.ServletHolder(Class<? extends jakarta.servlet.Servlet> servlet) Constructor for servlet class.ServletHolder(String name, jakarta.servlet.Servlet servlet) Constructor for servlet class.ServletHolder(String name, Class<? extends jakarta.servlet.Servlet> servlet) Constructor for servlet class.ServletHolder(Source creator) Constructor . -
Method Summary
Modifier and TypeMethodDescriptionprotected voidappendPath(StringBuffer path, String element) Concatenate an element on to fully qualified classname.voidCheck to ensure class of servlet is acceptable.intComparator by init order.protected jakarta.servlet.ServletvoidvoiddoStart()Method to override to start the lifecyclevoiddoStop()Method to override to stop the lifecyclevoiddump(Appendable out, String indent) Dump this object (and children) into an Appendable using the provided indent after any new lines.booleangetClassNameForJsp(String jsp) intGet the package for all jsps.jakarta.servlet.MultipartConfigElementgetNameOfJspClass(String jsp) jakarta.servlet.ServletGet the servlet.jakarta.servlet.ServletGet the servlet instance (no initialization done).jakarta.servlet.UnavailableExceptiongetUserRoleLink(String name) get a user role link.voidhandle(jakarta.servlet.ServletRequest request, jakarta.servlet.ServletResponse response) Service a request with this servlet.inthashCode()voidDo any setup necessary after startingprotected voidbooleanbooleanprotected booleanprotected booleanisJspServlet(String classname) protected jakarta.servlet.Servletprotected voidprepare(jakarta.servlet.ServletRequest request, jakarta.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(jakarta.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, getServletContext, getServletContextHandler, getServletHandler, getSource, illegalStateIfContextStarted, isInstance, setServletHandler, unwrap, wrapMethods inherited from class AbstractLifeCycle
addEventListener, getEventListeners, getState, getState, isFailed, isRunning, isStarted, isStarting, isStopped, isStopping, removeEventListener, setEventListeners, start, stop
-
Field Details
-
APACHE_SENTINEL_CLASS
- See Also:
-
JSP_GENERATED_PACKAGE_NAME
- See Also:
-
-
Constructor Details
-
ServletHolder
public ServletHolder()Constructor . -
ServletHolder
-
ServletHolder
public ServletHolder(jakarta.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
-
getMultipartConfigElement
public jakarta.servlet.MultipartConfigElement getMultipartConfigElement() -
setServlet
public void setServlet(jakarta.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
-
getRoleLinks
-
getForcedPath
- Returns:
- Returns the forcedPath.
-
setForcedPath
- Parameters:
forcedPath- The forcedPath to set.
-
isEnabled
public boolean isEnabled() -
setEnabled
public void setEnabled(boolean enabled) -
doStart
Description copied from class:AbstractLifeCycleMethod to override to start the lifecycle- Overrides:
doStartin classBaseHolder<jakarta.servlet.Servlet>- Throws:
Exception- If there was a problem starting. Will cause a transition to FAILED state
-
initialize
Description copied from class:BaseHolderDo any setup necessary after starting- Overrides:
initializein classBaseHolder<jakarta.servlet.Servlet>- Throws:
Exception- if unable to initialize
-
doStop
Description copied from class:AbstractLifeCycleMethod to override to stop the lifecycle- Overrides:
doStopin classBaseHolder<jakarta.servlet.Servlet>- Throws:
Exception- If there was a problem stopping. Will cause a transition to FAILED state
-
destroyInstance
- Overrides:
destroyInstancein classHolder<jakarta.servlet.Servlet>
-
getServlet
public jakarta.servlet.Servlet getServlet() throws jakarta.servlet.ServletExceptionGet the servlet.- Returns:
- The servlet
- Throws:
jakarta.servlet.ServletException- if unable to init the servlet on first use
-
getServletInstance
public jakarta.servlet.Servlet getServletInstance()Get the servlet instance (no initialization done).- Returns:
- The servlet or null
-
checkServletType
public void checkServletType() throws jakarta.servlet.UnavailableExceptionCheck to ensure class of servlet is acceptable.- Throws:
jakarta.servlet.UnavailableException- if Servlet class is not of typeServlet
-
isAvailable
public boolean isAvailable()- Returns:
- true if the holder is started and is not unavailable
-
initJspServlet
-
getRunAsRole
-
setRunAsRole
-
prepare
protected void prepare(jakarta.servlet.ServletRequest request, jakarta.servlet.ServletResponse response) throws jakarta.servlet.ServletException, jakarta.servlet.UnavailableException Prepare to service a request.- Parameters:
request- the requestresponse- the response- Throws:
jakarta.servlet.ServletException- if unable to prepare the servletjakarta.servlet.UnavailableException- if not available
-
handle
public void handle(jakarta.servlet.ServletRequest request, jakarta.servlet.ServletResponse response) throws jakarta.servlet.ServletException, jakarta.servlet.UnavailableException, IOException Service a request with this servlet.- Parameters:
request- the requestresponse- the response- Throws:
jakarta.servlet.ServletException- if unable to process the servletjakarta.servlet.UnavailableException- if servlet is unavailableIOException- if unable to process the request or response
-
isJspServlet
protected boolean isJspServlet() -
isJspServlet
-
getNameOfJspClass
-
getPackageOfJspClass
-
getJspPackagePrefix
-
getClassNameForJsp
-
appendPath
Concatenate an element on to fully qualified classname.- Parameters:
path- the path under constructionelement- the element of the name to add
-
getRegistration
-
newInstance
- Returns:
- the newly created Servlet instance
- Throws:
jakarta.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 exceptionException
-
createInstance
- Overrides:
createInstancein classBaseHolder<jakarta.servlet.Servlet>- Throws:
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<jakarta.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
-