spring aop郵件發送

最近公司項目需要做郵件發送功能,訂單付款之後發送郵件,我一開始就考慮使用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}

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章