Spring Boot 注册 Servlet 的三种方法,真是太有用了!

简介: Spring Boot 注册 Servlet 的三种方法,真是太有用了!

image.png本文栈长教你如何在 Spring Boot 注册 Servlet、Filter、Listener。


你所需具备的基础

什么是 Spring Boot?


Spring Boot 核心配置文件详解


Spring Boot 开启的 2 种方式


Spring Boot 自动配置原理、实战


Spring Boot 2.x 启动全过程源码分析


更多请在Java技术栈微信公众号后台回复关键字:boot。


一、Spring Boot 注册

Spring Boot 提供了 ServletRegistrationBean, FilterRegistrationBean, ServletListenerRegistrationBean 三个类分别用来注册 Servlet, Filter, Listener,下面是 Servlet 的示例代码。

import javax.servlet.http.HttpServlet;import javax.servlet.http.HttpServletRequest;import javax.servlet.http.HttpServletResponse;import java.io.IOException;/** * @author Java技术栈 */public class RegisterServlet extends HttpServlet {    @Override    protected void service(HttpServletRequest req, HttpServletResponse resp) throws IOException {        String name = getServletConfig().getInitParameter("name");        String sex = getServletConfig().getInitParameter("sex");        resp.getOutputStream().println("name is " + name);        resp.getOutputStream().println("sex is " + sex);    }}@Beanpublic ServletRegistrationBean registerServlet() {    ServletRegistrationBean servletRegistrationBean = new ServletRegistrationBean(            new RegisterServlet(), "/registerServlet");    servletRegistrationBean.addInitParameter("name", "javastack");    servletRegistrationBean.addInitParameter("sex", "man");    return servletRegistrationBean;}


二、组件扫描注册

Servlet 3.0 之前,Servlet、Filter、Listener 这些组件都需要在 web.xml 中进行配置,3.0 之后开始不再需要 web.xml 这个配置文件了,所有的组件都可以通过代码配置或者注解来达到目的。

如下图所示,截图自 Servlet 3.1。

image.png


Servlet 3.0 开始提供了这 3 个注解来代替。


@WebServlet => 代替 servlet 配置


@WebFilter => 代替 filter 配置


@WebListener => 代替 listener 配置


配置 Servlet 示例

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;/** * @author Java技术栈 */@WebServlet(name = "javaServlet", urlPatterns = "/javastack.cn", asyncSupported = true,        initParams = {        @WebInitParam(name = "name", value = "javastack"),        @WebInitParam(name = "sex", value = "man") })public class JavaServlet extends HttpServlet {    @Override    protected void service(HttpServletRequest req, HttpServletResponse resp) throws IOException {        String name = getServletConfig().getInitParameter("name");        String sex = getServletConfig().getInitParameter("sex");        resp.getOutputStream().println("name is " + name);        resp.getOutputStream().println("sex is " + sex);    }}

配置 Filter 示例

/** * @author Java技术栈 */@WebFilter(filterName = "javaFilter", urlPatterns = "/*", initParams = {        @WebInitParam(name = "name", value = "javastack"),        @WebInitParam(name = "code", value = "123456") })public class JavaFilter implements Filter {    @Override    public void init(FilterConfig filterConfig) throws ServletException {        System.out.println("java filter init.");        String name = filterConfig.getInitParameter("name");        String code = filterConfig.getInitParameter("code");        System.out.println("name is " + name);        System.out.println("code is " + code);    }    @Override    public void doFilter(ServletRequest request, ServletResponse response, FilterChain chain)            throws IOException, ServletException {        System.out.println("java filter processing.");        chain.doFilter(request, response);    }    @Override    public void destroy() {        System.out.println("java filter destroy.");    }}

Listener 配置方式类似,上面的示例代码一看就懂,这里不再详述。


需要注意的是,为了安全考虑,内嵌服务器不会直接执行 Servlet 3.0 里面的 javax.servlet.ServletContainerInitializer 接口,或者 Spring 中的 org.springframework.web.WebApplicationInitializer 接口,否则会导致终止 Spring Boot 应用。


所以,如果使用的是 Spring Boot 内嵌服务器,需要在配置类上面添加额外的 @ServletComponentScan 注解来开启 Servlet 组件扫描功能,如果使用的是独立的服务器,则不需要添加,会使用服务器内部的自动发现机制。


三、动态注册

如果你想在 Spring Boot 中完成 Servlet、Filter、Listener 的初始化操作,你需要在 Spring 中实现下面这个接口,并注册为一个 bean。


org.springframework.boot.web.servlet.ServletContextInitializer


ServletContext 提供了几个动态注册的方法,如下所示。

image.png


以下为动态添加 Servlet 示例代码。

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;/** * @author Java技术栈 */@WebServlet(name = "javaServlet", urlPatterns = "/javastack.cn", asyncSupported = true,        initParams = {        @WebInitParam(name = "name", value = "javastack"),        @WebInitParam(name = "sex", value = "man") })public class JavaServlet extends HttpServlet {    @Override    protected void service(HttpServletRequest req, HttpServletResponse resp) throws IOException {        String name = getServletConfig().getInitParameter("name");        String sex = getServletConfig().getInitParameter("sex");        resp.getOutputStream().println("name is " + name);        resp.getOutputStream().println("sex is " + sex);    }}import cn.javastack.springbootbestpractice.servlet.InitServlet;import org.springframework.boot.web.servlet.ServletContextInitializer;import org.springframework.stereotype.Component;import javax.servlet.ServletContext;import javax.servlet.ServletRegistration;/** * @author Java技术栈 */@Componentpublic class ServletConfig implements ServletContextInitializer {    @Override    public void onStartup(ServletContext servletContext) {        ServletRegistration initServlet = servletContext                .addServlet("initServlet", InitServlet.class);        initServlet.addMapping("/initServlet");        initServlet.setInitParameter("name", "javastack");        initServlet.setInitParameter("sex", "man");    }}

总结

本文介绍了在 Spring Boot 下的 3 种注册 Servlet、Filter、Listener 的方式,大家灵活运用。


相关文章
|
3月前
|
Java 开发者 Spring
【SpringBoot 异步魔法】@Async 注解:揭秘 SpringBoot 中异步方法的终极奥秘!
【8月更文挑战第25天】异步编程对于提升软件应用的性能至关重要,尤其是在高并发环境下。Spring Boot 通过 `@Async` 注解简化了异步方法的实现。本文详细介绍了 `@Async` 的基本用法及配置步骤,并提供了示例代码展示如何在 Spring Boot 项目中创建与管理异步任务,包括自定义线程池、使用 `CompletableFuture` 处理结果及异常情况,帮助开发者更好地理解和运用这一关键特性。
177 1
|
3天前
|
存储 运维 安全
Spring运维之boot项目多环境(yaml 多文件 proerties)及分组管理与开发控制
通过以上措施,可以保证Spring Boot项目的配置管理在专业水准上,并且易于维护和管理,符合搜索引擎收录标准。
12 2
|
1月前
|
SQL JSON Java
mybatis使用三:springboot整合mybatis,使用PageHelper 进行分页操作,并整合swagger2。使用正规的开发模式:定义统一的数据返回格式和请求模块
这篇文章介绍了如何在Spring Boot项目中整合MyBatis和PageHelper进行分页操作,并且集成Swagger2来生成API文档,同时定义了统一的数据返回格式和请求模块。
52 1
mybatis使用三:springboot整合mybatis,使用PageHelper 进行分页操作,并整合swagger2。使用正规的开发模式:定义统一的数据返回格式和请求模块
|
17天前
|
前端开发 Java Spring
Spring MVC源码分析之DispatcherServlet#getHandlerAdapter方法
`DispatcherServlet`的 `getHandlerAdapter`方法是Spring MVC处理请求的核心部分之一。它通过遍历预定义的 `HandlerAdapter`列表,找到适用于当前处理器的适配器,并调用适配器执行具体的处理逻辑。理解这个方法有助于深入了解Spring MVC的工作机制和扩展点。
24 1
|
18天前
|
前端开发 Java Spring
Spring MVC源码分析之DispatcherServlet#getHandlerAdapter方法
`DispatcherServlet`的 `getHandlerAdapter`方法是Spring MVC处理请求的核心部分之一。它通过遍历预定义的 `HandlerAdapter`列表,找到适用于当前处理器的适配器,并调用适配器执行具体的处理逻辑。理解这个方法有助于深入了解Spring MVC的工作机制和扩展点。
24 1
|
23天前
|
存储 安全 Java
|
15天前
|
前端开发 Java Spring
Spring MVC源码分析之DispatcherServlet#getHandlerAdapter方法
`DispatcherServlet`的 `getHandlerAdapter`方法是Spring MVC处理请求的核心部分之一。它通过遍历预定义的 `HandlerAdapter`列表,找到适用于当前处理器的适配器,并调用适配器执行具体的处理逻辑。理解这个方法有助于深入了解Spring MVC的工作机制和扩展点。
19 0
|
1月前
|
缓存 NoSQL Java
Springboot自定义注解+aop实现redis自动清除缓存功能
通过上述步骤,我们不仅实现了一个高度灵活的缓存管理机制,还保证了代码的整洁与可维护性。自定义注解与AOP的结合,让缓存清除逻辑与业务逻辑分离,便于未来的扩展和修改。这种设计模式非常适合需要频繁更新缓存的应用场景,大大提高了开发效率和系统的响应速度。
57 2
|
2月前
|
XML 缓存 Java
spring源码剖析-spring-beans(内部核心组件,BeanDefinition的注册,BeanWapper创建)
spring源码剖析-spring-beans(内部核心组件,BeanDefinition的注册,BeanWapper创建)
49 10
|
2月前
|
Java 应用服务中间件 Spring
IDEA 工具 启动 spring boot 的 main 方法报错。已解决
IDEA 工具 启动 spring boot 的 main 方法报错。已解决