什么是WebServlet注解
概念:
为了简化 Servlet 的配置而产生的
作用:
使 web.xml 从 Servlet 3.0 开始不再是必选项了
@WebServlet注解的属性
作用:
-
@WebServlet 将一个类声明为 Servlet
-
该注解会在部署时被容器处理
-
容器根据其具体的属性配置将相应的类部署为 Servlet。
常见属性:
属性名 | 类型 | 标签 | 描述 | 是否必需 |
---|---|---|---|---|
name | String | <servlet-name> |
指定 Servlet 的 name 属性。 如果没有显式指定,则取值为该 Servlet 的完全限定名,即包名+类名。 | 否 |
value | String[ ] | <url-pattern> |
该属性等价于 urlPatterns 属性,两者不能同时指定。 如果同时指定,通常是忽略 value 的取值。 | 是 |
urlPatterns | String[ ] | <url-pattern> |
指定一组 Servlet 的 URL 匹配模式。 | 是 |
loadOnStartup | int | <load-on-startup> |
指定 Servlet 的加载顺序。 | 否 |
initParams | WebInitParam[ ] | <init-param> |
指定一组 Servlet 初始化参数。 | 否 |
asyncSupported | boolean | <async-supported> |
声明 Servlet 是否支持异步操作模式。 | 否 |
description | String | <description> |
指定该 Servlet 的描述信息。 | 否 |
displayName | String | <display-name> |
指定该 Servlet 的显示名。 | 否 |
@WebServlet注解的使用
启用注解支持
使用@WebServlet注解
启用注解支持
过程:
-
在web.xml的顶层标签
<web-app>
中设置属性-
设置
metadata-complete
-
属性设置为 true,则容器在部署时将只依赖 web.xml,忽略所有的注解
-
不配置该属性,或者将其设置为 false,则表示启用注解支持
-
-
示例注解:
使用注解
不必创建 web.xml 文件。
使用@WebServlet注解
特点:
@WebServlet 属于类级别的注解,标注在继承了 HttpServlet 的类之上--->写在类上方
完整写法:
常用写法:
注释中设置多个属性需要用,
隔开
示例代码:
package ServletPractice;
import javax.jws.WebService;
import javax.servlet.ServletException;
import javax.servlet.annotation.WebInitParam;
import javax.servlet.annotation.WebServlet;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import java.io.IOException;
/**
* 使用注释的方式实现web.xml中创建Servlet容器的效果
* @since JDK 1.8
* @date 2021/09/14
* @author Lucifer
*/
注意事项:
-
通过实现 Serlvet 接口或继承 GenericServlet 创建的 Servlet 类无法使用 @WebServlet 注解。
-
使用 @WebServlet 注解配置的 Servlet 类,不要在 web.xml 文件中再次配置该 Servlet 相关属性
-