SpringAOP(注解方式實現面向切面編程)之常用Before、After、Around


一、首先在Springmvc.xml文件中引入如下內容(本示例是在ssm框架基礎上實現的)

  1、引入命名空間

xmlns:aop="http://www.springframework.org/schema/aop"

  2、在xsi:schemaLocation中引入如下內容(注意看清自己的spring版本號

http://www.springframework.org/schema/aop http://www.springframework.org/schema/aop/spring-aop-4.3.xsd
http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context-4.3.xsd

  3、在<beans></beans>節點中添加如下內容

<!-- 開啟掃描包,需要去掉service層不進行掃描,避免事務失效 -->
<context:component-scan base-package="com.hp">
        <!-- 配置不需要掃描 service層注解 -->
        <context:exclude-filter type="annotation" expression="org.springframework.stereotype.Service" />
</context:component-scan>
 <!-- 開啟aop注解方式,此步驟s不能少,這樣java類中的aop注解才會生效 -->
<aop:aspectj-autoproxy />

二、切面類

/**
 * @Aspect     將此類聲明為切面類
 * @Component  將此類交由spring管理
 * @author wsl
 *
 */
@Component
@Aspect
public class MyAop {
    /* 
   * sayings()方法只是一個代理對象,個人理解就是將此方法加上 *
@Pointcut 注解后 其他方法 只需要將value設為 此方法名即可 若有錯誤請指正 * @Pointcut 注解作用為定義切點 value值為准確切點位置 這里的意思是 com.hp.controller包下所有的方法
   */
@Pointcut(value = "execution(* com.hp.controller..*.*(..))") private void sayings() {} long time = 0; // 方法執行前執行 注意這里的value 是上面定義的代理對象 sayings() @Before(value = "sayings()") private void before() { time = new Date().getTime(); System.out.println("方法執行前執行"); } // 方法執行后執行 @After(value = "sayings()") private void after() { System.out.println("方法執行后執行,執行時間為" + (new Date().getTime() - time)); } // 環繞通知。注意要有ProceedingJoinPoint參數傳入。同時必須要有返回值,否者程序會中斷執行,web應用中會報頁面404; @Around(value = "sayings()") public Object sayAround(ProceedingJoinPoint pjp) { Object proceed = null; System.out.println("注解類型環繞通知..環繞前"); long time2 = new Date().getTime(); try { proceed = pjp.proceed(); } catch (Throwable e) { e.printStackTrace(); } System.out.println("注解類型環繞通知..環繞后,執行時間" + (new Date().getTime() - time2)); return proceed; } }

三、關於 @Pointcut 注解的拓展

  1、任何的Public方法

execution(public * *(..))

  2、以set開頭的方法

execution(* set*(..))

  3、定義在com.hp.in接口中的方法

execution(* com.hp.in.*(..))

  4、com.hp.wsl包中的所有方法

execution(* com.hp.wsl.*.*(..))

  5、com.hp.wsl包及其子包中的所有方法

execution(* com.hp.wsl..*.*(..))

四、致謝

  本文借鑒了:

     trayvon 前輩的  《Spring AOP 之二:Pointcut注解表達式》 一文,原文地址:https://my.oschina.net/u/2474629/blog/1083448

     小Cai先森 前輩的《spring中aop的注解實現方式簡單實例》 一文,原文地址:https://www.cnblogs.com/caijh/p/7154691.html

      如有不對的地方,謝謝指正;


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM