一、什么是注解
- 注解是代码特殊标记,格式为
@注解名称(属性名称=属性值, 属性名称=属性值..)
。 - 使用注解目的是为了简化
xml
配置。 - 注解可以作用在类、方法、属性。
二、创建对象的注解
@Component
@Service
@Controller
@Repository
四个注解功能都是一样的,都是用来创建bean
实例对象,但是@Controller
一般用在Web层,@Service
一般用在Service层,@Repository
一般用在Dao层。
三、基于注解方式实现对象创建
引入依赖并开启组件扫描
<?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">
<!--开启组件扫描-->
<context:component-scan base-package="service,dao"></context:component-scan>
</beans>
创建类,在类上面添加创建对象注解
//在注解里面 value 属性值可以省略不写,默认值是类名称首字母小写
@Service(value = "userService")
public class UserService {
public void add(){
System.out.println("UserService的add()方法");
}
}
测试
@Test
public void testService(){
//1.加载Spring配置文件
ApplicationContext context = new ClassPathXmlApplicationContext("annotation.xml");
//2.获取配置创建的对象
UserService userService = context.getBean("userService", UserService.class);
userService.add();
}
开启组件扫描细节配置
<!--use-default-filters="false" 表示现在不使用默认 filter,自己配置 filter
context:include-filter ,设置扫描哪些内容
-->
<context:component-scan base-package="service,dao" use-default-filters="false">
<context:include-filter type="annotation" expression="org.springframework.stereotype.Service"/>
</context:component-scan>
<context:component-scan base-package="service,dao" use-default-filters="false">
<!--context:exclude-filter: 设置哪些内容不进行扫描-->
<context:exclude-filter type="annotation" expression="org.springframework.stereotype.Service"/>
</context:component-scan>
四、基于注解方式实现属性注入
@Autowired
:根据属性类型进行自动装配
第一步:创建service
和dao
对象,在service
和dao
类添加创建对象注解
@Service(value = "userService")
public class UserService {
public void add(){
System.out.println("UserService的add()方法");
}
}
@Repository
public class UserDaoImpl implements UserDao {
@Override
public void add() {
System.out.println("UserDaoImpl的add()方法");
}
}
第二步:在 service
注入 dao
对象,在 service
类添加 dao
类型属性,在属性上面使用注解
@Service(value = "userService")
public class UserService {
//定义dao类型属性,不需要添加set方法,需要添加注入属性注解
@Autowired
private UserDao userDao;
public void add(){
System.out.println("UserService的add()方法");
userDao.add();
}
}
测试
@Test
public void testService(){
//1.加载Spring配置文件
ApplicationContext context = new ClassPathXmlApplicationContext("annotation.xml");
//2.获取配置创建的对象
UserService userService = context.getBean("userService", UserService.class);
userService.add();
}
输出结果:
UserService
对象使用@Autowired
注解,根据类型注入UserDao
类型的对象,如果去掉注解就会报错,空指针异常
@Qualifier
:根据名称进行注入
当一个接口有多个接口实现类时,使用@Autowired
根据类型无法确定到底是哪个接口实现了,此时需要配合@Qualifier
一起使用,@Qualifier
是根据名称进行注入。
@Service(value = "userService")
public class UserService {
//定义dao类型属性,不需要添加set方法,需要添加注入属性注解
@Autowired
@Qualifier(value = "userDaoImpl")
private UserDao userDao;
public void add(){
System.out.println("UserService的add()方法");
userDao.add();
}
}
这样就会找到类型为UserDao
,并且实现类名称为userDaoImpl
的类来进行属性注入,如果没有找到这个类名称,就会报错
@Resource
:可以根据类型注入,可以根据名称注入
@Service(value = "userService")
public class UserService {
//@Resource 根据类型进行注入
@Resource(name = "userDaoImpl") //根据名称进行注入
private UserDao userDao;
public void add(){
System.out.println("UserService的add()方法");
userDao.add();
}
}
@Value
:注入普通类型属性
@Value(value = "name的值")
private String name;
有了注解方式,可以完全替代XML方式,也就不需要创建xml配置文件,而是使用配置类来替代配置文件。
@Configuration //用来标识当前类为配置类,替代xml配置文件
@ComponentScan(basePackages = {"dao,service"}) //替代xml配置文件中的组件扫描
public class SpringConfig {
}
测试类
@Test
public void testService(){
//1.加载配置类
ApplicationContext context = new AnnotationConfigApplicationContext(SpringConfig.class);
//2.获取配置创建的对象
UserService userService = context.getBean("userService", UserService.class);
userService.add();
}