SpringIoC注解+Junit整合
一.IoC的注解形式
添加注解后,需要在.xml配置文件中开启注解扫描。
<context:component-scan base-package=“com”></context:component-scan>
注解可以不添加id属性值,默认为类的首字母小写
- @Component(“id属性”)
注解应用与类上,该注解表示将对应的类放入到spring容器中,
等价于 - 特殊注解
@Service 用于注解业务层组件
@Controller 用于注解控制器层组件
@Repository 用于注解数据访问组件(dao Data Access Object) - DI
- 简单类型
@Value(值) - 复杂数据类型
使用@Value和spEl表达式一起完成
#{要注入的bean名称} @Value("#{userDao}") - 自动注入
@AutoWired
默认根据类型注入,如果超过一个匹配成功,报异常
*例外:如果bean的名称和属性名正好相同也能装配成功
*如果启动时没有找到匹配项,报错,但是可以给注解添加required = false,但不能避免
如果要根据名称来匹配,可以和@Qualifier注解一起使用
除了定义在属性上,也可以定义在set方法上 - @Resource
默认根据名称进行匹配的,如果名称匹配不上,再根据类型匹配(匹配规则:要注入的属性名=bean名称)
如果需要指定名称,可以添加name属性,指定对应的bean名称
@Scope 指定bean的作用域
@PostConstruct 指定bean的init-method
@PreDestroy 指定bean的destroy-method
@Lazy 延迟加载
- 简单类型
二.spring整合Junit
在测试类中,每个测试方法都有以下两行代码:
ApplicationContext ac = new ClassPathXmlApplicationContext("applicationContext.xml");
UserService userService = ac.getBean("userService",UserService.class);
整合了Junit后可以在类中自动装配所需要的对象,不用getBean获取了
import org.junit.Test;
import org.junit.runner.RunWith;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.test.context.ContextConfiguration;
import org.springframework.test.context.junit4.SpringJUnit4ClassRunner;
使用Junit提供的
- @Runwith注解,将Junit原有的运行器替换成spring提供的SpringJUnit4ClassRunner
- @ContextConfiguration注解:
locations 属性:用于指定xml配置文件的位置。如果是类路径下,需要用 classpath:表明。
classes 属性:用于指定注解的类。当不使用 xml 配置时,需要用此属性指定注解类的位置
@RunWith(SpringJUnit4ClassRunner.class)
@ContextConfiguration(locations = "classpath:applicationContext.xml")
public class TestSpringJunit {
@Autowired
private UserDao userDao;
@Autowired
private UserService userService;
@Test
public void test01(){
userDao.getUserByName("tom");
userService.login("tom", "123");
}
}