Spring Boot 之Servlet、Listener、Filter

 在Spring Boot中,当需要以注解的方式添加session监听器、过滤器时,为了让其生效,还需要在配置类上添加@ServletComponentScan注解,该注解的作用是告诉spring boot,让其自动管理servlet,否则注解方式注册的servlet不起作用

一、添加自定义Servlet 

	/**
	 * 注册Servlet. 不需要添加注解:@ServletComponentScan
	 * @return
	 */
	@Bean
	public ServletRegistrationBean demoServlet(){
		ServletRegistrationBean registrationBean = new ServletRegistrationBean();
		registrationBean.setServlet(new DemoServlet());
		registrationBean.addUrlMappings("/demoServlet");
		return registrationBean;
	}
package cn.wuweixiang.springbootdemo.servlet;

import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import java.io.IOException;
import java.io.PrintWriter;

/**
 * DemoServlet
 *
 * @author weixiang.wu
 * @date 2018-08-22 20:34
 **/
public class DemoServlet extends HttpServlet {

	@Override
	protected void doGet(HttpServletRequest req, HttpServletResponse resp) {
		System.out.println(">>>>>>>>>>doGet()<<<<<<<<<<<");
	}

	@Override
	protected void doPost(HttpServletRequest req, HttpServletResponse resp) throws IOException {
		System.out.println(">>>>>>>>>>doPost()<<<<<<<<<<<");
		resp.setContentType("text/html");
		PrintWriter out = resp.getWriter();
		out.println("<html>");
		out.println("<head>");
		out.println("<title>Hello World</title>");
		out.println("</head>");
		out.println("<body>");
		out.println("<h1>这是:DemoServlet</h1>");
		out.println("</body>");
		out.println("</html>");
	}
}

二、添加监听器 

	/**
	 *  1.使用ServletListenerRegistrationBean注册Listener,只需要在@Configuration类中加入即可
	 *  2.直接使用@WebFilter
	 * @return
	 */
//	@Bean
//	public ServletListenerRegistrationBean<DemoListener> myServletListener() {
//		ServletListenerRegistrationBean<DemoListener> demoListener = new ServletListenerRegistrationBean<DemoListener>();
//		demoListener.setListener(new DemoListener());
//		return demoListener;
//	}
package cn.wuweixiang.springbootdemo.listener;

import javax.servlet.ServletContextEvent;
import javax.servlet.ServletContextListener;
import javax.servlet.annotation.WebListener;

/**
 * DemoListener
 *
 * @author weixiang.wu
 * @date 2018-08-22 20:49
 **/
@WebListener
public class DemoListener implements ServletContextListener {
	@Override
	public void contextInitialized(ServletContextEvent sce) {
		System.err.println("DemoListener.contextInitialized");
	}

	@Override
	public void contextDestroyed(ServletContextEvent sce) {
		System.err.println("DemoListener.contextDestroyed");
	}
}

三、添加过滤器

	/**
	 * 1.使用FilterRegistrationBean注册Filter,只需要在@Configuration类中加入即可
	 * 2.直接使用@WebFilter
	 * @see DemoFilter
	 * @return
	 */
//	@Bean
//	public FilterRegistrationBean demoFilter() {
//		FilterRegistrationBean demoFilter = new FilterRegistrationBean();
//		demoFilter.addUrlPatterns("/*");
//		demoFilter.setFilter(new DemoFilter());
//		return demoFilter;
//	}
package cn.wuweixiang.springbootdemo.filter;

import org.springframework.core.annotation.Order;

import javax.servlet.*;
import javax.servlet.annotation.WebFilter;
import java.io.IOException;

/**
 * DemoFilter
 *
 * @author weixiang.wu
 * @date 2018-08-22 20:43
 **/
@WebFilter(urlPatterns = "/*")
/** Lower values have higher priority.*/
@Order(value = 1)
public class DemoFilter implements Filter {
   @Override
   public void init(FilterConfig filterConfig) throws ServletException {
      System.err.println("DemoFilter.init");
   }

   @Override
   public void doFilter(ServletRequest request, ServletResponse response, FilterChain chain) throws IOException, ServletException {
      System.err.println("DemoFilter.doFilter");
   }

   @Override
   public void destroy() {
      System.err.println("DemoFilter.destroy");
   }
}     

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

发表于

我来说两句

0 条评论
登录 后参与评论

相关文章

来自专栏IT技术精选文摘

深入分析Spring 与 Spring MVC容器

public WebApplicationContext initWebApplicationContext(ServletContext servletCon...

2506
来自专栏码匠的流水账

聊聊SecurityContextPersistenceFilter

本文主要研究下SecurityContextPersistenceFilter的作用。

1042
来自专栏码匠的流水账

spring security免登录动态配置方案2

之前有篇文章讲了怎么进行免登录动态配置的方案,动用了反射去实现,有点黑魔法的味道,这里再介绍另外一种方案

1461
来自专栏Spring相关

SpringSecurity自定义用户登录

根据上一节的配置,默认在服务开启的时候会被要求自动的进行表单登陆。用到的用户名只能是一个固定的用户名user,它的密码是每次启动的时候服务器自动生成的。最常见的...

1.5K3
来自专栏JadePeng的技术博客

spring security实现动态配置url权限的两种方法

标准的RABC, 权限需要支持动态配置,spring security默认是在代码里约定好权限,真实的业务场景通常需要可以支持动态配置角色访问权限,即在运行时去...

4740
来自专栏Netkiller

Spring boot 2.0 with Oauth2 + Jwt

中国广东省深圳市宝安区龙华镇溪山美地 518109 +86 13113668890 +86 755 29812080 <>

1.2K0
来自专栏一个会写诗的程序员的博客

【Kotlin Spring Boot 服务端开发: 问题集锦】Spring Security 5 : There is no PasswordEncoder mapped for the id "

【Kotlin Spring Boot 服务端开发: 问题集锦】Spring Security 5 : There is no PasswordEncoder...

971
来自专栏JavaEdge

Spring Http源码

/* Copyright 2002-2017 the original author or authors. Licensed under the Apac...

3495
来自专栏osc同步分享

springmvc下载文件

@RequestMapping("/testResponseEntity") public ResponseEntity<byte[]> testRespo...

2237
来自专栏码匠的流水账

spring security自定义指南

AuthenticationManager接口有个实现ProviderManager相当于一个provider chain,它里头有个List provider...

4111

扫码关注云+社区

领取腾讯云代金券