zoukankan      html  css  js  c++  java
  • 获取连接点信息

    获取连接点信息,参考使用注解定义增强

    1.UserBizLogger .java

     1 package com.aop;
     2 
     3 import java.util.Arrays;
     4 
     5 import org.apache.log4j.Logger;
     6 import org.aspectj.lang.JoinPoint;
     7 import org.aspectj.lang.annotation.AfterReturning;
     8 import org.aspectj.lang.annotation.Aspect;
     9 import org.aspectj.lang.annotation.Before;
    10 
    11 /**
    12  * 
    13  * @author Mr
    14  * 使用注解
    15  */
    16 @Aspect
    17 public class UserBizLogger {
    18     private static final Logger log = Logger.getLogger(UserBizLogger.class);
    19     //前置增强  com.biz.IUserBiz表示接口全类名
    20     @Before("execution(* com.biz.IUserBiz.*(..))")
    21     public void before(JoinPoint jp){
    22         log.info("调用"+jp.getTarget()+"的"+jp.getSignature().getName()+
    23                 "方法,方法的参数是:"+Arrays.toString(jp.getArgs()));
    24     }
    25     //后置增强
    26     @AfterReturning(pointcut="execution(* com.biz.IUserBiz.*(..))",returning="returnValue")
    27     public void afterReturing(JoinPoint jp,Object returnValue){
    28         log.info("调用"+jp.getTarget()+"的"+jp.getSignature().getName()+
    29                 "方法,方法的返回值是:"+returnValue);
    30     }
    31 }

    2.spring配置文件

    1     <bean id="dao" class="com.dao.impl.IUserDaoImpl"></bean>
    2     <bean id="biz" class="com.biz.impl.IUserBizImpl">
    3         <property name="dao" ref="dao"></property>
    4     </bean>
    5     <!-- 定义包含注解的增强类的实例 -->
    6     <bean class="com.aop.UserBizLogger"></bean>
    7     <!-- 织入使用注解定义的增强,需要引入AOP命名空间 -->
    8     <aop:aspectj-autoproxy></aop:aspectj-autoproxy>

    3.测试结果

  • 相关阅读:
    C++随笔
    STM32调试总结
    摄像头CMOS和CCD的比较
    modelsim 中 WAVE窗口中能不能只显示变量名,而不显示路径
    modelsim仿真xilinx mig ip core相关问题
    modelsim仿真vivado自动化脚本
    modelsim无法识别include文件的解决方法
    UVM的类库
    uvm
    uvm
  • 原文地址:https://www.cnblogs.com/myhzb/p/7538007.html
Copyright © 2011-2022 走看看