曾经XML的配置:
<bean id="accountService" class="com.itheima.service.impl.AccountServiceImpl" scope="" init-method-m="" destroyethod=""> <property name="" value="" | ref=""></property> </bean>
首先告知spring在创建容器时要扫描的包
首先要告知spring在创建容器时要扫描的包,配置所需要的标签不是在beans的约束中,而是一个名称为context名称空间和约束中,所以我们所有的事情都是要先扫描到才能使用注解进行开发这个是前提,而contrext的头约束和之前的不一样,在core里面搜索后得到如下的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>
Spring注解分四类下面依次介绍
第一类 用于创建对象的
作用和在xml配置文件中编写一个bean标签一样的
相当于: <bean id="" class="">
@Component介绍
作用:用于把当前类对象存入spring容器中
属性:
value:用于指定bean的id。当我们不写时,它的默认值是当前类的首字母改小写,写的话就指定为为自己写的值。**
举例如下
第一步搭建好环境后用@Component注解配置UserService
代码如下:
package Service.IMPL; import Dao.IMPL.UserDao; import Dao.IUserDao; import Service.IUserService; import org.springframework.stereotype.Component; @Component(value = "userService") public class UserService implements IUserService { //private将这个对象私有化 //因为dao是一个接口的实现类 接口是不是实例化的 但是可以创建一个接口的实现类对象 private IUserDao dao=new UserDao(); // private IUserDao dao= (IUserDao) BeanFactory.getBean("UserDao"); public void save() { dao.save(); }
第二步在bean.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/> <context:component-scan base-package="Service"></context:component-scan> </beans>
测试结果运行成功
那么我们使用注解创建对象的方式就成功了,成功的创建了userService对象,比我们之前的操作更加便捷一点
另外Spring中还提供了下面三个注解
@Controller:一般用在表现层
@Service:一般用在业务层
@Repository:一般用在持久层
以上三个注解他们的作用和属性与Component是一模一样。
他们三个是spring框架为我们提供明确的三层使用的注解,使我们的三层对象更加清晰
细节:如果注解中有且只有一个属性要赋值时,且名称是 value, value 在赋值是可以不写。就是可以直接写个@Component(“userService”)而不是@Component(value = “userService”)
第二类 用于注入数据的注解,就是可以实现在service中注入一个dao这样的操作
他们的作用就和在xml配置文件中的bean标签中写一个property标签的作用是一样的,就是在一个类中注入另外一个类
相当于: <property name="" ref=""> <property name="" value="">
@Autowired详解
作用:自动按照类型注入。只要容器中有唯一的一个bean对象类型和要注入的变量类型匹配,就可以注入成功
出现位置:
可以是变量上,也可以是方法上
细节:
在使用注解注入时,set方法就不是必须的了。
注意下面
因为spring中ioc其实就是map容器,然后里面放着要注入的对象,
所以当代码中只有一个accountDao时我们就可以直接通过数据类型找到,当里面两个这样类型时,我们就会通过数据类型后面的变量名称来进行匹配进而完成一个注入。但是如果变量名称也不相等那么就是报错。
@Qualifier注解
作用:在按照类中注入的基础之上再按照名称注入。它在给类成员注入时不能单独使用。
上面出现的多个Bean对象解决问题可以用这个注解解决,但是必须和@Autowired注解一起使用。如下:
//自动注入 @Autowired @Qualifier("userDao1") private IUserDao userDao;
这样就解决了上面出现两个之后如何区分的问题
@Resource 注解
这个不用配合@Autowired注解,可以直接解决上面出现两个Bean对象数据类型一样的注入问题
@Resource(name = "accountDao2")
作用:直接按照bean的id注入。它可以独立使用
属性:
name:用于指定bean的id。
以上三个注解都是只能注入其他Bean类型的数据,而基本类型和String类型无法使用上述注解实现,另外,集合类型的注入只能通过XML来实现。
@Value
作用:用于注入基本类型和String类型的数据
属性:
value:用于指定数据的值。它可以使用spring中SpEL(也就是spring的el表达式)
SpEL的写法:${表达式}
第三类 用于改变作用范围的:
作用就和在xml中使用scope属性是一样的
相当于: <bean id="" class="" scope=""
@Scope
作用:
指定 bean 的作用范围。
属性:
value:指定范围的值。
取值: singleton, prototype, request, session, global session
@Service("userService") @Scope("singleton ") public class UserService implements IUserService {
第四类 和生命周期相关的
作用和在bean标签中使用init-method和destory-method的作用一样的
相当于: <bean id="" class="" init-method="" destroy-method="" />
@PostConstruct
作用:
value:用于指定初始化方法。
@PreDestroy
作用:
value:用于指定销毁方法
注意如果不用自己的实现的方法而用接口可能使用不了方法,这时我们要把返回值类型改成实现类类型。