Spring@Resource注解
@Resource和@Autowired注解都是⽤来实现依赖注⼊的。只是@AutoWried按by type⾃动注⼊,⽽@Resource默认按byName⾃动注⼊即直接根绝bean的ID进⾏注⼊。
@Resource有两个重要属性,分别是name和type
spring将name属性解析为bean的名字,⽽type属性则被解析为bean的类型。所以如果使⽤name属性,则使⽤byName的⾃动注⼊策略,如果使⽤type属性则使⽤byType的⾃动注⼊策略。如果都没有指定,则通过反射机制使⽤byName⾃动注⼊策略。
@Resource依赖注⼊时查bean的规则:(以⽤在field上为例)
1. 既不指定name属性,也不指定type属性,则⾃动按byName⽅式进⾏查。如果没有到符合的bean,则回退为⼀个原始类型进⾏查,如果到就注⼊。
此时name是变量名
错误⽰例:
@Resource
private String bucketName;
@Resource
private String styleName;
此时的name值是配置bean⾥的name属性指定的值,⽽不是id的值
resource和autowired注解的区别<bean id="bucketName " class="java.lang.String">
<constructor-arg value="${oos.bucketName}"/>
</bean>
<!-- 图⽚样式名 -->
<bean id="styleName " class="java.lang.String">
<constructor-arg value="${oos.styleName}"/>
</bean>
这⾥为什么要重新理解,是因为之前我⼀直认为对应的是配置⽂件的id属性的值,直到在配置上⾯两个String类型的bean的时候,居然会报错,如下: No qualifying bean of type [java.lang.String] is defined: expected single matching bean but found 2: bucketName,styleName 这是因为spring会去bean元素⾥name属性值和变量名⼀致的bean,但是因为都没有指定name属性,所以不到然后就按照原始类型String去查,结果⼀下到了两个,所以就报错。
2. 只是指定了@Resource注解的name,则按name后的名字去bean元素⾥查有与之相等的name属性的bean。
正确⽰例
@Resource(name="bucket")
private String bucketName;
@Resource(name="style")
private String styleName;
<bean name="bucket" class="java.lang.String">
<constructor-arg value="${oos.bucketName}"/>
</bean>
<!-- 图⽚样式名 -->
<bean name="style" class="java.lang.String">
<constructor-arg value="${oos.styleName}"/>
</bean>
3. 只指定@Resource注解的type属性,则从上下⽂中到类型匹配的唯⼀bean进⾏装配,不到或者到多个,都会抛出异常
4. 既指定了@Resource的name属性⼜指定了type,则从Spring上下⽂中到唯⼀匹配的bean进⾏装配,不到则抛出异常

版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。