news 2026/4/20 3:49:56

“Default Servlet Reference Table of Contents” 并非一个标准的、由官方(如 Oracle、Apache Tomcat 或 Jakarta EE 规范)

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
“Default Servlet Reference Table of Contents” 并非一个标准的、由官方(如 Oracle、Apache Tomcat 或 Jakarta EE 规范)

“Default Servlet Reference Table of Contents” 并非一个标准的、由官方(如 Oracle、Apache Tomcat 或 Jakarta EE 规范)发布的独立文档标题。它通常指Tomcat 服务器中 DefaultServlet 的功能说明与配置参考的目录结构,即对 Tomcat 内置的org.apache.catalina.servlets.DefaultServlet(负责静态资源服务,如 HTML、CSS、JS、图片等)的配置项、行为特性、初始化参数及其作用的概览性目录。

以下是典型的Tomcat DefaultServlet 参考文档的目录结构(Table of Contents)

  1. Overview of the Default Servlet
  2. Purpose and Responsibilities
  3. Configuration in web.xml (or context.xml / server.xml)
  4. Initialization Parameters (init-param)
    -debug
    -listings(目录浏览开关)
    -readonly(是否禁止 PUT/DELETE 等写操作)
    -sendfile(启用零拷贝传输)
    -fileEncoding/inputEncoding/outputEncoding
    -useAcceptRanges
    -welcomeFiles(补充默认欢迎页)
  5. MIME Type Mapping and Resource Handling
  6. Caching Behavior and Cache Control Headers
  7. Security Considerations (e.g., path traversal protection, hidden file filtering)
  8. Customization via Subclassing or Replacement
  9. Common Use Cases & Examples
  10. Troubleshooting & Logging Tips

✅ 注:该内容基于 Apache Tomcat 9/10 官方文档(DefaultServlet)整理;Jakarta EE 规范本身不定义 DefaultServlet 实现,而是由各 Servlet 容器(如 Tomcat、Jetty、WildFly)自行提供。

<!-- 示例:在 web.xml 中配置 DefaultServlet(通常无需显式配置,除非需覆盖默认行为) --><servlet><servlet-name>default</servlet-name><servlet-class>org.apache.catalina.servlets.DefaultServlet</servlet-class><init-param><param-name>listings</param-name><param-value>false</param-value></init-param><load-on-startup>1</load-on-startup></servlet>

Default Servlet Reference Table of Contents
What is the DefaultServlet
Where is it declared?
What can I change?
How do I customize directory listings?
How do I secure directory listings?

What is the DefaultServlet

The default servlet is the servlet which serves static resources as well as serves the directory listings (if directory listings are enabled).
Where is it declared?

It is declared globally in $CATALINA_BASE/conf/web.xml. By default here is it’s declaration:

<servlet> <servlet-name>default</servlet-name> <servlet-class> org.apache.catalina.servlets.DefaultServlet </servlet-class> <init-param> <param-name>debug</param-name> <param-value>0</param-value> </init-param> <init-param> <param-name>listings</param-name> <param-value>false</param-value> </init-param> <load-on-startup>1</load-on-startup> </servlet>

<servlet-mapping> <servlet-name>default</servlet-name> <url-pattern>/</url-pattern> </servlet-mapping>

So by default, the default servlet is loaded at webapp startup and directory listings are disabled and debugging is turned off.
What can I change?

The DefaultServlet allows the following initParamters:
Property Description
debug Debugging level. It is not very useful unless you are a tomcat developer. As of this writing, useful values are 0, 1, 11, 1000. [0]
listings If no welcome file is present, can a directory listing be shown? value may be true or false [false]
Welcome files are part of the servlet api.
WARNING: Listings of directories containing many entries are expensive. Multiple requests for large directory listings can consume significant proportions of server resources.
precompressed If a precompressed version of a file exists (a file with .br or .gz appended to the file name located alongside the original file), Tomcat will serve the precompressed file if the user agent supports the matching content encoding (br or gzip) and this option is enabled. [false]
The precompressed file with the with .br or .gz extension will be accessible if requested directly so if the original resource is protected with a security constraint, the precompressed versions must be similarly protected.
It is also possible to configure the list of precompressed formats. The syntax is comma separated list of [content-encoding]=[file-extension] pairs. For example: br=.br,gzip=.gz,bzip2=.bz2. If multiple formats are specified, the client supports more than one and the client does not express a preference, the order of the list of formats will be treated as the server preference order and used to select the format returned.
readmeFile If a directory listing is presented, a readme file may also be presented with the listing. This file is inserted as is so it may contain HTML.
globalXsltFile If you wish to customize your directory listing, you can use an XSL transformation. This value is a relative file name (to either $CATALINA_BASE/conf/ or $CATALINA_HOME/conf/) which will be used for all directory listings. This can be overridden per context and/or per directory. See contextXsltFile and localXsltFile below. The format of the xml is shown below.
contextXsltFile You may also customize your directory listing by context by configuring contextXsltFile. This must be a context relative path (e.g.: /path/to/context.xslt) to a file with a .xsl or .xslt extension. This overrides globalXsltFile. If this value is present but a file does not exist, then globalXsltFile will be used. If globalXsltFile does not exist, then the default directory listing will be shown.
localXsltFile You may also customize your directory listing by directory by configuring localXsltFile. This must be a file in the directory where the listing will take place to with a .xsl or .xslt extension. This overrides globalXsltFile and contextXsltFile. If this value is present but a file does not exist, then contextXsltFile will be used. If contextXsltFile does not exist, then globalXsltFile will be used. If globalXsltFile does not exist, then the default directory listing will be shown.
input Input buffer size (in bytes) when reading resources to be served. [2048]
output Output buffer size (in bytes) when writing resources to be served. [2048]
readonly Is this context “read only”, so HTTP commands like PUT and DELETE are rejected? [true]
fileEncoding File encoding to be used when reading static resources. [platform default]
sendfileSize If the connector used supports sendfile, this represents the minimal file size in KB for which sendfile will be used. Use a negative value to always disable sendfile. [48]
useAcceptRanges If true, the Accept-Ranges header will be set when appropriate for the response. [true]
showServerInfo Should server information be presented in the response sent to clients when directory listing is enabled. [true]
sortListings Should the server sort the listings in a directory. [false]
sortDirectoriesFirst Should the server list all directories before all files. [false]
How do I customize directory listings?

You can override DefaultServlet with you own implementation and use that in your web.xml declaration. If you can understand what was just said, we will assume you can read the code to DefaultServlet servlet and make the appropriate adjustments. (If not, then that method isn’t for you)

You can use either localXsltFile or globalXsltFile and DefaultServlet will create an xml document and run it through an xsl transformation based on the values provided in localXsltFile and globalXsltFile. localXsltFile is first checked, followed by globalXsltFile, then default behaviors takes place.

Format:

<listing> <entries> <entry type='file|dir' urlPath='aPath' size='###' date='gmt date'> fileName1 </entry> <entry type='file|dir' urlPath='aPath' size='###' date='gmt date'> fileName2 </entry> ... </entries> <readme></readme> </listing> size will be missing if type='dir' Readme is a CDATA entry

The following is a sample xsl file which mimics the default tomcat behavior:

<?xml version="1.0" encoding="UTF-8"?>

<xsl:stylesheet xmlns:xsl=“http://www.w3.org/1999/XSL/Transform”
version=“3.0”>

<xsl:output method=“html” html-version=“5.0”
encoding=“UTF-8” indent=“no”
doctype-system=“about:legacy-compat”/>

<xsl:template match=“listing”>

Sample Directory Listing For

Sample Directory Listing For


FilenameSizeLast Modified

Apache Tomcat/8.5

<xsl:template match=“entries”>
<xsl:apply-templates select=“entry”/>
</xsl:template>

<xsl:template match=“readme”>



xsl:apply-templates/

</xsl:template>

<xsl:template match=“entry”>


<xsl:variable name=“urlPath” select=“@urlPath”/>

xsl:apply-templates/




<xsl:value-of select=“@size”/>



<xsl:value-of select=“@date”/>



</xsl:template>

</xsl:stylesheet>

How do I secure directory listings?
Use web.xml in each individual webapp. See the security section of the Servlet specification.

您可以使用自己的实现重写DefaultServlet,并在web.xml声明中使用它。如果您能够理解刚才所说的,我们假设您可以将代码读取到DefaultServletServlet并进行适当的调整。(如果不是,那么这种方法不适合你)
您可以使用localXsltFile或globalXsltFile,DefaultServlet将创建一个xml文档,并根据localXsltFile和globalXsltFile中提供的值通过xsl转换运行它。首先检查localXsltFile,然后检查globalXsltFile,然后执行默认行为。

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/20 3:47:15

HTML5中解决数据库版本号管理混乱的规范化建议

IndexedDB 通过整数版本号和 upgradeneeded 事件实现可靠 schema 迁移&#xff0c;版本必须递增、迁移逻辑须幂等且仅在该事件中执行&#xff0c;Web SQL 已废弃不应使用。HTML5 的 Web SQL Database&#xff08;已废弃&#xff09;和 IndexedDB 都不直接提供“数据库版本号管理…

作者头像 李华
网站建设 2026/4/20 3:46:13

微信每日说Docker部署完整教程:快速搭建稳定运行环境

微信每日说Docker部署完整教程&#xff1a;快速搭建稳定运行环境 【免费下载链接】wechatBot 微信每日说&#xff0c;三步教你用Node做一个微信哄女友(基友)神器&#xff01;还能帮女朋友解决垃圾分类难题 项目地址: https://gitcode.com/gh_mirrors/we/wechatBot 微信每…

作者头像 李华
网站建设 2026/4/20 3:42:54

XStream安全机制详解:从ForbiddenClassException看Java反序列化安全最佳实践

XStream安全机制深度解析&#xff1a;构建坚不可摧的Java反序列化防线 当XML数据流经XStream转换器时&#xff0c;一个未被妥善处理的类引用可能成为整个系统的阿喀琉斯之踵。2019年某知名电商平台因反序列化漏洞导致千万级用户数据泄露的案例&#xff0c;至今仍是Java开发者心…

作者头像 李华
网站建设 2026/4/20 3:42:11

JSON Resume Schema版本管理:遵循Semantic Versioning的最佳实践

JSON Resume Schema版本管理&#xff1a;遵循Semantic Versioning的最佳实践 【免费下载链接】resume-schema JSON-Schema is used here to define and validate our proposed resume json 项目地址: https://gitcode.com/gh_mirrors/re/resume-schema JSON Resume Sche…

作者头像 李华
网站建设 2026/4/20 3:42:09

深入解析ELL核心架构:节点、端口与模型编译原理

深入解析ELL核心架构&#xff1a;节点、端口与模型编译原理 【免费下载链接】ELL Embedded Learning Library 项目地址: https://gitcode.com/gh_mirrors/el/ELL Embedded Learning Library&#xff08;ELL&#xff09;是一款专为嵌入式设备优化的机器学习框架&#xff…

作者头像 李华