亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 學院 > 開發設計 > 正文

spring的aop實現

2019-11-08 03:09:56
字體:
來源:轉載
供稿:網友

來源:http://www.tuicool.com/articles/QbaQru

SPRing默認aspectJ切入點語法

引入:將方法或字段添加到被處理的類中。 目標對象: 包含連接點的對象。也被稱作 被通知或被代理對象。  AOP代理:AOP框架創建的對象,對目標對象的加強。 織入:將增強處理添加到目標對象中,并創建一個被增強的對象的過程。 

掃描加的注釋和啟動@Aspect所需要的jar包: 

為了在Spring配置中使用@AspectJ切面,首先必須啟用Spring對@AspectJ切面配置的支持,并確保 自動代理(autoproxying) 的bean是否能被這些切面通知。自動代理是指Spring會判斷一個bean是否使用了一個或多個切面通知,并據此自動生成相應的代理以攔截其方法調用,并且確保通知在需要時執行。

通過在Spring的配置中引入下列元素來啟用Spring對@AspectJ的支持:

<aop:aspectj-autoproxy/>

配置文件 

xmlns:context="http://www.springframework.org/schema/context"http://www.springframework.org/schema/contexthttp://www.springframework.org/schema/context/spring-context-4.0.xsd配置aop

增加驗證驗證文檔xmlns:aop="http://www.springframework.org/schema/aop"http://www.springframework.org/schema/aop http://www.springframework.org/schema/aop /spring-aop-4.0.xsdUserDao.java
package net.csdn.www.dao;import org.springframework.stereotype.Component;@Componentpublic class UserDao {    public void save(){    	System.out.println("用戶保存成功!");    }}applicationContext.xml 
<?xml version="1.0" encoding="UTF-8"?><beans 	xmlns="http://www.springframework.org/schema/beans"	xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"	xmlns:aop="http://www.springframework.org/schema/aop"	xmlns:context="http://www.springframework.org/schema/context"	xsi:schemaLocation="http://www.springframework.org/schema/beans 	http://www.springframework.org/schema/beans/spring-beans-4.0.xsd	http://www.springframework.org/schema/aop 	http://www.springframework.org/schema/aop/spring-aop-4.0.xsd	http://www.springframework.org/schema/context	http://www.springframework.org/schema/context/spring-context-4.0.xsd"	>	<!-- 語言寫入值xmlns:p -->	<!-- xmlns:context掃描加的注釋 -->	<context:component-scan base-package="net.csdn.www.dao,net.csdn.www.aop">		<!-- 啟動@Aspect支持 -->	<context:include-filter type="annotation"			expression="org.aspectj.lang.annotation.Aspect"/>	</context:component-scan>    <aop:aspectj-autoproxy/></beans>使用 execution 切入點指示符 

execution(public * *(..))  所有的公共方法 execution(* set*(..))  以set開頭的任意方法 execution(* com.xyz.service.AccountService.*(..)) com.xyz.service.AccountService類中的所有的方法 execution(* com.xyz.service.*.*(..))  com.xyz.service包中的所有的類的所有的方法 execution(* com.xyz.service..*.*(..)) com.xyz.service包及子包中所有的類的所有的方法 execution(* cn.itcast.spring.sh..*.*(String,?,Integer))  cn.itcast.spring.sh包及子包中所有的類的有三個參數                                                             第一個參數為String,第二個參數為任意類型,                                                             第三個參數為Integer類型的方法 

定義成一個切面 LogAspect.java 
package net.csdn.www.aop;import java.util.logging.Level;import java.util.logging.Logger;import org.aspectj.lang.ProceedingJoinPoint;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;//定義成一個切面@Aspectpublic class LogAspect {	//定義一個切入點    ,訪問修飾符,包名,類名,方法名(參數,異常)	@Before("execution(* net.csdn.www.dao.*.save*(..))")	public void saveLog() {		Logger log = Logger.getLogger(LogAspect.class.getName());		log.log(Level.INFO, "信息被保存");	}	}測試代碼:
ApplicationContext context=new  ClassPathXmlApplicationContext("applicationContext.xml");		UserDao userDao=(UserDao) context.getBean("userDao");		userDao.save();運行結果: 信息: JSR-330 'javax.inject.Inject' annotation found and supported for autowiring 2014-3-27 21:35:00 net.csdn.www.aop.LogAspect saveLog 信息: 信息被保存 用戶保存成功! 

在UserDao.java中聲明一個方法:

  public void delete(){    	int i= 5/0;    }
@AfterThrowing(throwing="rvt",pointcut="execution(* net.csdn.www.dao.*.delete*(..))")	public void throwLog(Throwable rvt){	      System.out.println("獲取目標方法拋出的異常"+rvt);	      System.out.println("記錄日志");	}調用delete()方法后的運行結果:

Exception in thread "main" java.lang.ArithmeticException: / by zero at net.csdn.www.dao.UserDao.delete(UserDao.java:15) at net.csdn.www.dao.UserDao$$FastClassBySpringCGLIB$$c34aca31.invoke(<generated>) at org.springframework.cglib.proxy.MethodProxy.invoke(MethodProxy.java:204) at org.springframework.aop.framework.CglibAopProxy$CglibMethodInvocation.invokeJoinpoint(CglibAopProxy.java:711) at org.springframework.aop.framework.ReflectiveMethodInvocation.proceed(ReflectiveMethodInvocation.java:157) at org.springframework.aop.aspectj.AspectJAfterThrowingAdvice.invoke(AspectJAfterThrowingAdvice.java:58)獲取目標方法拋出的異常java.lang.ArithmeticException: / by zero 記錄日志 at org.springframework.aop.framework.ReflectiveMethodInvocation.proceed(ReflectiveMethodInvocation.java:179) at org.springframework.aop.interceptor.ExposeInvocationInterceptor.invoke(ExposeInvocationInterceptor.java:92) at org.springframework.aop.framework.ReflectiveMethodInvocation.proceed(ReflectiveMethodInvocation.java:179) at org.springframework.aop.framework.CglibAopProxy$DynamicAdvisedInterceptor.intercept(CglibAopProxy.java:644) at net.csdn.www.dao.UserDao$$EnhancerBySpringCGLIB$$d3fba046.delete(<generated>) at net.csdn.www.test.Test.main(Test.java:14) 

添加UserDao.java帶返回值的方法

public String selectUser(String name){    	System.out.println("用戶信息查詢成功");    	return "success";    }
//定義一個Around的切入點	@Around("execution(* net.csdn.www.dao.*.select*(..))")	public Object selectLog(ProceedingJoinPoint pj) throws Throwable{		Logger log = Logger.getLogger(LogAspect.class.getName());		log.log(Level.INFO, "信息被查詢");		//System.out.println(pj.getArgs()+"--");		Object result= pj.proceed(new String[]{"peitihuande zhi"});		return "peitihuande zhi";	}運行結果:

信息: JSR-330 'javax.inject.Inject' annotation found and supported for autowiring 2014-3-27 22:28:00 net.csdn.www.aop.LogAspect selectLog 信息: 信息被查詢 用戶信息查詢成功 peitihuande zhi 


發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
日本精品久久久久影院| 久久国产精品影片| 欧美人在线观看| 日本精品视频在线播放| 国产精品久久久久久久久久新婚| 欧美色视频日本版| 国产亚洲精品高潮| 欧美多人乱p欧美4p久久| 国内精品免费午夜毛片| 国产91在线视频| 日韩在线视频观看| 亚洲аv电影天堂网| 亚洲深夜福利在线| 欧美日韩久久久久| 欧美中文在线视频| 69久久夜色精品国产7777| 亚洲精品乱码久久久久久金桔影视| 国产亚洲在线播放| 久久97久久97精品免视看| 国产精品海角社区在线观看| 欧洲精品在线视频| 中文字幕免费精品一区高清| 色999日韩欧美国产| 日韩hd视频在线观看| 国产日韩在线视频| 国产精品永久免费视频| 国内免费久久久久久久久久久| 欧美裸身视频免费观看| 国产精品久久在线观看| 中文字幕欧美日韩va免费视频| 久久精品一区中文字幕| 久久精品视频在线| 国产精品一区二区久久久久| 日韩精品免费在线| 欧美精品第一页在线播放| 岛国av一区二区在线在线观看| 亚洲男人天堂2023| 亚洲第一页中文字幕| 欧美色xxxx| 亚洲色图五月天| 精品亚洲一区二区| 91精品视频大全| 欧美日韩国产一中文字不卡| 裸体女人亚洲精品一区| 欧美大肥婆大肥bbbbb| 91精品视频专区| 亚洲香蕉成视频在线观看| 国产视频福利一区| 精品国偷自产在线视频99| 亚洲成人三级在线| 亚洲精品第一国产综合精品| 国产精品亚洲激情| 国产福利视频一区二区| 国产成人福利夜色影视| 国产成人精品电影久久久| 久久韩剧网电视剧| 国产成人自拍视频在线观看| 久久精品成人动漫| 欧美日韩在线视频一区| 4388成人网| 欧美日韩国产中字| 91久久嫩草影院一区二区| 精品中文字幕在线观看| 亚洲天堂2020| 精品女同一区二区三区在线播放| 欧美一区亚洲一区| 亚洲综合在线中文字幕| 日韩网站免费观看| 国产精品一二三视频| 免费不卡在线观看av| 欧美精品www| 亚洲精品国产精品自产a区红杏吧| 97超碰国产精品女人人人爽| 欧美成人高清视频| 中文字幕亚洲无线码在线一区| 黑人巨大精品欧美一区二区一视频| 亚洲成人网在线观看| 亚洲一区二区三区成人在线视频精品| 日韩亚洲综合在线| 色久欧美在线视频观看| 久久视频在线观看免费| 91亚洲精品久久久久久久久久久久| 91大神在线播放精品| 91嫩草在线视频| 奇门遁甲1982国语版免费观看高清| 欧美日韩精品中文字幕| 91久久国产婷婷一区二区| 久久久久99精品久久久久| 精品国产91久久久| 精品亚洲一区二区三区在线播放| 国产精品6699| 久久久久久久久久av| 国产成人免费av| 国产欧美在线播放| 日韩激情片免费| 国产69精品久久久| 亚洲老板91色精品久久| 国产精品99免视看9| 欧美成人手机在线| 日产精品久久久一区二区福利| 九九热精品视频| 欧美日韩在线观看视频小说| 亚洲人永久免费| 亚洲综合精品一区二区| 欧美日韩国产二区| 欧美一级bbbbb性bbbb喷潮片| 91国语精品自产拍在线观看性色| 欧美激情在线观看| 韩国福利视频一区| 国产精品露脸av在线| 国产精品欧美激情在线播放| 精品久久中文字幕久久av| 国产一区欧美二区三区| 欧美最近摘花xxxx摘花| 久久久久久久久综合| 日韩电影在线观看永久视频免费网站| 国内精品国产三级国产在线专| 亚洲精品一区中文| 国产精品wwwwww| 久久精品中文字幕一区| 久久久久久久久久久av| 欧美日韩午夜剧场| 久久久99免费视频| 日韩欧美999| 中文字幕精品在线| 国产欧美日韩精品丝袜高跟鞋| 高清欧美性猛交xxxx黑人猛交| 九九久久久久久久久激情| 欧美日韩国产黄| 国产精品99一区| 欧美精品久久久久a| 91超碰caoporn97人人| 久久精品美女视频网站| 国产精品无av码在线观看| 在线日韩av观看| 黑人与娇小精品av专区| 亚洲免费一级电影| 国产成人在线一区| 亚洲国产精品中文| 国产亚洲人成a一在线v站| 成人激情视频小说免费下载| 色综合伊人色综合网| 国产成人精品午夜| 国产精品久久久久久久久免费看| 日韩精品久久久久| 亚洲精品一区二区久| 久久久在线视频| 亚洲天堂视频在线观看| 国产精品第2页| 亚洲自拍偷拍第一页| 51久久精品夜色国产麻豆| 中文字幕日韩视频| 欧美亚洲第一区| 国产精品久久久久91| 久久国产精品99国产精| 国产美女主播一区| 91精品视频免费观看| 久久久久国产精品一区| 日韩在线中文视频| 91精品视频大全| 亚洲影院色无极综合| 久久久久久久久久av| 欧美疯狂做受xxxx高潮| 国产香蕉一区二区三区在线视频|