最近公司項目需要做郵件發送功能,訂單付款之後發送郵件,我一開始就考慮使用aop技術,尼瑪,用的時候遇到各種蛋疼的問題,公司框架是ssm,在定義切點的時候,我將切點放在控制層action中,然後就發現各種問題,蛋疼一筆,沒搞定,然後就使用了jms技術搞定了,之後又重新研究了一下,這次切點我沒有放在action中,切點定義在service層中,這樣就不會出現蛋疼的問題,目的也達到了。好了廢話了好多,見代碼。
//配置文件
<!-- start aop config -->
<context:component-scan base-package="com.maimai.aop"/>
<aop:aspectj-autoproxy proxy-target-class="true"/>
<!-- end -->
//切面
package com.maimai.aop;
import org.aspectj.lang.annotation.After;
import org.aspectj.lang.annotation.AfterReturning;
import org.aspectj.lang.annotation.AfterThrowing;
import org.aspectj.lang.annotation.Around;
import org.aspectj.lang.annotation.Aspect;
import org.aspectj.lang.annotation.Before;
import org.aspectj.lang.annotation.Pointcut;
import org.springframework.stereotype.Component;
@Component
@Aspect
public class MailAop {
@Pointcut("execution(* com.maimai.engine.DealEngine.payByLeftMoney(..))")
public void perform(){
}
@AfterReturning("perform()")
public void methodAfter(){
System.out.println("............這是後置通知......");
}
/*
@Before("perform()")
public void myBeforeAdvice() {// 如果需要知道攔截的方法的信息,也可以需添加JoinPoint參數
System.out.println("............這是前置......");
}
// 最終置通知
@After("perform()")
public void doAfter() {
System.out.println("這是最終通知");
}
// 環繞通知
// @Around(value="pointcut1()")
@Around("perform()")
public void myAroundAdvice() {
// System.out.println("這是環繞通知:"+"sessionId="+session.getId() );
}
@AfterThrowing("perform()")
public void myAfterThrowingAdvice(){
System.out.println("----------------------------------------------------------------------啊,完蛋了報錯了");
}
*/
}
//打印結果
2015-09-02 16:57:02,580 [http-8080-3] DEBUG [org.springframework.jdbc.datasource.DataSourceUtils] - Returning JDBC Connection to DataSource
2015-09-02 16:57:02,585 [http-8080-3] DEBUG [org.springframework.beans.factory.support.DefaultListableBeanFactory] - Returning cached instance of singleton bean 'mailAop'
............這是後置通知......
2015-09-02 16:57:03,502 [http-8080-3] DEBUG [org.springframework.jms.core.JmsTemplate] - Executing callback on JMS Session: ActiveMQSession {id=ID:wwsoft-PC-62768-1441184151155-0:2:1,started=false}