曾经的XML配置:
<bean id="accountService" class="com.itheima.service.impl.AccountServiceImpl" scope="" init-method="" destroy-method=""> <property name="" value="" | ref=""></property> </bean>
如果使用注解, 但没有导入以下jar包
或者在xml配置文件中没有配置以下内容(特别注意,头配置也有改动) 时, 无法成功创建bean
<!--告知spring在创建容器时要扫描的包,配置所需要的标签不是在beans的约束中,而是一个名称为
context名称空间和约束中-->
<context:component-scan base-package="com.itheima"></context:component-scan>
注解:
1. 用于创建对象的
它们的作用就和在xml配置文件中编写一个<bean>标签实现的功能是一样的
@Component :
作用: 用于把当前类对象存入Spring容器中
属性:
value: 用于指定bean的id . 当我们不写时,他的默认值是当前类名,且首字母改小写
@Component(value="accountService") 如果value只有一个 可以写成@Component("accountService")
@Controller 一般用于表现层
@Service 一般用于业务层
@Repository 一般用于持久层
以上三个注解的作用与Component是一摸一样的.
他们三个是spring框架为我们提供明确的三层使用的注解,使我们的三层对象更加清晰
2. 用于注入数据的
它们的作用就和在xml配置文件中编写一个<property>标签实现的功能是一样的
@Autowired
作用: 自动按照类型注入. 只要容器中有唯一的一个bean对象类型和要注入的变量类型匹配, 就可以注入成功
如果ioc容器中没有任何bean的类型和要注入的变量类型匹配,则报错。
如果Ioc容器中有多个类型匹配时:
先按照类型圈定出来匹配的范围
接下来会使用变量名称作为bean的id在圈定出来的范围中继续查找,
如果有匹配的,则注入成功, 如果都不一样,就报错
出现位置: 可以是变量上,也可以是方法上
细节: 在使用注解注入时,set方法就不是必须的了 自动按照类型(或某类实现的接口类型)进行匹配
@Qualifier
作用: 在按照类型注入的基础之上 再按照名称注入.
它在给类成员注入时不能单独使用,
但是在给方法参数注入时可以单独使用
属性: value:用于指定注入bean的id
在给类成员注入时不能单独使用, 必须和Autowired配合使用
@Resource
作用: 直接按照bean的id注入. 它可以独立使用
属性: name 用于指定beanid
=====以上三个注入都只能注入其他bean类型的数据,=====
=====而基本类型和String类型无法使用上述注解实现=====
@Value
作用: 用于注入基本类型和String类型的数据
属性: value: 用于指定数据的值. 它可以使用Spring中的SpEL(Spring的EL表达式)
SqEL的写法: ${表达式}
3. 用于改变作用范围的
它们的作用就和在bean标签中使用scope属性实现的功能是一样的
@Scope
作用: 用于指定bean的作用范围
属性: value: 指定范围的取值. 常用的两个singleton prototype 默认单例
4. 和生命周期相关
它们的作用就和在bean标签中使用init-method和destroy-methode的作用是一样的
@PreDestroy
作用: 用于指定销毁方法
@PreConstruct
作用: 用于指定初始化方法