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;
}
}
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。
相关文章
SpringDataJpa的使用之一对一、一对多、多对多 关系映射问题
这篇文章主要介绍了SpringDataJpa的使用 -- 一对一、一对多、多对多关系映射,本文主要讲述 @OneToOne、@OneToMany、@ManyToOne、@ManyToMany 这四个关系映射注解的使用,以及其对应的级联关系,需要的朋友可以参考下2022-07-07
java 重载(overload)与重写(override)详解及实例
这篇文章主要介绍了java 重载(overload)与重写(override)详解及实例的相关资料,并附实例代码,需要的朋友可以参考下2016-10-10
责任链模式在spring security过滤器链中的应用小结
责任链模式在SpringSecurity过滤器链中的应用,通过一系列的过滤器按顺序处理请求,每个过滤器负责特定的安全功能,实现灵活且可扩展的请求处理机制,感兴趣的朋友跟随小编一起看看吧2024-11-11
Java Redis Template批量查询指定键值对的实现
本文主要介绍了Java Redis Template批量查询指定键值对的实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧2022-07-07


最新评论