原创

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.gzcx.net/article/1734

%3E**%E9%83%91%E9%87%8D%E5%A3%B0%E6%98%8E**%3A%20%E6%9C%AC%E6%96%87%E9%A6%96%E5%8F%91%E4%BA%8E%5B%E4%BA%BA%E5%B7%A5%E5%8D%9A%E5%AE%A2%5D(https%3A%2F%2Fwww.gzcx.net)%0A%0A%23%23%23%201%E3%80%81%E5%8F%82%E6%95%B0%E8%AF%B4%E6%98%8E%0A**%E7%A4%BA%E4%BE%8B**%0A%60%60%60%0Aexecution(*%20com._94rg.method.ces..*.*(..))%0A%60%60%60%0A%0A%7C%20%E6%A0%87%E8%AF%86%E7%AC%A6%20%7C%E5%90%AB%E4%B9%89%20%20%7C%0A%7C%20---%20%7C%20---%20%7C%0A%7C%20execution()%20%7C%20%E8%A1%A8%E8%BE%BE%E5%BC%8F%E7%9A%84%E4%B8%BB%E4%BD%93%20%7C%0A%7C%20%20%E7%AC%AC%E4%B8%80%E4%B8%AA%E2%80%9C*%E2%80%9D%E7%AC%A6%E5%8F%B7%7C%20%20%E8%A1%A8%E7%A4%BA%E8%BF%94%E5%9B%9E%E5%80%BC%E7%9A%84%E7%B1%BB%E5%9E%8B%E4%BB%BB%E6%84%8F%7C%0A%7C%20%20com._94rg.method.ces%7C%20AOP%E6%89%80%E5%88%87%E7%9A%84%E6%9C%8D%E5%8A%A1%E7%9A%84%E5%8C%85%E5%90%8D%EF%BC%8C%E5%8D%B3%EF%BC%8C%E9%9C%80%E8%A6%81%E8%BF%9B%E8%A1%8C%E6%A8%AA%E5%88%87%E7%9A%84%E4%B8%9A%E5%8A%A1%E7%B1%BB%20%7C%0A%7C%20%20%E5%8C%85%E5%90%8D%E5%90%8E%E9%9D%A2%E7%9A%84%E2%80%9C..%E2%80%9D%7C%20%E8%A1%A8%E7%A4%BA%E5%BD%93%E5%89%8D%E5%8C%85%E5%8F%8A%E5%AD%90%E5%8C%85%20%7C%0A%7C%20%E7%AC%AC%E4%BA%8C%E4%B8%AA%E2%80%9C*%E2%80%9D%20%7C%20%E8%A1%A8%E7%A4%BA%E7%B1%BB%E5%90%8D%EF%BC%8C*%E5%8D%B3%E6%89%80%E6%9C%89%E7%B1%BB%20%7C%0A%7C%20%20.*(..)%7C%20%E8%A1%A8%E7%A4%BA%E4%BB%BB%E4%BD%95%E6%96%B9%E6%B3%95%E5%90%8D%EF%BC%8C%E6%8B%AC%E5%8F%B7%E8%A1%A8%E7%A4%BA%E5%8F%82%E6%95%B0%EF%BC%8C%E4%B8%A4%E4%B8%AA%E7%82%B9%E8%A1%A8%E7%A4%BA%E4%BB%BB%E4%BD%95%E5%8F%82%E6%95%B0%E7%B1%BB%E5%9E%8B%20%7C%0A------%0A%0A%23%23%23%202%E3%80%81springaop%E7%9A%84%E5%BA%94%E7%94%A8%0A%3E%20%2B%20%E6%96%B9%E6%B3%95%E8%80%97%E6%97%B6%E7%9B%91%E6%8E%A7%0A%3E%20%2B%20%E5%87%BA%E5%8F%82%E3%80%81%E5%85%A5%E5%8F%82%E6%89%93%E5%8D%B0%0A%3E%20%2B%20%E5%85%A8%E5%B1%80%E5%BC%82%E5%B8%B8%E6%8B%A6%E6%88%AA%0A%3E%20%2B%20mock%E4%B8%89%E6%96%B9jar%E4%B8%AD%E7%9A%84%E8%B0%83%E7%94%A8%0A%0A%0A%23%23%23%203%E3%80%81%E4%BB%A3%E7%A0%81%E5%88%86%E4%BA%AB%0A%60%60%60%0A%40Order(0)%0A%40Aspect%0A%40Component%0A%40Slf4j%0Apublic%20class%20EsAspect%20%7B%0A%20%20%20%20%40Value(%22%24%7BtestingMode%3Afalse%7D%22)%0A%20%20%20%20private%20boolean%20testingMode%3B%0A%0A%20%20%20%20%40PuppeteerConfigChangeListener%0A%20%20%20%20private%20void%20configChangeListener(ConfigChangeEvent%20changeEvent)%20%7B%0A%0A%20%20%20%20%20%20%20%20if%20(changeEvent.isChanged(%22testingMode%22))%20%7B%0A%20%20%20%20%20%20%20%20%20%20%20%20testingMode%20%3D%0A%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20Boolean.parseBoolean(%0A%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20changeEvent.getChange(%22testingMode%22).getNewValue())%3B%0A%20%20%20%20%20%20%20%20%20%20%20%20log.info(%22%E5%BD%93%E5%89%8D%E7%9A%84%E6%B5%8B%E8%AF%95%E6%A8%A1%E5%BC%8F%E5%BC%80%E5%85%B3%E4%B8%BA%3A%7B%7D%22%2C%20testingMode)%3B%0A%20%20%20%20%20%20%20%20%7D%0A%20%20%20%20%7D%0A%0A%20%20%20%20%2F**%0A%20%20%20%20%20*%20%E5%AE%9A%E4%B9%89%E4%B8%80%E4%B8%AA%E5%88%87%E5%85%A5%E7%82%B9%0A%20%20%20%20%20*%2F%0A%20%20%20%20%40Pointcut(%22execution(public%20*%20com._94rg.DocSearchApi.*(..))%22)%0A%20%20%20%20private%20void%20doAspect()%20%7B%0A%20%20%20%20%7D%0A%0A%20%20%20%20%0A%20%20%20%20%40Around(%22doAspect()%22)%0A%20%20%20%20public%20Object%20methodMonitor(ProceedingJoinPoint%20pjp)%20throws%20Throwable%20%7B%0A%20%20%20%20%20%20%20%20if%20(testingMode)%20%7B%0A%20%20%20%20%20%20%20%20%20%20%20%20MethodSignature%20methodSignature%20%3D%20(MethodSignature)%20pjp.getSignature()%3B%0A%20%20%20%20%20%20%20%20%20%20%20%20Class%20type%20%3D%20methodSignature.getReturnType()%3B%0A%20%20%20%20%20%20%20%20%20%20%20%20if%20(type%20!%3D%20Void.TYPE)%20%7B%0A%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20return%20type.newInstance()%3B%0A%20%20%20%20%20%20%20%20%20%20%20%20%7D%0A%0A%20%20%20%20%20%20%20%20%7D%20else%20%7B%0A%20%20%20%20%20%20%20%20%20%20%20%20return%20pjp.proceed()%3B%0A%20%20%20%20%20%20%20%20%7D%0A%20%20%20%20%20%20%20%20return%20null%3B%0A%20%20%20%20%7D%0A%0A%7D%0A%60%60%60%0A%0A%0A%0A%0A%3E%20%E7%89%88%E6%9D%83%E5%A3%B0%E6%98%8E%EF%BC%9A%E6%9C%AC%E6%96%87%E4%B8%BA%E4%BA%BA%E5%B7%A5%E5%8D%9A%E5%AE%A2%E7%9A%84%E5%8E%9F%E5%88%9B%E6%96%87%E7%AB%A0%EF%BC%8C%E9%81%B5%E5%BE%AA%20CC%204.0%20BY-SA%20%E7%89%88%E6%9D%83%E5%8D%8F%E8%AE%AE%EF%BC%8C%E8%BD%AC%E8%BD%BD%E8%AF%B7%E9%99%84%E4%B8%8A%E5%8E%9F%E6%96%87%E5%87%BA%E5%A4%84%E9%93%BE%E6%8E%A5%E5%8F%8A%E6%9C%AC%E5%A3%B0%E6%98%8E%E3%80%82%0A%E6%9C%AC%E6%96%87%E9%93%BE%E6%8E%A5%EF%BC%9A%5Bhttps%3A%2F%2Fwww.gzcx.net%2Farticle%2F1734%5D(https%3A%2F%2Fwww.gzcx.net%2Farticle%2F1734)
正文到此结束
本文目录