前篇
IOC操作-Bean管理(基于注解的方式)
-
什么是注解?
(1)注解是代码特殊的标记,格式:注解名称(属性名=属性值,属性名=属性值...)
(2)使用注解:注解作用在类、方法、属性上。
(3)使用注解的目的:简化XML配置
-
Spring针对Bean管理中创建对象提供的注解有:
@Component
@Service
@Controller
@Repository
以上四个注解功能是一样的,都可以用来创建Bean实例。
-
基于注解方式实现对象的创建
第一步 引入依赖
第二步 添加context名称空间
<?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">
</beans>
第三步 开启组件扫描
<!-- 开启组件扫描-->
<context:component-scan base-package="com.atguigu"/>
第四步 创建类,在类上添加创建对象注解
/*
在注解里面 value 属性值可以省略不写,
默认值是类名称,首字母小写
UserService -- userService
*/
@Component(value="userService")
public class UserService {
public void test1(){
System.out.println("add...");
}
}
第五步 测试
public class TestDemo {
@Test
public void test1(){
ApplicationContext context =
new ClassPathXmlApplicationContext("bean01.xml");
UserService userService = context.getBean("userService", UserService.class);
System.out.println(userService);
}
}
组件扫描补充内容
示例:
<!-- 设置只扫描哪些-->
<context:component-scan base-package="com.atguigu" use-default-filters="false">
<context:include-filter type="annotation" expression="org.springframework.stereotype.Controller"/>
</context:component-scan>
<!-- 设置不扫描哪些-->
<context:component-scan base-package="com.atguigu">
<context:exclude-filter type="annotation" expression="org.springframework.stereotype.Controller"/>
</context:component-scan>
基于注解方式实现属性注入
(1)Autowired:基于属性类型进行自动装配
第一步 把 service 和 dao 对象创建,在 service 和 dao 类添加创建对象注解
第二步 在 service 注入 dao 对象,在 service 类添加 dao 类型属性,在属性上面使用注解
@Service
public class UserService {
//定义 dao 类型属性
//不需要添加 set 方法
//添加注入属性注解
@Autowired
private UserDao userDao;
public void add() {
System.out.println("service add.......");
userDao.add();
}
}
(2)Qualifier:根据属性名称进行注入
使用:与@Autowired注解一起使用
(如上例所示:如果UserDao有多个实现类,只根据名称注入时会分不清到底是哪一个实现类,此时需要加入属性的名称来一起确定要注入的实现类)
//添加注入属性注解
@Autowired //根据类型进行注入
@Qualifier(value = "userDaoImpl1") //根据名称进行注入
private UserDao userDao;
@Component("userDaoImpl1")
public class USerDaoImpl implements UserDao{
public void test1(){
System.out.println("dao add...");
}
}
(3)@Resource: 可以根据类型注入,也可以根据名称进行注入(该注解不属于spring中的注解,而是属于javax扩展包中的注解)
// @Resource //根据类型进行注入
@Resource(name = "userDaoImpl1") //根据名称进行注入
private UserDao userDao;
public void test1(){
System.out.println("service add..." + name);
userDao.test1();
}
}
(4)@Value:注入普通类型的属性
@Value(value = "张三")
private String name;
完全注解开发(使用配置类代替XML配置文件)
(1)创建配置类,替代 xml 配置文件
@Configurable //配置类注解
@ComponentScan(basePackages = {"com.atguigu"})
public class SpringConfig {
}
(2)编写测试类
@Test
public void test2(){
// 加载配置文件
ApplicationContext context =
new AnnotationConfigApplicationContext(SpringConfig.class);
UserService userService = context.getBean("userService", UserService.class);
userService.test1();
System.out.println(userService);
}