从 01 开始 从 01 开始
首页
  • 📚 计算机基础

    • 计算机简史
    • 数字电路
    • 计算机组成原理
    • 操作系统
    • Linux
    • 计算机网络
    • 数据库
    • 编程工具
    • 装机
  • 🎨 前端

    • Node
  • JavaSE
  • Java 高级
  • JavaEE

    • 构建、依赖管理
    • Ant
    • Maven
    • 日志框架
    • Junit
    • JDBC
    • XML-JSON
  • JavaWeb

    • 服务器软件
    • 环境管理和配置管理-科普篇
    • Servlet
  • Spring

    • Spring基础
  • 主流框架

    • Redis
    • Mybatis
    • Lucene
    • Elasticsearch
    • RabbitMQ
    • MyCat
    • Lombok
  • SpringMVC

    • SpringMVC 基础
  • SpringBoot

    • SpringBoot 基础
  • Windows 使用技巧
  • 手机相关技巧
  • 最全面的输入法教程
  • 最全面的浏览器教程
  • Office
  • 图片类工具
  • 效率类工具
  • 最全面的 RSS 教程
  • 码字工具
  • 各大平台
  • 校招
  • 五险一金
  • 职场规划
  • 关于离职
  • 杂谈
  • 自媒体
  • 📖 读书

    • 读书工具
    • 走进科学
  • 🌍 英语

    • 从零开始学英语
    • 英语兔的相关视频
    • Larry 想做技术大佬的相关视频
  • 🏛️ 政治

    • 新闻合订本
    • 反腐
    • GFW
    • 404 内容
    • 审查与自我审查
    • 互联网
    • 战争
    • 读书笔记
  • 💰 经济

    • 关于税
    • 理财
  • 💪 健身

    • 睡眠
    • 皮肤
    • 口腔健康
    • 学会呼吸
    • 健身日志
  • 🏠 其他

    • 驾驶技能
    • 租房与买房
    • 厨艺
  • 电影

    • 电影推荐
  • 电视剧
  • 漫画

    • 漫画软件
    • 漫画推荐
  • 游戏

    • Steam
    • 三国杀
    • 求生之路
  • 小说
  • 关于本站
  • 关于博主
  • 打赏
  • 网站动态
  • 友人帐
  • 从零开始搭建博客
  • 搭建邮件服务器
  • 本站分享
  • 🌈 生活

    • 2022
    • 2023
    • 2024
    • 2025
  • 📇 文章索引

    • 文章分类
    • 文章归档

晓林

程序猿,自由职业者,博主,英语爱好者,健身达人
首页
  • 📚 计算机基础

    • 计算机简史
    • 数字电路
    • 计算机组成原理
    • 操作系统
    • Linux
    • 计算机网络
    • 数据库
    • 编程工具
    • 装机
  • 🎨 前端

    • Node
  • JavaSE
  • Java 高级
  • JavaEE

    • 构建、依赖管理
    • Ant
    • Maven
    • 日志框架
    • Junit
    • JDBC
    • XML-JSON
  • JavaWeb

    • 服务器软件
    • 环境管理和配置管理-科普篇
    • Servlet
  • Spring

    • Spring基础
  • 主流框架

    • Redis
    • Mybatis
    • Lucene
    • Elasticsearch
    • RabbitMQ
    • MyCat
    • Lombok
  • SpringMVC

    • SpringMVC 基础
  • SpringBoot

    • SpringBoot 基础
  • Windows 使用技巧
  • 手机相关技巧
  • 最全面的输入法教程
  • 最全面的浏览器教程
  • Office
  • 图片类工具
  • 效率类工具
  • 最全面的 RSS 教程
  • 码字工具
  • 各大平台
  • 校招
  • 五险一金
  • 职场规划
  • 关于离职
  • 杂谈
  • 自媒体
  • 📖 读书

    • 读书工具
    • 走进科学
  • 🌍 英语

    • 从零开始学英语
    • 英语兔的相关视频
    • Larry 想做技术大佬的相关视频
  • 🏛️ 政治

    • 新闻合订本
    • 反腐
    • GFW
    • 404 内容
    • 审查与自我审查
    • 互联网
    • 战争
    • 读书笔记
  • 💰 经济

    • 关于税
    • 理财
  • 💪 健身

    • 睡眠
    • 皮肤
    • 口腔健康
    • 学会呼吸
    • 健身日志
  • 🏠 其他

    • 驾驶技能
    • 租房与买房
    • 厨艺
  • 电影

    • 电影推荐
  • 电视剧
  • 漫画

    • 漫画软件
    • 漫画推荐
  • 游戏

    • Steam
    • 三国杀
    • 求生之路
  • 小说
  • 关于本站
  • 关于博主
  • 打赏
  • 网站动态
  • 友人帐
  • 从零开始搭建博客
  • 搭建邮件服务器
  • 本站分享
  • 🌈 生活

    • 2022
    • 2023
    • 2024
    • 2025
  • 📇 文章索引

    • 文章分类
    • 文章归档
  • JavaSE

  • JavaSenior

  • JavaEE

  • JavaWeb

    • 服务器软件

    • 环境管理和配置管理-科普篇
    • Servlet 入门

      • 什么是 Servlet
      • Servlet 入门案例
      • Servlet 生命周期
      • Servlet 中的注解
        • 注解的好处
        • 使用注解
        • @WebServlet 注解的原理
        • 资源路径的配置
      • Tomcat 集成 IDEA
      • Servlet 体系结构
      • HTTP 协议基础
      • 深入 request 和 response 对象
      • request 对象基本使用
      • request 其他功能
      • Servlet 实现登录功能
      • HTTP 协议基础-响应
      • Response 对象基本使用
      • response 对象之重定向
      • response 输出字符到浏览器
      • response 输出字节数据
      • 验证码案例
      • ServletContext
      • 文件下载案例
      • Cookie 笔记
      • Cookie 的更多细节
      • Cookie 实践:记住上次访问时间
      • JSP 入门
      • JSP 的内置对象和案例
      • IDEA 与 JavaWeb 的小技巧
      • Session 笔记
      • 验证码案例
      • JSP 深入学习
      • MVC 开发模式
      • EL 表达式和 JSTL 标签
      • JSTL 标签库
      • 案例:列表的增删改查
      • Filter 学习
      • Filter 案例
      • Listener 学习
      • Java 中的 Ajax
      • Java 中的 JSON
  • Spring

  • 主流框架

  • SpringMVC

  • SpringBoot

  • Java
  • JavaWeb
  • Servlet 入门
2023-04-17
目录

Servlet 中的注解

# 10.Servlet 中的注解

为了简化 web.xml 的配置,我们可以使用注解。

# 注解的好处

一个项目的功能是非常多的,为了避免一个 Servlet 代码过长,我们会分很多个 Servlet;

但随着 Servlet 的增多,web.xml 配置也注解增多,等 web.xml 也变的很长的时候,就不便于维护了,为此我们可以使用注解,简化配置。

# 使用注解

我们根据以下步骤来演示如何使用注解:

  1. 定义一个类,实现 Servlet 接口
  2. 复写方法
  3. 在类上使用@WebServlet 注解:@WebServlet("资源路径") 因为该注解就是在类上的,不用再写全类名,只需关心资源路径即可。 ‍ 然后我们编写 service 方法:
@WebServlet("/demo3")
public class ServletDemo3Anno implements Servlet {
    // 省略其他代码.... 

    public void service(ServletRequest servletRequest, ServletResponse servletResponse) throws ServletException, IOException {
        System.out.println("Hello Servlet Annotation!");
    }

    // 省略其他代码.... 
}
1
2
3
4
5
6
7
8
9
10

‍ 重启项目并访问 http://localhost: 8080/hello/demo3,可以看到控制台打印了

Hello Servlet Annotation!
1

版本注意:需要 Servlet3.0 及以上,也就是 JavaEE 6 及以上(目前基本上都是,如果遇到低版本的需要注意)

使用了注解后,我们可以不使用 web.xml 了,删掉也可以

# @WebServlet 注解的原理

为什么@WebServlet 可以实现简化配置呢?其实我们看看源码就知道了。WebServlet.class 的部分源码如下 ↓ 每一个都有默认值

@Target({ElementType.TYPE})
@Retention(RetentionPolicy.RUNTIME)
@Documented
public @interface WebServlet {
    String name() default "";  //相当于 <Servlet-name>,全类名

    String[] value() default {};//代表 urlPatterns()属性配置

    String[] urlPatterns() default {};//相当于 <url-pattern>   一个数组,可以有多个资源路径对应

    int loadOnStartup() default -1;//相当于 <load-on-startup>

    WebInitParam[] initParams() default {};

    boolean asyncSupported() default false;

    String smallIcon() default "";

    String largeIcon() default "";

    String description() default "";

    String displayName() default "";
}
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24

可以看到关键的是 value 这个默认属性,代表的就是 urlPatterns 这个属性,而 urlPatterns 就是资源路径。

之所以是 String 数组。是因为一个 Servlet 可以有多个访问路径,例如 web.xml 中这样配置:

<servlet-mapping>
    <servlet-name>demo2</servlet-name>  <!-- 访问路径时,使用哪个Servlet-->
    <url-pattern>/demo2</url-pattern>   <!-- 访问哪个路径-->
</servlet-mapping>

<!-- 可以多个路径对应一个Servlet   -->
<servlet-mapping>
    <servlet-name>demo2</servlet-name>  <!-- 访问路径时,使用哪个Servlet-->
    <url-pattern>/demo4</url-pattern>   <!-- 访问哪个路径-->
</servlet-mapping>
1
2
3
4
5
6
7
8
9
10

为此,可以有如下写法

@WebServlet(urlPatterns = {"/demo3", "/demo5"})
@WebServlet(urlPatterns = "/demo3") //如果只有一个值,可以省略大括号
@WebServlet("/demo3") //如果只有一个值,可以省略 urlPatterns
1
2
3

# 资源路径的配置

urlpartten 配置的是 Servlet 访问路径,也叫资源路径

那么路径能怎么定义呢?支持正则吗?支持多层路径吗?有如下写法:

  • /xxx:路径匹配
  • /xxx/xxx:多层路径,目录结构
  • 通配符匹配:例如 @WebServlet({"/user/*"}),就是访问任何 user 的子目录都匹配
  • *.do:扩展名匹配,访问任何.do 路径都会执行,例如 localhost/demo.do。也可以定义为其他扩展名,例如 .action 等。 注意扩展名前面不能加斜线/,例如这样定义会报错:@WebServlet("/*.do")
  • 如果多个 Servlet 都匹配了某个路径,则看优先级。 通配符星号 * 是非常低的,如果有一个 Servlet1 定义的路径是 /demo3,而有个 Servlet2 的放了路径是 /*,那么访问/demo3 的时候, 只有 Servlet1 的 service 方法会执行。

注意,不能一个资源路径与与其他 Servlet 重复,例如两个 Servlet 的访问路径都是 /demo1,这样启动会报错。

上次更新: 2025/6/3 09:31:54
Servlet 生命周期
Tomcat 集成 IDEA

← Servlet 生命周期 Tomcat 集成 IDEA→

最近更新
01
新闻合订本 2025-10
10-31
02
2025 年 10 月记
10-30
03
用 AI 批量优化思源笔记排版
10-15
更多文章>
Theme by Vdoing | Copyright © 2022-2025 | 粤 ICP 备 2022067627 号 -1 | 粤公网安备 44011302003646 号 | 点击查看十年之约
  • 跟随系统
  • 浅色模式
  • 深色模式
  • 阅读模式