自动装配注解

Spring利用依赖注入(DI),完成对IOC容器中中各个组件的依赖关系赋值

@Autowired

@Autowired自动注入
1)、默认优先按照类型去容器中找对应的组件:applicationContext.getBean(BookDao.class);找到就赋值
2)、如果找到多个相同类型的组件,再将属性的名称作为组件的id去容器中查找applicationContext.getBean("bookDao")
3)、@Qualifier("bookDao"):使用@Qualifier指定需要装配的组件的id,而不是使用属性名
4)、自动装配默认一定要将属性赋值好,没有就会报错;可以使用@Autowired(required=false);
5)、@Primary:让Spring进行自动装配的时候,默认使用首选的bean;@Primary添加到bean上,指定为首选
也可以继续使用@Qualifier指定需要装配的bean的名字,@Qualifier优先级更高一点
BookService{
    @Autowired
    BookDao  bookDao;
}

@Resource @Inject

Spring还支持使用@Resource(JSR250)和@Inject(JSR330)[java规范的注解]
@Resource:可以和@Autowired一样实现自动装配功能;默认是按照组件名称进行装配的;name=指定名称没有能支持@Primary功能没有支持@Autowired(reqiured=false);
@Inject:需要导入javax.inject的包,和Autowired的功能一样。没有required=false的功能;
@Autowired:Spring定义的; @Resource、@Inject都是java规范

Autowired

@Autowired:构造器,参数,方法,属性;都是从容器中获取参数组件的值
 1)、[标注在方法位置]

@Autowired 
//标注在方法,Spring容器创建当前对象,就会调用方法,完成赋值;
//方法使用的参数,自定义类型的值从ioc容器中获取
public void setCar(Car car) {
	this.car = car;
}

@Bean标注的方法创建对象的时候,方法参数的值从容器中获取 ,默认不写@Autowired效果是一样的

@Bean
public Color color(@Autowired Car car) {
	Color color = new Color();
	color.setCar(car);
	return color;
}

 

2)、[标在构造器上]:如果组件只有一个有参构造器,这个有参构造器的@Autowired可以省略,参数位置的组件还是可以自动从容器中获取

//构造器要用的组件,都是从容器中获取,一个构造器这里可以省略
public Boss(@Autowired Car car) {
	this.car = car;
	System.out.println("Boss...有参构造器");
}

测试类

@Test
public void test01() {
	AnnotationConfigApplicationContext applicationContext = new AnnotationConfigApplicationContext(MainConifgOfAutowired.class);
	Boss boss = applicationContext.getBean(Boss.class);
	System.out.println(boss);
	Car car = applicationContext.getBean(Car.class);
	System.out.println(car);
	applicationContext.close();
}

运行结果

spring authorization server 接口权限管理_AutoWired

3)、[放在参数位置]

 

Aware接口原理

自定义组件想要使用Spring容器底层的一些组件(ApplicationContext,BeanFactory,xxx)

自定义组件实现xxxAware;在创建对象的时候,会调用接口规定的方法注入相关组件;Aware;
把Spring底层一些组件注入到自定义的Bean中;
xxxAware:功能使用xxxProcessor;
ApplicationContextAware==》ApplicationContextAwareProcessor;
@Component
public class Red implements ApplicationContextAware, BeanNameAware, EmbeddedValueResolverAware {
	private ApplicationContext applicationContext;
	@Override
	public void setApplicationContext(ApplicationContext applicationContext) throws BeansException {
		System.out.println("传入的ioc:" + applicationContext);
		this.applicationContext = applicationContext;
	}
	@Override
	public void setBeanName(String name) {
		System.out.println("当前bean的名字:" + name);
	}
	@Override
	public void setEmbeddedValueResolver(StringValueResolver resolver) {
		String resolveStringValue = resolver.resolveStringValue("你好 ${os.name} 我是 #{20*18}");
		System.out.println("解析的字符串:" + resolveStringValue);
	}
}

测试类

@Test
public void test01() {
	AnnotationConfigApplicationContext applicationContext = new AnnotationConfigApplicationContext(MainConifgOfAutowired.class);
	System.out.println(applicationContext);
	applicationContext.close();
}

spring authorization server 接口权限管理_AutoWired_02

 

在这边打个断点

spring authorization server 接口权限管理_赋值_03

debug启动

可以看到进入在set前进入两个方法

spring authorization server 接口权限管理_赋值_04

spring authorization server 接口权限管理_System_05

spring authorization server 接口权限管理_构造器_06

bean在初始化的时候调用后置处理器判断这个接口,然后将applicationContext注入到bean中