1.2 第二步:在配置文件中导入 context 的名称空间<?xml version="1.0" encoding="utf-8"?><beans xmlns="http://www.springframework.org/schema/beans" xmlns:aop="http://www.springframework.org/schema/aop" xmlns:context="http://www.springframework.org/schema/context" xmlns:xsi="http://www.w3.org/2001/xmlschema-instance" xsi:schemalocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans.xsd http://www.springframework.org/schema/aop http://www.springframework.org/schema/aop/spring-aop.xsd http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context.xsd"> <!-- 配置数据库操作对象 --> <bean id="dbassit" class="com.itheima.dbassit.dbassit"> <property name="datasource" ref="datasource"></property> <!-- 指定 connection 和线程绑定 --> <property name="usecurrentconnection" value="true"></property> </bean> <!-- 配置数据源 --> <bean id="datasource" class="com.mchange.v2.c3p0.combopooleddatasource"> <property name="driverclass" value="com.mysql.jdbc.driver"></property> <property name="jdbcurl" value="jdbc:mysql:///spring_day02"></property> <property name="user" value="root"></property> <property name="password" value="1234"></property> </bean></beans>
1.3 第三步:把资源使用注解配置账户的业务层实现类
@service("accountservice")public class accountserviceimpl implements iaccountservice { @autowired private iaccountdao accountdao;}
账户的持久层实现类
@repository("accountdao")public class accountdaoimpl implements iaccountdao { @autowired private dbassit dbassit ;}
1.4 第四步:在配置文件中指定 spring 要扫描的包<!-- 告知 spring,在创建容器时要扫描的包 --><context:component-scan base-package="com.itheima"></context:component-scan>
2 配置步骤2.1 第一步:把通知类也使用注解配置事务控制类
@component("txmanager")public class transactionmanager { //定义一个 dbassit @autowired private dbassit dbassit ;}
2.2 第二步:在通知类上使用@aspect 注解声明为切面作用:
把当前类声明为切面类。
事务控制类
@component("txmanager")@aspect//表明当前类是一个切面类public class transactionmanager { //定义一个 dbassit @autowired private dbassit dbassit ;}
2.3 第三步:在增强的方法上使用注解配置通知2.3.1 @before作用:
把当前方法看成是前置通知。
属性:
value:用于指定切入点表达式,还可以指定切入点表达式的引用。
//开启事务@before("execution(* com.itheima.service.impl.*.*(..))")public void begintransaction() { try { dbassit.getcurrentconnection().setautocommit(false); } catch (sqlexception e) { e.printstacktrace(); }}
2.3.2 @afterreturning作用:
把当前方法看成是后置通知。
属性:
value:用于指定切入点表达式,还可以指定切入点表达式的引用
//提交事务@afterreturning("execution(* com.itheima.service.impl.*.*(..))")public void commit() { try { dbassit.getcurrentconnection().commit(); } catch (sqlexception e) { e.printstacktrace(); }}
2.3.3 @afterthrowing作用:
把当前方法看成是异常通知。
属性:
value:用于指定切入点表达式,还可以指定切入点表达式的引用
//回滚事务@afterthrowing("execution(* com.itheima.service.impl.*.*(..))")public void rollback() { try { dbassit.getcurrentconnection().rollback(); } catch (sqlexception e) { e.printstacktrace(); }}
2.3.4 @after作用:
把当前方法看成是最终通知。
属性:
value:用于指定切入点表达式,还可以指定切入点表达式的引用
//释放资源@after("execution(* com.itheima.service.impl.*.*(..))")public void release() { try { dbassit.releaseconnection(); } catch (exception e) { e.printstacktrace(); }}
2.4 第四步:在 spring 配置文件中开启 spring 对注解 aop 的支持<!-- 开启 spring 对注解 aop 的支持 --><aop:aspectj-autoproxy/>
3 环绕通知注解配置 @around作用:
把当前方法看成是环绕通知。
属性:
value:用于指定切入点表达式,还可以指定切入点表达式的引用。
/*** 环绕通知* @param pjp* @return*/@around("execution(* com.itheima.service.impl.*.*(..))")public object transactionaround(proceedingjoinpoint pjp) { //定义返回值 object rtvalue = null; try { //获取方法执行所需的参数 object[] args = pjp.getargs(); //前置通知:开启事务 begintransaction(); //执行方法 rtvalue = pjp.proceed(args); //后置通知:提交事务 commit(); }catch(throwable e) { //异常通知:回滚事务 rollback(); e.printstacktrace(); }finally { //最终通知:释放资源 release(); } return rtvalue;}
4 切入点表达式注解 @pointcut作用:
指定切入点表达式
属性:
value:指定表达式的内容
@pointcut("execution(* com.itheima.service.impl.*.*(..))")private void pt1() {} /** * 引用方式: * 环绕通知 * @param pjp * @return */ @around("pt1()")//注意:千万别忘了写括号 public object transactionaround(proceedingjoinpoint pjp) { //定义返回值 object rtvalue = null; try { //获取方法执行所需的参数 object[] args = pjp.getargs(); //前置通知:开启事务 begintransaction(); //执行方法 rtvalue = pjp.proceed(args); //后置通知:提交事务 commit(); }catch(throwable e) { //异常通知:回滚事务 rollback(); e.printstacktrace(); }finally { //最终通知:释放资源 release(); } return rtvalue;}
5 不使用 xml 的配置方式@configuration@componentscan(basepackages="com.itheima")@enableaspectjautoproxypublic class springconfiguration { }
以上就是java spring之基于注解的aop怎么配置的详细内容。
