8、Spring5-IOC容器-Bean管理-注解方式
基于注解方式实现对象创建和注入属性等操作
1、什么是注解
(1)注解是代码特殊标记,格式:@注解名称(属性名称=属性值,属性名称=属性值...)
(2)使用注解,注解作用在类上面、方法上面、属性上面
(3)使用注解的目的:为了简化xml配置,把配置使用更优雅、更简洁的方式实现
2、Spring针对Bean管理中创建对象提供了注解
创建对象常用的注解:
(1)@Component
(2)@Service
(3)@Controller
(4)@Repository
上面的四个注解功能是一样的,都可以用来创建bean的实例,但是一般情况下,将每个注解用在不同的层中
3、基于注解方式实现对象创建
第一步:引入依赖 spirng-aop.jar
第二步:开启组件扫描,只有开启扫描,Spring才能找到注解,如果不开启,spring就不知道注解的部分
<?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:p="http://www.springframework.org/schema/p" xmlns:context="http://www.springframework.org/schema/context" xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans.xsd http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context.xsd"> <!--开启组件扫描 1、如果扫描多个包,多个包使用都好隔开 2、如果都在一个目录下,只需扫描包的上层目录 --> <context:component-scan base-package="com.spring5.dao,com.spring5.service"></context:component-scan> </beans>
第三步:创建类,在类上面添加创建对象的注解
//在注解里的value属性值可以省略不写,默认值是类的名称,首字母小写 //@Component(value = "userService") //相当于<bean id="userService" class="com.spring5.service"> @Service public class UserService { public void add(){ System.out.println("Service add....."); } }
测试如下:
@Test public void test1(){ ApplicationContext context = new ClassPathXmlApplicationContext("bean1.xml"); UserService userService = context.getBean("userService", UserService.class); System.out.println(userService); userService.add(); }
4、开启组件扫描细节配置
<!--实例1 use-default-filters="false" : 表示现在不使用默认的filter,而是使用自己配置的filter context:include-filter : 设置扫描哪些内容 下面的配置意思是扫秒在com.spring5包下所有带了注解Controller的类,别的不会扫描 --> <context:component-scan base-package="com.spring5" use-default-filters="false"> <context:include-filter type="annotation" expression="org.springframework.stereotype.Controller"/> </context:component-scan>
<!--实例2 下面的配置是扫描包下的所有内容 context:exclude-filter :设置哪些内容不进行扫描 下面配置的意思是扫描com.spring5包中所有的内容除了包含Controller注解的类 --> <context:component-scan base-package="com.spring5"> <context:exclude-filter type="annotation" expression="org.springframework.stereotype.Controller"/> </context:component-scan>
5、基于注解方式实现属性的注入
注入属性常用的注解:
(1)@Autowired 根据属性类型进行自动装配(注入)
演示步骤
第一步:把 service 和 dao 对象创建,在 service 和 dao 类中添加创建对象的注解
//UserDao 接口 public interface UserDao { public void add(); } //这里是 UserDao 的实现类,并创建一个 userDaoImpl1 对象 @Repository(value = "userDaoImpl1") public class UserDaoImpl implements UserDao{ @Override public void add() { System.out.println("dao add...."); } }
第二步:service 中注入 dao 对象,在 service 中定义 dao 类型的属性,在 属性上面使用注解
@Service //创建 UserService 对象 public class UserService { //定义 dao 类型的属性 //不需要添加 set 方法,因为注解已经帮我们封装了,直接写个属性即可 @Autowired //根据类型进行注入(注:该类型的对象只能存在一个) private UserDao userDao; public void add(){ System.out.println("Service add....."); userDao.add(); //调用userDaoImpl中的方法 } }
(2)@Qualified 根据属性的名称进行注入
这个@Qualified 注解的使用,要和上面的@Autowired 进行使用
@Service public class UserService { //定义dao类型的属性 //不需要添加set方法,因为注解已经帮我们封装了,直接写个属性即可 @Autowired //根据类型进行注入 @Qualifier(value = "userDaoImpl1") //根据类型进行注入虽然方便,但是该类型若有多个实现类,就不能确定需要是哪个对象,根据名称可以定位到某个对象的名称 private UserDao userDao; public void add(){ System.out.println("Service add....."); userDao.add(); } }
这里的@AutoWired 和 @Qualified 连用可以精确到创建的对象的名称,而这种类型的对象可以存在多个,若使用类型进行注入,这种对象只能存在一个
(3)@Resource 可以根据类型注入,也可以根据名称注入
@Service public class UserService { // @Resource //根据类型进行注入 @Resource(name = "userDaoImpl1") //根据名称进行注入 private UserDao userDao; public void add(){ System.out.println("Service add....."); userDao.add(); } }
@Resouce 是javax扩展包中的注解,所以Spring官方建议我们使用 @Autowired 和 @Qualified ,但是功能可以做到
(4)@value 注入普通类型属性
@Value(value = "abc") private String name;
6、完全注解开发
(1)创建配置类,用于替代 Spring 的 xml 配置文,将配置文件中的内容放到配置类中,使用注解实现
@Configuration //表示当前类当作一个配置类,用于替代xml配置文件 @ComponentScan(basePackages = {"com.spring5"}) //与<context:component-scan base-package="com.spring5"></context:component-scan>等价 public class SpringConfig { }
(2)编写测试类
@Test public void test2(){ //加载配置类 ApplicationContext context = new AnnotationConfigApplicationContext(SpringConfig.class); UserService userService = context.getBean("userService", UserService.class); System.out.println(userService); userService.add(); }