8、使用注解开发
在Spring4之后,要使用注解开发,必须要保证aop的包导入了
使用注解需要导入context约束,增加注解的支持
1. 导入约束 xmlns:context="http://www.springframework.org/schema/context"
2. 配置注解的支持 <context:annotation-config/>
<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xmlns:context="http://www.springframework.org/schema/context"
xsi:schemaLocation="http://www.springframework.org/schema/beans
https://www.springframework.org/schema/beans/spring-beans.xsd
http://www.springframework.org/schema/context
https://www.springframework.org/schema/context/spring-context.xsd">
<!--开启注解的支持-->
<context:annotation-config/>
<!--指定要扫描的包,这个包下的组件注解就会生效-->
<context:component-scan base-package="com.chif.pojo"/>
<!--
<bean id="user" class="com.chif.pojo.User"/>
-->
</beans>
-
bean
@component (把普通pojo实例化到spring容器中,相当于配置文件中的<bean id="" class=""/>) @Component,@Service,@Controller,@Repository注解的类,并把这些类纳入进spring容器中管理。 下面写这个是引入component的扫描组件 <context:component-scan base-package=”com.mmnc”>
-
属性如何注入
package com.chif.pojo;
import org.springframework.beans.factory.annotation.Value;
public class User {
public String name;
@Value("chif2")
//相当于 <property name="name" value="chif"/>
//可以放在属性上,也可以放在set方法上
public void setName(String name) {
this.name = name;
}
}
3.衍生的注解
@Component 有几个衍生注解,我们在web开发中,会按照mvc三层架构分层!
- dao【@Respository】
- service【@Service】
- Conrtroller【@Conrtroller】
这四个功能注解都是一样的,都是代表将某个类注册到Spring容器中装配。
4.自动装配
- @Autowired:自动装配通过类型,名字
如果Autowired不能唯一自动装配上属性,则需要通过@Qualifer(value="xxx")配合使用
- @Nullable : 字段标记了这个注解,说明这个字段可以为null
- @Resource:自动装配通过名字,类型
5.作用域
@Scope("singleton")
@Scope("prototype")
6.小结
xml与注解:
- xml更加万能,适用于任何场合!维护简单方便
- 注解不是自己的类使用不了,维护相对复杂!
xml与注解最佳实践方式:
- xml用来管理bean
- 注解只负责属性的注入
- 我们在使用的过程中,只需要注意一个问题:必须让注解生效,就需要开启注解的支持!
<!--开启注解的支持-->
<context:annotation-config/>
<!--指定要扫描的包,这个包下的组件注解就会生效-->
<context:component-scan base-package="com.chif.pojo"/>