SpringPointcut案例

SpringPointcut案例


创建通知类对象 实现类 实现接口方法

/*
自定义接口 IMathEnt  里面有 
	int  addUser(int i,int j);
	int  subUser(int i,int j);
	int  rideUser(int i,int j);
	int  exceptUser(int i,int j);
 四个方法;DMathEnt 实现类实现接口中所有方法
*/
public class DMathEnt implements IMathEnt {

	@Override
	public int addUser(int i, int j) {
		int ret=i+j;
		System.out.println("执行的方法是:addUser=>>> 结果为:" +ret );
		return ret;
	}

	@Override
	public int subUser(int i, int j) {
		int ret=i-j;
		System.out.println("执行的方法是:subUser=>>> 结果为:" +ret );
		return ret;
	}

	@Override
	public int rideUser(int i, int j) {
		int ret=i*j;
		System.out.println("执行的方法是:rideUser=>>> 结果为:" +ret );
		return ret;
	}

	@Override
	public int exceptUser(int i, int j) {
		int ret=i/j;
		System.out.println("执行的方法是:exceptUser=>>> 结果为:" +ret );
		return ret;
	}

}

通知类


import java.util.Arrays;
import org.aspectj.lang.JoinPoint;
import org.aspectj.lang.ProceedingJoinPoint;
import org.aspectj.lang.Signature;

public class ObjectAspect {
	

	//写通知  前置通知
	public void methodBegin(JoinPoint joinpoint){
		//获取签名参数 :joinPiint传递的参数形式
		Signature signature	=joinpoint.getSignature();
		//方法传递的实际参数
		Object[] args=joinpoint.getArgs();
		
		System.out.println("[前置通知] 执行了方法:["+signature.getName()+"]参数列表为:"+Arrays.asList(args));
	}
	//返回通知
	public void methodReturn(JoinPoint joinpoint,Object resutl){
		//获取签名参数 :joinPiint传递的参数形式
		Signature signature	=joinpoint.getSignature();
		String methodName=signature.getName();
		
		System.out.println("[返回通知] 执行了方法:["+methodName+"]返回结果为:"+resutl);
	}
	//返回异常通知
	public void methodThrow(JoinPoint joinpoint,ArithmeticException throwable){
		//获取签名参数 :joinPiint传递的参数形式
		String methodName	=joinpoint.getSignature().getName();
		String message=throwable.getMessage();
		
		System.out.println("[异常通知] 执行了方法:["+methodName+"]返回异常信息为:"+message);
	}
	//后置通知
	
	public void methodFinallEnd(JoinPoint joinpoint){
		//获取签名参数 :joinPiint传递的参数形式
		String methodName	=joinpoint.getSignature().getName();
		System.out.println("[后置通知] 执行了方法:["+methodName+"]");
	}
	
	//环绕通知
		public Object myArround(ProceedingJoinPoint joinPoint){
			//获取签名参数 :joinPiint传递的参数形式
			String methodName = joinPoint.getSignature().getName();
					
			//获取参数
			Object[] args = joinPoint.getArgs();
			
			System.out.println("[环绕通知] 执行了方法:["+methodName+"]开始执行的参数为:"+Arrays.asList(args));
			
			Object resutl = null;
			
			try {
				resutl = joinPoint.proceed();
				//执行result表示 方法执行 结束
				System.out.println("[环绕通知] 执行了方法:["+methodName+"]正常结束,结果为:"+resutl+"【环绕通知】");
				
			} catch (Throwable e) {
				System.out.println("[环绕通知] 执行了方法:["+methodName+"]抛出异常,异常信息为:"+e.getMessage()+"【环绕通知】");
			}finally{
				System.out.println("[环绕通知] 执行了方法:["+methodName+"]最终结束");
			}
			return resutl;
		}
	
}

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:p="http://www.springframework.org/schema/p"
	xmlns:aop="http://www.springframework.org/schema/aop"
	xsi:schemaLocation="http://www.springframework.org/schema/beans 
						http://www.springframework.org/schema/beans/spring-beans-4.1.xsd						
						http://www.springframework.org/schema/aop
						http://www.springframework.org/schema/aop/spring-aop-4.1.xsd
						">
	<!-- 通知对象 -->
	<bean id="objAspect" class="com.ym.pointcut.ObjectAspect"></bean>
	<!-- 切面配置 -->
	<aop:config>
		<!-- 切点配置 -->
											<!--说明: com.ym.dao.下面的所有的子包,所有的类,所有的方法 -->
		<aop:pointcut expression="execution(* com.ym.dao.*.*(..))" id="pc"/>
		
		<!--
			 前置通知(before):在目标方法执行之前执行
	
			后置通知(after):在目标方执行完成后执行,如果目标方法异常,则后置通知不再执行
	
			异常通知(After-throwing):目标方法抛出异常的时候执行
	
			最终通知(finally);不管目标方法是否有异常都会执行,相当于try。。catch。。finally中的finally
	
			环绕通知(round):可以控制目标方法是否执行 
		-->
		<!-- 切面的通知引入 ,要按照下面的顺序写,不然出错 -->
		<aop:aspect ref="objAspect">
			<aop:before method="methodBegin" pointcut-ref="pc"/>
			<aop:after-returning method="methodReturn" pointcut-ref="pc" returning="resutl"/>
			<aop:after-throwing method="methodThrow" pointcut-ref="pc" throwing="throwable"/>
			<aop:after method="methodFinallEnd" pointcut-ref="pc"/>
			<aop:around method="myArround" pointcut-ref="pc"/>
		</aop:aspect>
	
	</aop:config>
	
	<!-- 创建通知类对象 实现类 -->
	<bean id="dMathEnt" class="com.ym.dao.impl.DMathEnt"></bean>

</beans>

测试类


import java.util.Vector;
import org.springframework.beans.factory.BeanFactory;
import org.springframework.context.support.ClassPathXmlApplicationContext;
import com.ym.dao.IMathEnt;

public class TestDemo {
	
	public static void main(String[] args) {
		
		/*获取配置 spring环境*/
		BeanFactory bf = new  ClassPathXmlApplicationContext("applicationContext.xml");
		//获取接口对象
		
		IMathEnt imath = bf.getBean("dMathEnt",IMathEnt.class);
		imath.addUser(20, 5);
		imath.exceptUser(20, 0);	
	}
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值