一、注解
注解是代码特殊标记,格式:@注解名称(属性名称=属性值, 属性名称=属性值..) 。注解作用在类上面,方法上面,属性上面 。使用注解的目的是简化XML的配置。
1.1 Spring 针对 Bean 管理中创建对象提供的注解
- @Component
- @Service
- @Controller
- @Repository
上面四个注解功能是一样的,都可以用来创建bean 实例
1.2 基于注解方式实现对象创建的步骤
(1)引入依赖(引入需要的jar包)
(2)开启组件扫描
<?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.wyf"></context:component-scan>
</beans>
(3)创建类 ,在类上面添加创建对象注解
@Component(value = "userService") //<bean id="userService" class=".."/>
public class UserService {
public void add(){
System.out.println("service add....");
}
}
测试代码:
@Test
public void TestService(){
//1. 加载spring 配置文件
ApplicationContext context = new ClassPathXmlApplicationContext("bean6.xml");
//2. 获取配置创建的对象
UserService userService = context.getBean("userService", UserService.class);
System.out.println(userService);
userService.add();
}
运行结果:
com.wyf.service.UserService@15bbf42f
service add....
以上代码,当程序加载配置文件后,根据文件中的组件扫描配置,会扫描指定包下的所有类,当遇到有@Component等四个创建对象(这四个注解功能相同,只是作为一个指示)的注解时,Spring会创建该类,并交由Bean容器管理。
1.3 开启组件扫描细节配置
<!--示例1
use-default-filters="false" 表示现在不使用默认 filter,自己配置 filter
context:include-filter ,设置扫描哪些内容
-->
<context:component-scan base-package="com.atguigu" use-default-filters="false">
<context:include-filter type="annotation"
expression="org.springframework.stereotype.Controller"/>
</context:component-scan>
<!--示例2
下面配置扫描包所有内容
context:exclude-filter: 设置哪些内容不进行扫描
-->
<context:component-scan base-package="com.atguigu">
<context:exclude-filter type="annotation"
expression="org.springframework.stereotype.Controller"/>
</context:component-scan>
二、基于注解方式的属性注入
2.1 @Autowired注解
@Autowired:根据属性类型进行自动装配
示例:创建两个类Service和Dao,使用注解的方式在Service类中调用Dao的方法。
第一步 把 service 和 dao 对象创建,在 service 和 dao 类添加创建对象注解
第二步 在 service 注入 dao 对象,在 service 类添加 dao 类型属性,在属性上面使用注解
对象创建代码:
@Component(value = "userDaoImpl")
public class UserDaoImpl implements UserDao{
@Override
public void updata() {
System.out.println("dao updata....");
}
}
@Component(value = "userService") //<bean id="userService" class=".."/>
public class UserService {
//定义Dao类型属性
//不需要添加set方法
//添加注入属性注解 @Autowired根据类型进行注入
@Autowired
private UserDao userDao;
public void add(){
System.out.println("service add....");
userDao.updata();
}
}
2.2 @Qualifier注解
@Qualifier:根据名称进行注入 。
这个@Qualifier 注解的使用,和上面2.1节的@Autowired注解 一起使用 。
@Component(value = "userService") //<bean id="userService" class=".."/>
public class UserService {
//定义Dao类型属性
//不需要添加set方法
//添加注入属性注解
@Autowired //根据类型进行注入
@Qualifier(value = "userDaoImpl") //根据名称进行注入
private UserDao userDao;
public void add(){
System.out.println("service add....");
userDao.updata();
}
}
2.3 @Resource注解
@Resource:即可以根据类型注入,也可以根据名称注入
//@Resource //根据类型进行注入
@Resource(name = "userDaoImpl1") //根据名称进行注入
private UserDao userDao;
2.4 @Value注解
@Value:注入普通类型属性
@Value(value = "abc")
private String name;
三、完全注解开发
创建配置类,替代xml配置文件
/**
* 配置类
*/
@Configuration //当前类作为一个配置类,用以替代xml配置文件
@ComponentScan(basePackages = {"com.wyf"})
public class SpringConfig {
}
编写测试代码:
@Test
public void TestConfig(){
//加载spring 配置类
ApplicationContext context = new AnnotationConfigApplicationContext(SpringConfig.class);
UserService userService = context.getBean("userService", UserService.class);
System.out.println(userService);
userService.add();
}
四、结束
完全注解开发,相比于XML配置文件开发更加方便、快捷,其也是SpringBoot的基础。