Spring常用注解及自定义Filter的实现

@Configuration通常用在配置类上,告诉spring这是一个配置类(配置类类似配置文件,区别在于用类的形式来表现xml;

@Service用于标注业务层组件service层,

@Controller用于标注控制层组件(如struts中的action) ,

@Repository用于标注数据访问组件,即DAO组件,

@component把普通pojo实例化到spring容器中,相当于配置文件中的 <bean id="" class=""/>

使用@Configuration会扫描以上四种注解声明的类。

@Bean在配置类中使用时,表示这是一个JavaBean。

例如:

//配置类 == 配置文件
@ComponentScan(value = "com.spring") // 告诉spring这个是一个配置类
})
public class MainConfig {

 // 注册一个bean,类型为返回值的类型,id默认用方法名
 @Bean
 public Person person1() {
 return new Person("张三", 20);
 }

  //可以为bean定义id
 @Bean("student")
 public Person person2() {
 return new Person("韩梅梅", 12);
 }

}

@ComponentSan value:指定要扫描的包
    excludeFilters = Filter[] :指定扫描的时候按照什么规则排除哪些组件
    includeFilters = Filter[] :指定扫描的时候只需要包含哪些组件
        FilterType.ANNOTATION:注解类型
        FilterType.ASSIGNABLE_TYPE:按照指定的类型,如指定BookService,会查找BookService本身,及其子类
        FilterType.ASPECTJ:使用ASPECTJ表达式,不经常使用
        FilterType.REGEX:使用正则表达式
        FilterType.CUSTOM:使用自定义表达式

@ComponentScan排除扫描类型

@ComponentScan(value = "com.spring", excludeFilters = {//排除指定的扫描类型
 //过滤注解类型  @Controller @Repository
 @Filter(type = FilterType.ANNOTATION, classes = { Controller.class,Repository.class })
})

@ComponentScan扫描指定类型

@ComponentScan(value = "com.spring", includeFilters = {//指定的扫描类型
 //过滤注解类型  @Controller @Repository
 @Filter(type = FilterType.ANNOTATION, classes = { Controller.class,Repository.class })
},useDefaultFilters = false)//注意,使用扫描指定类型时,需要配置useDefaultFilters = false 禁用默认规则

@ComponentScans可以理解为@ComponentScan数组,可以配置多个@ComponentScan

@ComponentScans(value= {
 @ComponentScan(value = "com.spring", includeFilters = {//指定的扫描类型
  //过滤注解类型  @Controller @Repository
  @Filter(type = FilterType.ANNOTATION, classes = { Controller.class,Repository.class }) ,
                //指定类型
  @Filter(type = FilterType.ASSIGNABLE_TYPE,classes = (BookService.class)),
                //自定义
  @Filter(type = FilterType.CUSTOM,classes = (MyTypeFilter.class))
 },useDefaultFilters = false)//注意,使用扫描指定类型时,需要配置useDefaultFilters = false 禁用默认规则
})

自定义包含规则

public class MyTypeFilter implements TypeFilter {

 /**
  * 返回true匹配成功,返回false匹配失败
 * metadataReader 读取到的当前正在扫描的类的信息
 * metadataReaderFactory 可以获取到其他任何类的信息
 */
 public boolean match(MetadataReader metadataReader, MetadataReaderFactory metadataReaderFactory)
  throws IOException {
 //获取当前类注解的信息
 AnnotationMetadata nnnotationmetadata = metadataReader.getAnnotationMetadata();
 //获取当前正在扫描的类的类信息
 ClassMetadata classMetadata = metadataReader.getClassMetadata();
 //获取当前类的资源信息(类的路径)
 Resource resource = metadataReader.getResource();

 String className = classMetadata.getClassName();
 System.out.println(">>>>"+className);
 if(className.contains("er")) {
  return true;
 }
 return false;
 }

}

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持我们。

(0)

相关推荐

  • SpringBoot初始教程之Servlet、Filter、Listener配置详解

    1.介绍 通过之前的文章来看,SpringBoot涵盖了很多配置,但是往往一些配置是采用原生的Servlet进行的,但是在SpringBoot中不需要配置web.xml的 因为有可能打包之后是一个jar包的形式,这种情况下如何解决?SpringBoot 提供了两种方案进行解决 2.快速开始 2.1 方案一 方案一采用原生Servlet3.0的注解进行配置.@WebServlet .@WebListener.@WebFilter是Servlet3.0 api中提供的注解 通过注解可以完全代替web

  • spring-boot实现增加自定义filter(新)

    前言 传统的javaEE增加Filter是在web.xml中配置,如以下代码: <filter> <filter-name>TestFilter</filter-name> <filter-class>com.cppba.filter.TestFilter</filter-class> </filter> <filter-mapping> <filter-name>TestFilter</filter-n

  • springboot中filter的用法详解

    一.在spring的应用中我们存在两种过滤的用法,一种是拦截器.另外一种当然是过滤器.我们这里介绍过滤器在springboot的用法,在springmvc中的用法基本上一样,只是配置上面有点区别. 二.filter功能,它使用户可以改变一个 request和修改一个response. Filter 不是一个servlet,它不能产生一个response,它能够在一个request到达servlet之前预处理request,也可以在离开 servlet时处理response.换种说法,filter

  • springboot使用filter获取自定义请求头的实现代码

    有个钱包项目,本来用的是微服务这一套,后来感觉没必要,重构成了简单的springboot项目,但是token校验重构完之后出问题了,之前写filter走的是springgateway,基于GatewayFilter实现,重构了之后基于filter,然后当请求进入过滤器的时候,发现不能获取到请求的自定义请求头. String token = request.getHeader("token"); // null String id = request.getHeader("id

  • 详解Spring Boot实战之Filter实现使用JWT进行接口认证

    本文介绍了spring Boot实战之Filter实现使用JWT进行接口认证,分享给大家 jwt(json web token) 用户发送按照约定,向服务端发送 Header.Payload 和 Signature,并包含认证信息(密码),验证通过后服务端返回一个token,之后用户使用该token作为登录凭证,适合于移动端和api jwt使用流程 本文示例接上面几篇文章中的代码进行编写,请阅读本文的同时可以参考前面几篇文章 1.添加依赖库jjwt,本文中构造jwt及解析jwt都使用了jjwt库

  • springboot扫描自定义的servlet和filter代码详解

    这几天使用spring boot编写公司一个应用,在编写了一个filter,用于指定编码的filter,如下: /** * Created by xiaxuan on 16/11/1. */ @WebFilter(urlPatterns = "/*",filterName="CharacterEncodeFilter", initParams={ @WebInitParam(name="encoding",value="UTF-8&qu

  • 详解spring security filter的工作原理

    这篇文章介绍filter的工作原理.配置方式为xml. Filter如何进入执行逻辑的 初始配置: <filter> <filter-name>springSecurityFilterChain</filter-name> <filter-class>org.springframework.web.filter.DelegatingFilterProxy</filter-class> </filter> <filter-mapp

  • spring boot 配置Filter过滤器的方法

    Filter 过滤器是web开发中很重要的一个组件,下面以一个session登陆的例子介绍下spring boot中如何使用Filter 首先要准备一个实现了Filter的接口的类 SessionFilter: import org.slf4j.LoggerFactory; import javax.servlet.*; import javax.servlet.http.HttpServletRequest; import javax.servlet.http.HttpServletRespo

  • JSP spring boot / cloud 使用filter防止XSS

    JSP spring boot / cloud 使用filter防止XSS 一.前言 XSS(跨站脚本攻击) 跨站脚本攻击(Cross Site Scripting),为不和层叠样式表(Cascading Style Sheets, CSS)的缩写混淆,故将跨站脚本攻击缩写为XSS.恶意攻击者往Web页面里插入恶意Script代码,当用户浏览该页之时,嵌入其中Web里面的Script代码会被执行,从而达到恶意攻击用户的目的. 二.思路 基于filter拦截,将特殊字符替换为html转意字符 (如

  • Spring Boot的filter(过滤器)简单使用实例详解

    过滤器(Filter)的注册方法和 Servlet 一样,有两种方式:代码注册或者注解注册 1.代码注册方式 通过代码方式注入过滤器 @Bean public FilterRegistrationBean indexFilterRegistration() { FilterRegistrationBean registration = new FilterRegistrationBean(new IndexFilter()); registration.addUrlPatterns("/&quo

  • Spring Boot 编写Servlet、Filter、Listener、Interceptor的方法

    前言 在编写过滤器.监听器.拦截器之前我们需要在spring-boot启动的类上加上注解@ServletComponentScan: @SpringBootApplication @ServletComponentScan public class MySpringbootApplication { public static void main(String[] args) { SpringApplication.run(MySpringbootApplication.class, args)

随机推荐