java学习-springaop AOP-execution格式说明

郑重声明: 本文首发于人工博客

1、参数说明

示例

execution(* com._94rg.method.ces..*.*(..))
标识符含义
execution()表达式的主体
第一个“*”符号表示返回值的类型任意
com._94rg.method.cesAOP所切的服务的包名,即,需要进行横切的业务类
包名后面的“…”表示当前包及子包
第二个“*”表示类名,*即所有类
.*(…)表示任何方法名,括号表示参数,两个点表示任何参数类型

2、springaop的应用

  • 方法耗时监控
  • 出参、入参打印
  • 全局异常拦截
  • mock三方jar中的调用

3、代码分享

@Order(0)
@Aspect
@Component
@Slf4j
public class EsAspect {
    @Value("${testingMode:false}")
    private boolean testingMode;

    @PuppeteerConfigChangeListener
    private void configChangeListener(ConfigChangeEvent changeEvent) {

        if (changeEvent.isChanged("testingMode")) {
            testingMode =
                    Boolean.parseBoolean(
                            changeEvent.getChange("testingMode").getNewValue());
            log.info("当前的测试模式开关为:{}", testingMode);
        }
    }

    /**
     * 定义一个切入点
     */
    @Pointcut("execution(public * com._94rg.DocSearchApi.*(..))")
    private void doAspect() {
    }

    
    @Around("doAspect()")
    public Object methodMonitor(ProceedingJoinPoint pjp) throws Throwable {
        if (testingMode) {
            MethodSignature methodSignature = (MethodSignature) pjp.getSignature();
            Class type = methodSignature.getReturnType();
            if (type != Void.TYPE) {
                return type.newInstance();
            }

        } else {
            return pjp.proceed();
        }
        return null;
    }

}

版权声明:本文为人工博客的原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接及本声明。
本文链接:https://www.94rg.com/article/1734

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值