时间:2021-05-20
组件注册
用@Bean来注册
搭建好maven web工程
pom加入spring-context,spring-core等核心依赖
创建实例类com.hjj.bean.Person, 生成getter,setter方法
public class Person { private String name; private int age;}创建com.hjj.config.MainConfig
@Configuration //告诉spring是一个配置类public class MainConfig { // 给容器中注册一个Bean,类行为返回值的类型,id默认是用方法名作为id @Bean("mikePerson") public Person person(){ return new Person("mike",20); }}主测试类
public class MainTest { public static void main(String[] args) { AnnotationConfigApplicationContext applicationContext = new AnnotationConfigApplicationContext(MainConfig.class); Person bean = applicationContext.getBean(Person.class); System.out.println(bean); String[] beanNamesForType = applicationContext.getBeanNamesForType(Person.class); for (String type : beanNamesForType) { System.out.println(type); //配置类中的方法名,注意:通过修改配置类的@bean value也可以修改 } }}@ComponentScan包扫描
配置类中MainConfig.java
@Configuration //告诉spring是一个配置类@ComponentScan("com.hjj") // 扫描包的路径public class MainConfig { // 给容器中注册一个Bean,类行为返回值的类型,id默认是用方法名作为id @Bean("mikePerson") public Person person(){ return new Person("mike",20); }}新建测试的com.hjj.controller,service,dao
@Controllerpublic class BookController {}@Repositorypublic class BookDao {}@Servicepublic class BookService {}单元测试
@Test public void test01(){ AnnotationConfigApplicationContext applicationContext = new AnnotationConfigApplicationContext(MainConfig.class); String[] beanDefinitionNames = applicationContext.getBeanDefinitionNames(); //获取所有组件 for (String beanDefinitionName : beanDefinitionNames) { System.out.println(beanDefinitionName); } }ComponentScan字段,有includeFilter(),和excludeFilter() 只包含或排除某些组件
@ComponentScan(value = "com.hjj",excludeFilters={@Filter(type=FilterType.ANNOTATION,classes={Controller.class,Service.class})})
@ComponentScan(value = "com.hjj",includeFilters={@Filter(type=FilterType.ANNOTATION,classes={Controller.class,Service.class})},userDefaultFilters=false)
// excludeFilter源码
ComponentScan.Filter[] excludeFilters() default {};
@ComponentScan被@Repeatable(ComponentScans.class),可以重复写,用来写不同的执行策略。
@ComponentScans 里面可以放ComponentScan类型的值
@Retention(RetentionPolicy.RUNTIME)@Target({ElementType.TYPE})@Documentedpublic @interface ComponentScans { ComponentScan[] value();}FilterType
public enum FilterType { ANNOTATION, // 按注解扫描 ASSIGNABLE_TYPE, // 按给定的类型 ASPECTJ, // 可以用aspectJ表达式 REGEX, // 正则表达式 CUSTOM; // 自定义规则 private FilterType() { }}ASSIGNABLE_TYPE
@ComponentScan(value = "com.hjj",includeFilters ={@ComponentScan.Filter(type=FilterType.ASSIGNABLE_TYPE,classes = {BookService.class})})// config配置如上注解后 bookservice,可以被发现 @Test public void demoTest1(){ AnnotationConfigApplicationContext applicationContext = new AnnotationConfigApplicationContext(MainConfig.class); String[] beanDefinitionNames = applicationContext.getBeanDefinitionNames(); for (String beanDefinitionName : beanDefinitionNames) { System.out.println(beanDefinitionName); } }Custom 可以自定义配置或写业务扫描类的信息,match返回true则是加到组件
1.复写TypeFilter的match方法
public class MyTypeFilter implements TypeFilter { /** * * @param metadataReader 读取到的当前正在扫描的类的信息 * @param metadataReaderFactory 可以获取到其他任何类信息 * @return * @throws IOException */ @Override public boolean match(MetadataReader metadataReader, MetadataReaderFactory metadataReaderFactory) throws IOException { // 获取当前类注解的信息 AnnotationMetadata annotationMetadata = metadataReader.getAnnotationMetadata(); // 获取当前正在扫描类的信息 ClassMetadata classMetadata = metadataReader.getClassMetadata(); // 获取当前类资源(类的路径等) Resource resource = metadataReader.getResource(); String className = classMetadata.getClassName(); System.out.println("className:" + className); return false; }}2. 加上注解
@Configuration //告诉spring是一个配置类@ComponentScan(value = "com.hjj",includeFilters ={ @ComponentScan.Filter(type=FilterType.CUSTOM,classes = {MyTypeFilter.class})}, useDefaultFilter=false)public class MainConfig {}@Testpublic void test01(){AnnotationConfigApplicationContext applicationContext = new AnnotationConfigApplicationContext(MainConfig.class);String[] beanDefinitionNames = applicationContext.getBeanDefinitionNames();for (String beanDefinitionName : beanDefinitionNames) {System.out.println(beanDefinitionName);}}结果
className:com.hjj.test.IOCTestclassName:com.hjj.MainTestclassName:com.hjj.bean.PersonclassName:com.hjj.config.MyTypeFilterclassName:com.hjj.demo.DemoTestclassName:com.hjj.demo.EmployeeclassName:com.hjj.demo.Managerorg.springframework.context.annotation.internalConfigurationAnnotationProcessororg.springframework.context.annotation.internalAutowiredAnnotationProcessororg.springframework.context.annotation.internalCommonAnnotationProcessororg.springframework.context.event.internalEventListenerProcessororg.springframework.context.event.internalEventListenerFactorymainConfig以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
我们不妨先将spring常用的注解按照功能进行分类1、将普通类加入容器形成Bean的注解日常开发中主要使用到的定义Bean的注解包括(XML方式配置bean暂不
springboot常用注解如下: 1、ComponentScan。自动扫描组件,可自动发现和装配一些Bean。 2、Configuration。用于定制配
问题在使用springboot开发项目过程中,有些时候可能出现说会有在spring容器加载前就需要注入bean的类,这个时候如果直接使用@Autowire注解,
一前言本篇内容主要是讲解2个重要的注解使用方式和场景,@Primary,@Qualifier注解;其作用就是消除bean注入时的歧义,能够让spring容器知道
前言@Resource和@Autowired都是做bean的注入时使用,其实@Resource并不是Spring的注解,它的包是javax.annotation