1. 引入依赖包
<!--spring整合mybatis--> <dependency> <groupId>org.mybatis</groupId> <artifactId>mybatis-spring</artifactId> <version>1.3.2</version> </dependency> <!-- 连接池 --> <dependency> <groupId>org.apache.commons</groupId> <artifactId>commons-dbcp2</artifactId> <version>2.1.1</version> </dependency> <dependency> <groupId>org.apache.commons</groupId> <artifactId>commons-pool2</artifactId> <version>2.4.3</version> </dependency>
2. 集成配置文件
该文件用于spring与mybatis的集成,具体配置文件及注释见课件中的applicationContext-base.xml
2.1 开启注解式开发
1) context:annotation-config/: 用于激活那些已经在spring容器里注册过的bean上面的注解,使用该注解相当于传统方式:
<!--@Autowired-->
<bean />
<!--@ Resource 、@ PostConstruct、@ PreDestroy等注解-->
<bean />
<!--@PersistenceContext注解-->
<bean />
<!--@Required-->
<bean />
context:annotation-config/是配置上述注解的简化配置方式,但是如果我们需要使用@Component, @Service, @Controller等注解则只使用该配置无效。该注解只能对已经注册的bean起作用,对于还没有在spring容器中注册的bean并不起作用。
2)<context:component-scan base-package=”XX.XX”/>:该配置除了具有上面提到的context:annotation-config/注解提到的作用,同时还具有自动将带有@Component, @Service, @Controller,@Repository等注解的对象注册到spring容器中的作用。如果同时使用了这两个配置则context:annotation-config/配置忽略,不会重复注册。对于使用注解式开发该配置必须有。
3)开启注解式事务
<tx:annotation-driven transaction-manager="transactionManager"/>: manager属性指定的是事务管理器,具体配置见课件中的完整配置文件
2.2 spring引入外部配置文件
<!--2. 引入外置jdbc配置文件 --> <!-- 第一种方式<bean > <property name="location" value="classpath:jdbc.properties"/></bean> --> <!-- 第二种方式,比第一种方式更简洁,第一种方式更好理解一些 --><context:property-placeholder location="classpath:jdbc.properties"/>
2.3 数据库连接池
dbcp连接池,配置详见完整配置文件
2.4 spring整合mybatis
sqlSessionFactory的配置,相见配置文件
2.5 自动代理
<aop:aspectj-autoproxy/>:自动为spring容器中那些配置@aspectJ切面的bean创建代理。依然由AnnotationAwareAspectJAutoProxyCreator进行自动代理的创建,该配置用来隐藏具体的实现细节。<aop:aspectj-autoproxy/>有一个proxy-target-class属性,当该属性默认为false,表示使用jdk动态代理来织入增强,如果为true则表示使用CGLIB进行织入增强,不管配置的是true还是false,当目标类没有声明接口时,spring都会自动使用CGLIB进行织入增强。
3. 注解式开发的几个常用注解
注解 | 作用 |
@Respository | 用于注解数据库访问层的bean |
@Service | 用于注解业务层bean |
@Controller | 用于访问控制层bean |
@Component | 用于注解一个组件,可以替代上几个注解,但从可读性上上面的几个更好理解其作用 |
@Autowired | 依赖注入的注解,spring的特有实现,默认按类型装配,默认情况下必须要求依赖对象必须存在,如果要允许null值,可以设置它的required属性为false,如:@Autowired(required=false),如果我们想使用名称装配可以结合@Qualifier注解进行使用。示例:@Autowired() @Qualifier("baseDao") |
@Resource | 这个注解属于J2EE,默认按名称进行装配,名称可以通过name属性进行指定,如果没有指定name属性,当注解写在字段上时,默认取字段名进行安装名称查找,如果name属性一旦指定,就只会按照名称进行装配,示例:@Resource(name="baseDao") |
@Transactional | 注解方法或类需要进行事务控制,使用该注解需要在spring中配置开启事务注解,并配置事务管理器 |
@Scope | 控制对象在spring容器中的生命周期,默认为singleton,其他的值有prototype, request, session, global session |
4. spring-test
1)依赖包
<dependency> <groupId>org.springframework</groupId> <artifactId>spring-test</artifactId> <version>${spring.version}</version> </dependency>
2)相关的注解
@RunWith(SpringJUnit4ClassRunner.class) @ContextConfiguration(locations={"classpath*:ApplicationContext*.xml"})
3)在执行单元测试时,为了避免产生脏数据,可将测试单元设置成事务回滚
@Rollback(value = true|false)//true回滚事务,false提交事务 @Transactional(transactionManager = "transactionManager")
示例:
5. 使用拦截器简化分页实现
定义拦截器后:
附录一:spring常用注解
@Service用于标注业务层组件
@Controller用于标注控制层组件(如struts中的action)
@Repository用于标注数据访问组件,即DAO组件
@Component泛指组件,当组件不好归类的时候,我们可以使用这个注解进行标注。
@Aspect//切面
@Pointcut//定义需要切面的地方,表达式参数(https://blog.csdn.net/elim168/article/details/78150438)
@annotation//当执行的方法上拥有指定的注解时生效。
@After
@Before
@Around