Package org.eclipse.jetty.server.handler
Class HandlerCollection
- java.lang.Object
-
- org.eclipse.jetty.util.component.AbstractLifeCycle
-
- org.eclipse.jetty.util.component.ContainerLifeCycle
-
- org.eclipse.jetty.server.handler.AbstractHandler
-
- org.eclipse.jetty.server.handler.AbstractHandlerContainer
-
- org.eclipse.jetty.server.handler.HandlerCollection
-
- All Implemented Interfaces:
Handler,HandlerContainer,Container,Destroyable,Dumpable,Dumpable.DumpableContainer,LifeCycle
- Direct Known Subclasses:
ContextHandlerCollection,HandlerList
@ManagedObject("Handler of multiple handlers") public class HandlerCollection extends AbstractHandlerContainer
A collection of handlers.The default implementations calls all handlers in list order, regardless of the response status or exceptions. Derived implementation may alter the order or the conditions of calling the contained handlers.
-
-
Nested Class Summary
Nested Classes Modifier and Type Class Description protected static classHandlerCollection.Handlers-
Nested classes/interfaces inherited from class org.eclipse.jetty.server.handler.AbstractHandler
AbstractHandler.ErrorDispatchHandler
-
Nested classes/interfaces inherited from class org.eclipse.jetty.util.component.AbstractLifeCycle
AbstractLifeCycle.AbstractLifeCycleListener
-
Nested classes/interfaces inherited from interface org.eclipse.jetty.util.component.Container
Container.InheritedListener, Container.Listener
-
Nested classes/interfaces inherited from interface org.eclipse.jetty.util.component.Dumpable
Dumpable.DumpableContainer
-
Nested classes/interfaces inherited from interface org.eclipse.jetty.util.component.LifeCycle
LifeCycle.Listener
-
-
Field Summary
Fields Modifier and Type Field Description protected java.util.concurrent.atomic.AtomicReference<HandlerCollection.Handlers>_handlers
-
Constructor Summary
Constructors Constructor Description HandlerCollection()HandlerCollection(boolean mutableWhenRunning, Handler... handlers)HandlerCollection(Handler... handlers)
-
Method Summary
All Methods Instance Methods Concrete Methods Modifier and Type Method Description voidaddHandler(Handler handler)Adds a handler.voiddestroy()Destroys the managed Destroyable beans in the reverse order they were added.protected voidexpandChildren(java.util.List<Handler> list, java.lang.Class<?> byClass)Handler[]getHandlers()voidhandle(java.lang.String target, Request baseRequest, javax.servlet.http.HttpServletRequest request, javax.servlet.http.HttpServletResponse response)Handle a request.protected HandlerCollection.HandlersnewHandlers(Handler[] handlers)voidprependHandler(Handler handler)Prepends a handler.voidremoveHandler(Handler handler)voidsetHandlers(Handler[] handlers)protected booleanupdateHandlers(HandlerCollection.Handlers old, HandlerCollection.Handlers handlers)-
Methods inherited from class org.eclipse.jetty.server.handler.AbstractHandlerContainer
doShutdown, expandHandler, findContainerOf, getChildHandlerByClass, getChildHandlers, getChildHandlersByClass, setServer
-
Methods inherited from class org.eclipse.jetty.server.handler.AbstractHandler
doError, doStart, doStop, getServer
-
Methods inherited from class org.eclipse.jetty.util.component.ContainerLifeCycle
addBean, addBean, addEventListener, addManaged, contains, dump, dump, dump, dump, dump, dumpBeans, dumpObject, dumpObjects, dumpStdErr, dumpThis, getBean, getBeans, getBeans, getContainedBeans, getContainedBeans, isAuto, isManaged, isUnmanaged, manage, removeBean, removeBeans, removeEventListener, setBeans, setStopTimeout, start, stop, unmanage, updateBean, updateBean, updateBeans
-
Methods inherited from class org.eclipse.jetty.util.component.AbstractLifeCycle
addLifeCycleListener, getState, getState, getStopTimeout, isFailed, isRunning, isStarted, isStarting, isStopped, isStopping, removeLifeCycleListener, start, stop, toString
-
Methods inherited from class java.lang.Object
clone, equals, finalize, getClass, hashCode, notify, notifyAll, wait, wait, wait
-
Methods inherited from interface org.eclipse.jetty.util.component.Dumpable.DumpableContainer
isDumpable
-
Methods inherited from interface org.eclipse.jetty.util.component.LifeCycle
addLifeCycleListener, isFailed, isRunning, isStarted, isStarting, isStopped, isStopping, removeLifeCycleListener, start, stop
-
-
-
-
Field Detail
-
_handlers
protected final java.util.concurrent.atomic.AtomicReference<HandlerCollection.Handlers> _handlers
-
-
Method Detail
-
getHandlers
@ManagedAttribute(value="Wrapped handlers", readonly=true) public Handler[] getHandlers()
- Returns:
- the array of handlers.
-
setHandlers
public void setHandlers(Handler[] handlers)
- Parameters:
handlers- the array of handlers to set.
-
newHandlers
protected HandlerCollection.Handlers newHandlers(Handler[] handlers)
-
updateHandlers
protected boolean updateHandlers(HandlerCollection.Handlers old, HandlerCollection.Handlers handlers)
-
handle
public void handle(java.lang.String target, Request baseRequest, javax.servlet.http.HttpServletRequest request, javax.servlet.http.HttpServletResponse response) throws java.io.IOException, javax.servlet.ServletExceptionDescription copied from interface:HandlerHandle a request.- Specified by:
handlein interfaceHandler- Specified by:
handlein classAbstractHandler- Parameters:
target- The target of the request - either a URI or a name.baseRequest- The original unwrapped request object.request- The request either as theRequestobject or a wrapper of that request. Themethod can be used access the Request object if required.HttpConnection.getCurrentConnection().getHttpChannel().getRequest()response- The response as theResponseobject or a wrapper of that request. Themethod can be used access the Response object if required.HttpConnection.getCurrentConnection().getHttpChannel().getResponse()- Throws:
java.io.IOException- if unable to handle the request or response processingjavax.servlet.ServletException- if unable to handle the request or response due to underlying servlet issue
-
addHandler
public void addHandler(Handler handler)
Adds a handler. This implementation adds the passed handler to the end of the existing collection of handlers. If the handler is already added, it is removed and readded
-
prependHandler
public void prependHandler(Handler handler)
Prepends a handler. This implementation adds the passed handler to the start of the existing collection of handlers.
-
removeHandler
public void removeHandler(Handler handler)
-
expandChildren
protected void expandChildren(java.util.List<Handler> list, java.lang.Class<?> byClass)
- Overrides:
expandChildrenin classAbstractHandlerContainer
-
destroy
public void destroy()
Description copied from class:ContainerLifeCycleDestroys the managed Destroyable beans in the reverse order they were added.- Specified by:
destroyin interfaceDestroyable- Specified by:
destroyin interfaceHandler- Overrides:
destroyin classAbstractHandler
-
-