Package org.apache.catalina.servlets
Class DefaultServlet
- java.lang.Object
- 
- jakarta.servlet.GenericServlet
- 
- jakarta.servlet.http.HttpServlet
- 
- org.apache.catalina.servlets.DefaultServlet
 
 
 
- 
- All Implemented Interfaces:
- Servlet,- ServletConfig,- Serializable
 - Direct Known Subclasses:
- WebdavServlet
 
 public class DefaultServlet extends HttpServlet The default resource-serving servlet for most web applications, used to serve static resources such as HTML pages and images. This servlet is intended to be mapped to / e.g.: <servlet-mapping> <servlet-name>default</servlet-name> <url-pattern>/</url-pattern> </servlet-mapping>It can be mapped to sub-paths, however in all cases resources are served from the web application resource root using the full path from the root of the web application context. 
 e.g. given a web application structure:/context /images tomcat2.jpg /static /images tomcat.jpg... and a servlet mapping that maps only /static/*to the default servlet:<servlet-mapping> <servlet-name>default</servlet-name> <url-pattern>/static/*</url-pattern> </servlet-mapping>Then a request to /context/static/images/tomcat.jpgwill succeed while a request to/context/images/tomcat2.jpgwill fail.- Author:
- Craig R. McClanahan, Remy Maucherat
- See Also:
- Serialized Form
 
- 
- 
Nested Class SummaryNested Classes Modifier and Type Class Description protected static classDefaultServlet.CompressionFormat
 - 
Field SummaryFields Modifier and Type Field Description protected static intBUFFER_SIZESize of file transfer buffer in bytes.protected DefaultServlet.CompressionFormat[]compressionFormatsList of compression formats to serve and their preference order.protected StringcontextXsltFileAllow customized directory listing per context.protected intdebugThe debugging detail level for this servlet.protected StringfileEncodingFile encoding to be used when reading static files.protected static RangesFULLFull range marker.protected StringglobalXsltFileAllow customized directory listing per instance.protected intinputThe input buffer size to use when serving resources.protected booleanlistingsShould we generate directory listings?protected StringlocalXsltFileAllow customized directory listing per directory.protected static StringmimeSeparationMIME multipart separation stringprotected intoutputThe output buffer size to use when serving resources.protected StringreadmeFileAllow a readme file to be included.protected booleanreadOnlyRead only flag.protected WebResourceRootresourcesThe complete set of web application resourcesprotected intsendfileSizeMinimum size for sendfile usage in bytes.protected booleanshowServerInfoFlag to determine if server information is presented.protected static StringManagersmThe string manager for this package.protected booleansortListingsFlag to determine if resources should be sorted.protected org.apache.catalina.servlets.DefaultServlet.SortManagersortManagerThe sorting manager for sorting files and directories.protected booleanuseAcceptRangesShould the Accept-Ranges: bytes header be send with static resources?- 
Fields inherited from class jakarta.servlet.http.HttpServletLEGACY_DO_HEAD
 
- 
 - 
Constructor SummaryConstructors Constructor Description DefaultServlet()
 - 
Method SummaryAll Methods Instance Methods Concrete Methods Modifier and Type Method Description protected booleancheckIfHeaders(HttpServletRequest request, HttpServletResponse response, WebResource resource)Check if the conditions specified in the optional If headers are satisfied.protected booleancheckIfMatch(HttpServletRequest request, HttpServletResponse response, WebResource resource)Check if the if-match condition is satisfied.protected booleancheckIfModifiedSince(HttpServletRequest request, HttpServletResponse response, WebResource resource)Check if the if-modified-since condition is satisfied.protected booleancheckIfNoneMatch(HttpServletRequest request, HttpServletResponse response, WebResource resource)Check if the if-none-match condition is satisfied.protected booleancheckIfUnmodifiedSince(HttpServletRequest request, HttpServletResponse response, WebResource resource)Check if the if-unmodified-since condition is satisfied.protected booleancheckSendfile(HttpServletRequest request, HttpServletResponse response, WebResource resource, long length, Ranges.Entry range)Check if sendfile can be used.protected voidcopy(InputStream is, ServletOutputStream ostream)Copy the contents of the specified input stream to the specified output stream, and ensure that both streams are closed before returning (even in the face of an exception).protected voidcopy(InputStream is, PrintWriter writer, String encoding)Copy the contents of the specified input stream to the specified output stream, and ensure that both streams are closed before returning (even in the face of an exception).protected voidcopy(WebResource resource, long length, ServletOutputStream ostream, Ranges.Entry range)Copy the contents of the specified input stream to the specified output stream, and ensure that both streams are closed before returning (even in the face of an exception).protected voidcopy(WebResource resource, long length, ServletOutputStream ostream, Ranges ranges, String contentType)Copy the contents of the specified input stream to the specified output stream, and ensure that both streams are closed before returning (even in the face of an exception).protected IOExceptioncopyRange(InputStream istream, ServletOutputStream ostream)Copy the contents of the specified input stream to the specified output stream, and ensure that both streams are closed before returning (even in the face of an exception).protected IOExceptioncopyRange(InputStream istream, ServletOutputStream ostream, long start, long end)Copy the contents of the specified input stream to the specified output stream, and ensure that both streams are closed before returning (even in the face of an exception).protected IOExceptioncopyRange(Reader reader, PrintWriter writer)Copy the contents of the specified input stream to the specified output stream, and ensure that both streams are closed before returning (even in the face of an exception).voiddestroy()Finalize this servlet.protected StringdetermineMethodsAllowed(HttpServletRequest req)protected voiddoDelete(HttpServletRequest req, HttpServletResponse resp)Process a DELETE request for the specified resource.protected voiddoGet(HttpServletRequest request, HttpServletResponse response)Process a GET request for the specified resource.protected voiddoHead(HttpServletRequest request, HttpServletResponse response)Process a HEAD request for the specified resource.protected voiddoOptions(HttpServletRequest req, HttpServletResponse resp)Override default implementation to ensure that TRACE is correctly handled.protected voiddoPost(HttpServletRequest request, HttpServletResponse response)Process a POST request for the specified resource.protected voiddoPut(HttpServletRequest req, HttpServletResponse resp)Process a PUT request for the specified resource.protected FileexecutePartialPut(HttpServletRequest req, ContentRange range, String path)Handle a partial PUT.protected SourcefindXsltSource(WebResource directory)Return a Source for the xsl template (if possible).protected StringgenerateETag(WebResource resource)Provides the entity tag (the ETag header) for the given resource.protected StringgetPathPrefix(HttpServletRequest request)Determines the appropriate path to prepend resources with when generating directory listings.protected StringgetReadme(WebResource directory, String encoding)Get the readme file as a string.protected StringgetRelativePath(HttpServletRequest request)Return the relative path associated with this servlet.protected StringgetRelativePath(HttpServletRequest request, boolean allowEmptyPath)voidinit()Initialize this servlet.protected ContentRangeparseContentRange(HttpServletRequest request, HttpServletResponse response)Parse the content-range header.protected RangesparseRange(HttpServletRequest request, HttpServletResponse response, WebResource resource)Parse the range header.protected InputStreamrender(HttpServletRequest request, String contextPath, WebResource resource, String encoding)Decide which way to render.protected InputStreamrenderHtml(HttpServletRequest request, String contextPath, WebResource resource, String encoding)Return an InputStream to an HTML representation of the contents of this directory.protected StringrenderSize(long size)Render the specified file size (in bytes).protected InputStreamrenderXml(HttpServletRequest request, String contextPath, WebResource resource, Source xsltSource, String encoding)Return an InputStream to an XML representation of the contents this directory.protected StringrewriteUrl(String path)URL rewriter.protected voidsendNotAllowed(HttpServletRequest req, HttpServletResponse resp)protected voidserveResource(HttpServletRequest request, HttpServletResponse response, boolean content, String inputEncoding)Serve the specified resource, optionally including the data content.protected voidservice(HttpServletRequest req, HttpServletResponse resp)Receives standard HTTP requests from the publicservicemethod and dispatches them to thedoMethod methods defined in this class.- 
Methods inherited from class jakarta.servlet.http.HttpServletdoTrace, getLastModified, init, service
 - 
Methods inherited from class jakarta.servlet.GenericServletgetInitParameter, getInitParameterNames, getServletConfig, getServletContext, getServletInfo, getServletName, log, log
 
- 
 
- 
- 
- 
Field Detail- 
smprotected static final StringManager sm The string manager for this package.
 - 
FULLprotected static final Ranges FULL Full range marker.
 - 
mimeSeparationprotected static final String mimeSeparation MIME multipart separation string- See Also:
- Constant Field Values
 
 - 
BUFFER_SIZEprotected static final int BUFFER_SIZE Size of file transfer buffer in bytes.- See Also:
- Constant Field Values
 
 - 
debugprotected int debug The debugging detail level for this servlet.
 - 
inputprotected int input The input buffer size to use when serving resources.
 - 
listingsprotected boolean listings Should we generate directory listings?
 - 
readOnlyprotected boolean readOnly Read only flag. By default, it's set to true.
 - 
compressionFormatsprotected DefaultServlet.CompressionFormat[] compressionFormats List of compression formats to serve and their preference order.
 - 
outputprotected int output The output buffer size to use when serving resources.
 - 
localXsltFileprotected String localXsltFile Allow customized directory listing per directory.
 - 
contextXsltFileprotected String contextXsltFile Allow customized directory listing per context.
 - 
globalXsltFileprotected String globalXsltFile Allow customized directory listing per instance.
 - 
readmeFileprotected String readmeFile Allow a readme file to be included.
 - 
resourcesprotected transient WebResourceRoot resources The complete set of web application resources
 - 
fileEncodingprotected String fileEncoding File encoding to be used when reading static files. If none is specified the platform default is used.
 - 
sendfileSizeprotected int sendfileSize Minimum size for sendfile usage in bytes.
 - 
useAcceptRangesprotected boolean useAcceptRanges Should the Accept-Ranges: bytes header be send with static resources?
 - 
showServerInfoprotected boolean showServerInfo Flag to determine if server information is presented.
 - 
sortListingsprotected boolean sortListings Flag to determine if resources should be sorted.
 - 
sortManagerprotected transient org.apache.catalina.servlets.DefaultServlet.SortManager sortManager The sorting manager for sorting files and directories.
 
- 
 - 
Method Detail- 
destroypublic void destroy() Finalize this servlet.- Specified by:
- destroyin interface- Servlet
- Overrides:
- destroyin class- GenericServlet
 
 - 
initpublic void init() throws ServletExceptionInitialize this servlet.- Overrides:
- initin class- GenericServlet
- Throws:
- ServletException- if an exception occurs that interrupts the servlet's normal operation
 
 - 
getRelativePathprotected String getRelativePath(HttpServletRequest request) Return the relative path associated with this servlet.- Parameters:
- request- The servlet request we are processing
- Returns:
- the relative path
 
 - 
getRelativePathprotected String getRelativePath(HttpServletRequest request, boolean allowEmptyPath) 
 - 
getPathPrefixprotected String getPathPrefix(HttpServletRequest request) Determines the appropriate path to prepend resources with when generating directory listings. Depending on the behaviour ofgetRelativePath(HttpServletRequest)this will change.- Parameters:
- request- the request to determine the path for
- Returns:
- the prefix to apply to all resources in the listing.
 
 - 
serviceprotected void service(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException Description copied from class:jakarta.servlet.http.HttpServletReceives standard HTTP requests from the publicservicemethod and dispatches them to thedoMethod methods defined in this class. This method is an HTTP-specific version of theServlet.service(jakarta.servlet.ServletRequest, jakarta.servlet.ServletResponse)method. There's no need to override this method.- Overrides:
- servicein class- HttpServlet
- Parameters:
- req- the- HttpServletRequestobject that contains the request the client made of the servlet
- resp- the- HttpServletResponseobject that contains the response the servlet returns to the client
- Throws:
- ServletException- if the HTTP request cannot be handled
- IOException- if an input or output error occurs while the servlet is handling the HTTP request
- See Also:
- Servlet.service(jakarta.servlet.ServletRequest, jakarta.servlet.ServletResponse)
 
 - 
doGetprotected void doGet(HttpServletRequest request, HttpServletResponse response) throws IOException, ServletException Process a GET request for the specified resource.- Overrides:
- doGetin class- HttpServlet
- Parameters:
- request- The servlet request we are processing
- response- The servlet response we are creating
- Throws:
- IOException- if an input/output error occurs
- ServletException- if a servlet-specified error occurs
- See Also:
- ServletResponse.setContentType(java.lang.String)
 
 - 
doHeadprotected void doHead(HttpServletRequest request, HttpServletResponse response) throws IOException, ServletException Process a HEAD request for the specified resource.- Overrides:
- doHeadin class- HttpServlet
- Parameters:
- request- The servlet request we are processing
- response- The servlet response we are creating
- Throws:
- IOException- if an input/output error occurs
- ServletException- if a servlet-specified error occurs
 
 - 
doOptionsprotected void doOptions(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException Override default implementation to ensure that TRACE is correctly handled.- Overrides:
- doOptionsin class- HttpServlet
- Parameters:
- req- the- HttpServletRequestobject that contains the request the client made of the servlet
- resp- the- HttpServletResponseobject that contains the response the servlet returns to the client
- Throws:
- IOException- if an input or output error occurs while the servlet is handling the OPTIONS request
- ServletException- if the request for the OPTIONS cannot be handled
 
 - 
determineMethodsAllowedprotected String determineMethodsAllowed(HttpServletRequest req) 
 - 
sendNotAllowedprotected void sendNotAllowed(HttpServletRequest req, HttpServletResponse resp) throws IOException - Throws:
- IOException
 
 - 
doPostprotected void doPost(HttpServletRequest request, HttpServletResponse response) throws IOException, ServletException Process a POST request for the specified resource.- Overrides:
- doPostin class- HttpServlet
- Parameters:
- request- The servlet request we are processing
- response- The servlet response we are creating
- Throws:
- IOException- if an input/output error occurs
- ServletException- if a servlet-specified error occurs
- See Also:
- ServletOutputStream,- ServletResponse.setContentType(java.lang.String)
 
 - 
doPutprotected void doPut(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException Process a PUT request for the specified resource.- Overrides:
- doPutin class- HttpServlet
- Parameters:
- req- The servlet request we are processing
- resp- The servlet response we are creating
- Throws:
- IOException- if an input/output error occurs
- ServletException- if a servlet-specified error occurs
 
 - 
executePartialPutprotected File executePartialPut(HttpServletRequest req, ContentRange range, String path) throws IOException Handle a partial PUT. New content specified in request is appended to existing content in oldRevisionContent (if present). This code does not support simultaneous partial updates to the same resource.- Parameters:
- req- The Servlet request
- range- The range that will be written
- path- The path
- Returns:
- the associated file object
- Throws:
- IOException- an IO error occurred
 
 - 
doDeleteprotected void doDelete(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException Process a DELETE request for the specified resource.- Overrides:
- doDeletein class- HttpServlet
- Parameters:
- req- The servlet request we are processing
- resp- The servlet response we are creating
- Throws:
- IOException- if an input/output error occurs
- ServletException- if a servlet-specified error occurs
 
 - 
checkIfHeadersprotected boolean checkIfHeaders(HttpServletRequest request, HttpServletResponse response, WebResource resource) throws IOException Check if the conditions specified in the optional If headers are satisfied.- Parameters:
- request- The servlet request we are processing
- response- The servlet response we are creating
- resource- The resource
- Returns:
- trueif the resource meets all the specified conditions, and- falseif any of the conditions is not satisfied, in which case request processing is stopped
- Throws:
- IOException- an IO error occurred
 
 - 
rewriteUrlprotected String rewriteUrl(String path) URL rewriter.- Parameters:
- path- Path which has to be rewritten
- Returns:
- the rewritten path
 
 - 
serveResourceprotected void serveResource(HttpServletRequest request, HttpServletResponse response, boolean content, String inputEncoding) throws IOException, ServletException Serve the specified resource, optionally including the data content.- Parameters:
- request- The servlet request we are processing
- response- The servlet response we are creating
- content- Should the content be included?
- inputEncoding- The encoding to use if it is necessary to access the source as characters rather than as bytes
- Throws:
- IOException- if an input/output error occurs
- ServletException- if a servlet-specified error occurs
 
 - 
parseContentRangeprotected ContentRange parseContentRange(HttpServletRequest request, HttpServletResponse response) throws IOException Parse the content-range header.- Parameters:
- request- The servlet request we are processing
- response- The servlet response we are creating
- Returns:
- the partial content-range, nullif the content-range header was invalid or#IGNOREif there is no header to process
- Throws:
- IOException- an IO error occurred
 
 - 
parseRangeprotected Ranges parseRange(HttpServletRequest request, HttpServletResponse response, WebResource resource) throws IOException Parse the range header.- Parameters:
- request- The servlet request we are processing
- response- The servlet response we are creating
- resource- The resource
- Returns:
- a list of ranges, nullif the range header was invalid or#FULLif the Range header should be ignored.
- Throws:
- IOException- an IO error occurred
 
 - 
renderprotected InputStream render(HttpServletRequest request, String contextPath, WebResource resource, String encoding) throws IOException, ServletException Decide which way to render. HTML or XML.- Parameters:
- request- The HttpServletRequest being served
- contextPath- The path
- resource- The resource
- encoding- The encoding to use to process the readme (if any)
- Returns:
- the input stream with the rendered output
- Throws:
- IOException- an IO error occurred
- ServletException- rendering error
 
 - 
renderXmlprotected InputStream renderXml(HttpServletRequest request, String contextPath, WebResource resource, Source xsltSource, String encoding) throws IOException, ServletException Return an InputStream to an XML representation of the contents this directory.- Parameters:
- request- The HttpServletRequest being served
- contextPath- Context path to which our internal paths are relative
- resource- The associated resource
- xsltSource- The XSL stylesheet
- encoding- The encoding to use to process the readme (if any)
- Returns:
- the XML data
- Throws:
- IOException- an IO error occurred
- ServletException- rendering error
 
 - 
renderHtmlprotected InputStream renderHtml(HttpServletRequest request, String contextPath, WebResource resource, String encoding) throws IOException Return an InputStream to an HTML representation of the contents of this directory.- Parameters:
- request- The HttpServletRequest being served
- contextPath- Context path to which our internal paths are relative
- resource- The associated resource
- encoding- The encoding to use to process the readme (if any)
- Returns:
- the HTML data
- Throws:
- IOException- an IO error occurred
 
 - 
renderSizeprotected String renderSize(long size) Render the specified file size (in bytes).- Parameters:
- size- File size (in bytes)
- Returns:
- the formatted size
 
 - 
getReadmeprotected String getReadme(WebResource directory, String encoding) Get the readme file as a string.- Parameters:
- directory- The directory to search
- encoding- The readme encoding
- Returns:
- the readme for the specified directory
 
 - 
findXsltSourceprotected Source findXsltSource(WebResource directory) throws IOException Return a Source for the xsl template (if possible).- Parameters:
- directory- The directory to search
- Returns:
- the source for the specified directory
- Throws:
- IOException- an IO error occurred
 
 - 
checkSendfileprotected boolean checkSendfile(HttpServletRequest request, HttpServletResponse response, WebResource resource, long length, Ranges.Entry range) Check if sendfile can be used.- Parameters:
- request- The Servlet request
- response- The Servlet response
- resource- The resource
- length- The length which will be written (will be used only if range is null)
- range- The range that will be written
- Returns:
- trueif sendfile should be used (writing is then delegated to the endpoint)
 
 - 
checkIfMatchprotected boolean checkIfMatch(HttpServletRequest request, HttpServletResponse response, WebResource resource) throws IOException Check if the if-match condition is satisfied.- Parameters:
- request- The servlet request we are processing
- response- The servlet response we are creating
- resource- The resource
- Returns:
- trueif the resource meets the specified condition, and- falseif the condition is not satisfied, in which case request processing is stopped
- Throws:
- IOException- an IO error occurred
 
 - 
checkIfModifiedSinceprotected boolean checkIfModifiedSince(HttpServletRequest request, HttpServletResponse response, WebResource resource) Check if the if-modified-since condition is satisfied.- Parameters:
- request- The servlet request we are processing
- response- The servlet response we are creating
- resource- The resource
- Returns:
- trueif the resource meets the specified condition, and- falseif the condition is not satisfied, in which case request processing is stopped
 
 - 
checkIfNoneMatchprotected boolean checkIfNoneMatch(HttpServletRequest request, HttpServletResponse response, WebResource resource) throws IOException Check if the if-none-match condition is satisfied.- Parameters:
- request- The servlet request we are processing
- response- The servlet response we are creating
- resource- The resource
- Returns:
- trueif the resource meets the specified condition, and- falseif the condition is not satisfied, in which case request processing is stopped
- Throws:
- IOException- an IO error occurred
 
 - 
checkIfUnmodifiedSinceprotected boolean checkIfUnmodifiedSince(HttpServletRequest request, HttpServletResponse response, WebResource resource) throws IOException Check if the if-unmodified-since condition is satisfied.- Parameters:
- request- The servlet request we are processing
- response- The servlet response we are creating
- resource- The resource
- Returns:
- trueif the resource meets the specified condition, and- falseif the condition is not satisfied, in which case request processing is stopped
- Throws:
- IOException- an IO error occurred
 
 - 
generateETagprotected String generateETag(WebResource resource) Provides the entity tag (the ETag header) for the given resource. Intended to be over-ridden by custom DefaultServlet implementations that wish to use an alternative format for the entity tag.- Parameters:
- resource- The resource for which an entity tag is required.
- Returns:
- The result of calling WebResource.getETag()on the given resource
 
 - 
copyprotected void copy(InputStream is, ServletOutputStream ostream) throws IOException Copy the contents of the specified input stream to the specified output stream, and ensure that both streams are closed before returning (even in the face of an exception).- Parameters:
- is- The input stream to read the source resource from
- ostream- The output stream to write to
- Throws:
- IOException- if an input/output error occurs
 
 - 
copyprotected void copy(InputStream is, PrintWriter writer, String encoding) throws IOException Copy the contents of the specified input stream to the specified output stream, and ensure that both streams are closed before returning (even in the face of an exception).- Parameters:
- is- The input stream to read the source resource from
- writer- The writer to write to
- encoding- The encoding to use when reading the source input stream
- Throws:
- IOException- if an input/output error occurs
 
 - 
copyprotected void copy(WebResource resource, long length, ServletOutputStream ostream, Ranges.Entry range) throws IOException Copy the contents of the specified input stream to the specified output stream, and ensure that both streams are closed before returning (even in the face of an exception).- Parameters:
- resource- The source resource
- length- the resource length
- ostream- The output stream to write to
- range- Range the client wanted to retrieve
- Throws:
- IOException- if an input/output error occurs
 
 - 
copyprotected void copy(WebResource resource, long length, ServletOutputStream ostream, Ranges ranges, String contentType) throws IOException Copy the contents of the specified input stream to the specified output stream, and ensure that both streams are closed before returning (even in the face of an exception).- Parameters:
- resource- The source resource
- length- the resource length
- ostream- The output stream to write to
- ranges- Enumeration of the ranges the client wanted to retrieve
- contentType- Content type of the resource
- Throws:
- IOException- if an input/output error occurs
 
 - 
copyRangeprotected IOException copyRange(InputStream istream, ServletOutputStream ostream) Copy the contents of the specified input stream to the specified output stream, and ensure that both streams are closed before returning (even in the face of an exception).- Parameters:
- istream- The input stream to read from
- ostream- The output stream to write to
- Returns:
- Exception which occurred during processing
 
 - 
copyRangeprotected IOException copyRange(Reader reader, PrintWriter writer) Copy the contents of the specified input stream to the specified output stream, and ensure that both streams are closed before returning (even in the face of an exception).- Parameters:
- reader- The reader to read from
- writer- The writer to write to
- Returns:
- Exception which occurred during processing
 
 - 
copyRangeprotected IOException copyRange(InputStream istream, ServletOutputStream ostream, long start, long end) Copy the contents of the specified input stream to the specified output stream, and ensure that both streams are closed before returning (even in the face of an exception).- Parameters:
- istream- The input stream to read from
- ostream- The output stream to write to
- start- Start of the range which will be copied
- end- End of the range which will be copied
- Returns:
- Exception which occurred during processing
 
 
- 
 
-