您好,登錄后才能下訂單哦!
本篇內容主要講解“Java Spring之基于注解的AOP怎么配置”,感興趣的朋友不妨來看看。本文介紹的方法操作簡單快捷,實用性強。下面就讓小編來帶大家學習“Java Spring之基于注解的AOP怎么配置”吧!
拷貝上一小節的工程即可。
<?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>
賬戶的業務層實現類
@Service("accountService") public class AccountServiceImpl implements IAccountService { @Autowired private IAccountDao accountDao; }
賬戶的持久層實現類
@Repository("accountDao") public class AccountDaoImpl implements IAccountDao { @Autowired private DBAssit dbAssit ; }
<!-- 告知 spring,在創建容器時要掃描的包 --> <context:component-scan base-package="com.itheima"></context:component-scan>
事務控制類
@Component("txManager") public class TransactionManager { //定義一個 DBAssit @Autowired private DBAssit dbAssit ; }
作用:
把當前類聲明為切面類。
事務控制類
@Component("txManager") @Aspect//表明當前類是一個切面類 public class TransactionManager { //定義一個 DBAssit @Autowired private DBAssit dbAssit ; }
作用:
把當前方法看成是前置通知。
屬性:
value:用于指定切入點表達式,還可以指定切入點表達式的引用。
//開啟事務 @Before("execution(* com.itheima.service.impl.*.*(..))") public void beginTransaction() { try { dbAssit.getCurrentConnection().setAutoCommit(false); } catch (SQLException e) { e.printStackTrace(); } }
作用:
把當前方法看成是后置通知。
屬性:
value:用于指定切入點表達式,還可以指定切入點表達式的引用
//提交事務 @AfterReturning("execution(* com.itheima.service.impl.*.*(..))") public void commit() { try { dbAssit.getCurrentConnection().commit(); } catch (SQLException e) { e.printStackTrace(); } }
作用:
把當前方法看成是異常通知。
屬性:
value:用于指定切入點表達式,還可以指定切入點表達式的引用
//回滾事務 @AfterThrowing("execution(* com.itheima.service.impl.*.*(..))") public void rollback() { try { dbAssit.getCurrentConnection().rollback(); } catch (SQLException e) { e.printStackTrace(); } }
作用:
把當前方法看成是最終通知。
屬性:
value:用于指定切入點表達式,還可以指定切入點表達式的引用
//釋放資源 @After("execution(* com.itheima.service.impl.*.*(..))") public void release() { try { dbAssit.releaseConnection(); } catch (Exception e) { e.printStackTrace(); } }
<!-- 開啟 spring 對注解 AOP 的支持 --> <aop:aspectj-autoproxy/>
作用:
把當前方法看成是環繞通知。
屬性:
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; }
作用:
指定切入點表達式
屬性:
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; }
@Configuration @ComponentScan(basePackages="com.itheima") @EnableAspectJAutoProxy public class SpringConfiguration { }
到此,相信大家對“Java Spring之基于注解的AOP怎么配置”有了更深的了解,不妨來實際操作一番吧!這里是億速云網站,更多相關內容可以進入相關頻道進行查詢,關注我們,繼續學習!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。