欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页

基于注解的SpringIoc配置

程序员文章站 2022-03-05 15:21:54
...

2.4 基于注解的Ioc配置

xml与注解的对应

基于注解的SpringIoc配置

使用注解开发时,bean.xml中的约束与xml配置不同,以下为约束

<?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
        http://www.springframework.org/schema/beans/spring-beans.xsd
        http://www.springframework.org/schema/context
        http://www.springframework.org/schema/context/spring-context.xsd">

    <context:annotation-config/>
</beans>

与XML配置功能相对应的注解

  • 用于创建对象的
		@Component:
/**	
			作用:用于把当前类对象存入spring容器中
			属性:
				value:用于指定bean的id。当我们不写时
					   它的默认值是当前类名,且首字母改
                       小写
*/		
	// 这里另外介绍3个与Component作用和属性一摸一样的注解
		@Controller:一般用在表现层
		@Service:一般用在业务层
		@Repository:一般用在持久层
		以上三个注解他们的作用和属性与Component是一摸一样。
		他们三个是spring框架为我们提供明确的三层使用的注解
		,使我们的三层对象更加清晰

对应的xml配置(忽略约束)

<!-- 告知spring在创建容器时要扫描的包,配置所需要的标签
	 不是在beans的约束中,而是一个名称为context名称空
	 间和约束中 -->
	<context:component-scan base-package="com"></context:component-scan>
  • 用于注入数据的
		@Autowired:
/**	
			作用:自动按照类型注入。只要容器中有唯一的一个bean对象类型和
				 要注入的变量类型匹配,就可以注入成功。
				 如果Ioc容器中没有任何bean的类型和要注入的变量类型匹配,
				 则报错。
		    出现位置:(可注解位置)
				 可以是变量上,也可以是方法上
			细节:
				 在使用注解注入时,set方法就不是必须的了。
*/		
		@Qualifier:
		(基于@Autowired注解)
/**	
			作用:在按照类中注入的基础之上再按照名称注入。它在给类成员注入
				 注入时不能单独使用。但是在给方法参数注入时可以
		    出现位置:
		    	 基于@Autowired注解	
			属性:
				 value:用于指定注入bean的id
			单独使用的特殊情况:
				 当容器中含有两个或以上相同的类且bean的id名不同时,可以
				 在方法中配置@Qualifier注解,如下图
*/	

基于注解的SpringIoc配置

		@Resource
/**	
			作用:直接按照bean的id注入。它可以独立使用
			属性:
				 name:用于指定bean的id
*/	

以上三个注入都只能注入其他bean类型的数据,而基本类型和String类型无法使用上述注解实现
另外,集合类型的注入只能通过XML来实现,于是下面的要讲的Value注解可以实现基本类型和
String类型数据的注入

		@Value
/**	
			作用:用于注入基本类型和String类型的数据
			属性:
				 value:用于指定数据的值。它可以使用
						spring中的SpEL(spring的el表达式)
						SpEL的写法:${表达式}
*/	
  • 用于改变作用范围的
		@Scope
/**	
			作用:用于指定bean的作用范围
			属性:
				 value:指定范围的取值。(默认单例)
				 常用取值:singleton、prototype
*/	
  • 和生命周期相关的(了解即可)
		@PreDestory
			// 作用:用于指定销毁方法
		@PostConstruct
			// 作用:用于指定初始化方法

取代xml配置文件的注解类

如果不想使用xml配置文件,spring也可以允许你创建一个配置类来配置Ioc容器

		@Configuration
			/** 作用:指定当前类是一个配置类
			 细节:当配置类作为AnnotationConfigApplicationContext对象
					创建的参数时,该注解可以不写
			*/
		@ComponentScan
			/** 作用:用于通过注解指定spring在创建容器时要扫描的包
			    属性:
					 value:它和basePackages的作用是一样的,都是用于
							指定创建容器时要扫描的包,等同于xml中配置了
<context:component-scan base-package=""></context:component-scan>
			*/
		@Import
			/** 作用:用于导入其他的配置类
				属性:
					 value:用于指定其他配置类的字节码文件
					 	 	当我们使用Import的注解之后,有Import注解的
							类可视为父配置类,而导入的都是子配置类
			*/
		@PropertySource
			/** 作用:用于指定properties文件的位置
				属性:
					 value:指定文件的名称和路径。
						    关键字:classpath,表示类路径下
			*/

将类对象加入Ioc容器的注解

		@Bean
			/** 作用:用于把当前方法的返回值作为bean对象存入spring的ioc容器中
			    属性:
					 name:用于指定bean的id。当不写时,默认值时当前方法的名称
				细节:
					 当我们使用注解配置方法时,如果方法有参数,spring框架会去
					 容器中查找有没有可用的bean对象。
					 查找的方式和Autowired注解的作用是一样的
			*/

创建Ioc容器对象时,我们不能再使用之前的
ApplicationContext ac = new ClassPathXmlApplicationContext(“beam.xml”);
新的创建对象的方式见下方代码块

// 获取容器
ApplicationContext ac = new AnnotationConfigApplicationContext(SpringConfiguration.class);

小贴士:
通过实际操作我们可以发现,注解Ioc配置并没有比配置xml文件更简单
因此我们在实际开发中,如果不是企业硬性要求,我们使用注解或xml的
原则是怎么简单怎么来
当我们需要导入容器的类在jar包中时
使用xml配置显然更简单
当我们自己写的类要导入容器时
使用注解显然更简单

Spring整合Junit

基于注解的SpringIoc配置基于注解的SpringIoc配置