CPPSERV


Home Projects Jobs Clientele Contact
CPPSERV Documentation Download TODO Mailing lists Bug tracker News RSS Feed Browse source

servlet::RequestDispatcher Class Reference

#include <RequestDispatcher.h>

Inheritance diagram for servlet::RequestDispatcher:

List of all members.


Public Member Functions

virtual ~RequestDispatcher ()
virtual void forward (ServletRequest &request, ServletResponse &response) const =0
virtual void include (ServletRequest &request, ServletResponse &response) const =0

Detailed Description

RequestDispatcher

Defines an object that receives requests from the client and sends them to any resource (such as a servlet, HTML file, or JSP file) on the server. The servlet container creates the RequestDispatcher object, which is used as a wrapper around a server resource located at a particular path or given by a particular name.

This interface is intended to wrap servlets, but a servlet container can create RequestDispatcher objects to wrap any type of resource.

Author:
Various
Version:
$Version$
See also:
ServletContext::getRequestDispatcher(java.lang.String)

ServletContext::getNamedDispatcher(java.lang.String)

ServletRequest::getRequestDispatcher(java.lang.String)

Definition at line 85 of file RequestDispatcher.h.


Constructor & Destructor Documentation

virtual servlet::RequestDispatcher::~RequestDispatcher (  )  [inline, virtual]

Definition at line 87 of file RequestDispatcher.h.


Member Function Documentation

virtual void servlet::RequestDispatcher::forward ( ServletRequest request,
ServletResponse response 
) const [pure virtual]

Forwards a request from a servlet to another resource (servlet, JSP file, or HTML file) on the server. This method allows one servlet to do preliminary processing of a request and another resource to generate the response.

For a RequestDispatcher obtained via getRequestDispatcher(), the ServletRequest object has its path elements and parameters adjusted to match the path of the target resource.

forward should be called before the response has been committed to the client (before response body output has been flushed). If the response already has been committed, this method throws an IllegalStateException. Uncommitted output in the response buffer is automatically cleared before the forward.

The request and response parameters must be either the same objects as were passed to the calling servlet's service method or be subclasses of the servlet::ServletRequestWrapper or servlet::ServletResponseWrapper classes that wrap them.

Parameters:
request a servlet::ServletRequest object that represents the request the client makes of the servlet
response a servlet::ServletResponse object that represents the response the servlet returns to the client
Exceptions:
ServletException if the target resource throws this exception
IOException if the target resource throws this exception
IllegalStateException if the response was already committed

Implemented in container::ServletContainer.

virtual void servlet::RequestDispatcher::include ( ServletRequest request,
ServletResponse response 
) const [pure virtual]

Includes the content of a resource (servlet, JSP page, HTML file) in the response. In essence, this method enables programmatic server-side includes.

The servlet::ServletResponse object has its path elements and parameters remain unchanged from the caller's. The included servlet cannot change the response status code or set headers; any attempt to make a change is ignored.

The request and response parameters must be either the same objects as were passed to the calling servlet's service method or be subclasses of the servlet::ServletRequestWrapper or servlet::ServletResponseWrapper classes that wrap them.

Parameters:
request a servlet::ServletRequest object that contains the client's request
response a servlet::ServletResponse object that contains the servlet's response
Exceptions:
ServletException if the included resource throws this exception
IOException if the included resource throws this exception

Implemented in container::ServletContainer.


The documentation for this class was generated from the following file:

SourceForge.net Logo