ProceedingJoinPoint joinPoint Api使用

 @Around("myPointcut()")
    public Integer AroundSave(ProceedingJoinPoint joinPoint) throws Throwable {
        /*1、获取目标方法的参数:save(new User()),此时user对象可以获取到*/
        Object[] args = joinPoint.getArgs();
        System.out.println("这是joinPoint的Api开始--------------------");
        System.out.println("打印目标方法参数列表args ="+ Arrays.toString(args));
        /*2、可以获取到目标方法的反射对象Method*/
        MethodSignature methodSignature = (MethodSignature) joinPoint.getSignature();
        Method method = methodSignature.getMethod();
        System.out.println("获取目标方法的对象名称:"+method);
        /*2.1、由method反射对象获取基本信息*/

        Class<?> declaringClass = method.getDeclaringClass();
        String className = declaringClass.getName();
        System.out.println("获取类名"+className);



        System.out.println("环绕通知开始");


         Integer result= (Integer) joinPoint.proceed();

        System.out.println("环绕通知结束");
        return result;
    }

在这里插入图片描述

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
按下面代码统计接口调用的次数:@Order(999) @Aspect @Component public class MonitorAspect { @Autowired private RabbitTemplate rabbitTemplate; @Pointcut("@annotation(com.sinosoft.common.messagestorage.annotation.Monitor)") public void monitorPointcut(){} @Around("monitorPointcut()") public Object monitor(ProceedingJoinPoint joinPoint) throws Throwable { // 获取方法参数和注解信息 MethodSignature signature = (MethodSignature) joinPoint.getSignature(); Method method = signature.getMethod(); Object[] args = joinPoint.getArgs(); ServletRequestAttributes requestAttributes = (ServletRequestAttributes) RequestContextHolder.getRequestAttributes(); Monitor monitor = method.getAnnotation(Monitor.class); // 记录监控信息 String requestUrl = requestAttributes.getRequest().getRequestURI(); String serviceName = method.getDeclaringClass().getSimpleName() + "." + method.getName(); String source = args.length > 0 ? args[0].toString() : ""; long startTime = System.currentTimeMillis(); int status = 200; Object result = null; try { result = joinPoint.proceed(); } catch (Exception e) { status = 500; throw e; } finally { long endTime = System.currentTimeMillis(); monitor(serviceName, source, status, startTime, endTime); } // 返回方法结果 return result; } private void monitor(String serviceName, String source, int status, long startTime, long endTime) { // 记录监控信息 Message message = new Message(); message.setServiceName(serviceName); message.setSource(source); message.setStatus(status); message.setStartTime(startTime); message.setEndTime(endTime); // 发送消息到MQ rabbitTemplate.setExchange("monitor.queue.test"); rabbitTemplate.setRoutingKey("monitorRoutingKey"); rabbitTemplate.convertAndSend(message); // rabbitTemplate.convertAndSend("monitor.queue.test", "monitorRoutingKey", message); } }
06-08

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Code攻城狮

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值