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>,org.eclipse.jetty.util.component.Dumpable,org.eclipse.jetty.util.component.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 org.eclipse.jetty.ee10.servlet.Holder
Holder.HolderConfig, Holder.HolderRegistrationNested classes/interfaces inherited from class org.eclipse.jetty.util.component.AbstractLifeCycle
org.eclipse.jetty.util.component.AbstractLifeCycle.AbstractLifeCycleListener, org.eclipse.jetty.util.component.AbstractLifeCycle.StopExceptionNested classes/interfaces inherited from interface org.eclipse.jetty.util.component.Dumpable
org.eclipse.jetty.util.component.Dumpable.DumpableContainerNested classes/interfaces inherited from interface org.eclipse.jetty.util.component.LifeCycle
org.eclipse.jetty.util.component.LifeCycle.Listener -
Field Summary
FieldsFields inherited from class org.eclipse.jetty.util.component.AbstractLifeCycle
FAILED, STARTED, STARTING, STOPPED, STOPPINGFields inherited from interface org.eclipse.jetty.util.component.Dumpable
KEY -
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()voiddoStop()voiddump(Appendable out, String indent) 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 org.eclipse.jetty.ee10.servlet.Holder
dump, getDisplayName, getInitParameter, getInitParameterNames, getInitParameters, getName, isAsyncSupported, setAsyncSupported, setClassName, setDisplayName, setHeldClass, setInitParameter, setInitParameters, setInstance, setNameMethods inherited from class org.eclipse.jetty.ee10.servlet.BaseHolder
getClassName, getHeldClass, getInstance, getServletContext, getServletContextHandler, getServletHandler, getSource, illegalStateIfContextStarted, isInstance, setServletHandler, unwrap, wrapMethods inherited from class org.eclipse.jetty.util.component.AbstractLifeCycle
addEventListener, getEventListeners, getState, getState, isFailed, isRunning, isStarted, isStarting, isStopped, isStopping, removeEventListener, setEventListeners, start, stopMethods inherited from class java.lang.Object
clone, finalize, getClass, notify, notifyAll, wait, wait, waitMethods inherited from interface org.eclipse.jetty.util.component.Dumpable
dumpSelf
-
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
@ManagedAttribute(value="initialization order", readonly=true) public int 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
- Overrides:
doStartin classBaseHolder<jakarta.servlet.Servlet>- Throws:
Exception
-
initialize
Description copied from class:BaseHolderDo any setup necessary after starting- Overrides:
initializein classBaseHolder<jakarta.servlet.Servlet>- Throws:
Exception- if unable to initialize
-
doStop
- Overrides:
doStopin classBaseHolder<jakarta.servlet.Servlet>- Throws:
Exception
-
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
- Specified by:
dumpin interfaceorg.eclipse.jetty.util.component.Dumpable- Overrides:
dumpin classBaseHolder<jakarta.servlet.Servlet>- Throws:
IOException
-
toString
-