aop切面重复调用两次controller

在AOP的@Around注解中误用 ProceedingJoinPoint.proceed() 导致Controller方法被调用两次。解决方法是只调用一次proceed()并将返回值赋给变量,避免重复执行。寻求原因。
摘要由CSDN通过智能技术生成

最近在测试接口时,总是调用两次,于是在aop找原因

错误原因:在aop的@Around这个接口中出现了两次ProceedingJoinPoint.proceed(),于是我将该信息赋值给一个变量,后调用这个变量即可解决。

ProceedingJoinPoint.proceed()使用多少次,则会调用controller多少次!!!

因为不知其所以然,还请了解原因的前辈们告知原因。

附上代码

@Aspect
@Component
public class HttpLoggerRespect {

    private final Logger logger = LoggerFactory.getLogger(HttpLoggerRespect.class);

    @Pointcut("execution(public * com.bigdata.bigdata.controller..*(..))")
    public void logPointCut() {
        logger.debug("审计使用");
    }

	@Around("logPointCut()")
    public Object doAround(ProceedingJoinPoint pjp) throws Throwable {
        RequestAttributes ra = RequestContextHolder.getRequestAttributes();

		// result的值就是被拦截方法的返回值
		Object result =pjp.proceed(); ///错误原因导致1
		System.out.prin
  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
要获取注解中自定义的值,可以使用反射的方式获取注解对象,并调用注解对象的方法获取值。具体步骤如下: 1. 定义一个自定义注解,例如 @MyAnnotation,并在注解中添加自定义属性,例如 value。 2. 在需要使用注解的地方(例如方法、类、参数等)上添加 @MyAnnotation 注解,并设置属性值。 3. 定义一个切面类,使用 @Aspect 注解标记类为切面,并在需要拦截的方法上添加切点表达式,例如 @Around。 4. 在切面方法中,通过 JoinPoint 获取目标方法,然后使用反射获取方法上的注解,从而获取注解中的属性值。 示例代码如下: ```java @Retention(RetentionPolicy.RUNTIME) @Target(ElementType.METHOD) public @interface MyAnnotation { String value(); } @Aspect @Component public class MyAspect { @Around("@annotation(com.example.MyAnnotation)") public Object around(ProceedingJoinPoint point) throws Throwable { MethodSignature signature = (MethodSignature) point.getSignature(); Method method = signature.getMethod(); MyAnnotation annotation = method.getAnnotation(MyAnnotation.class); String value = annotation.value(); // TODO: 处理注解值 return point.proceed(); } } @Controller public class UserController { @GetMapping("/users/{id}") @MyAnnotation("user_id") public String getUser(@PathVariable Long id) { // ... } } ``` 在上面的示例中,我们定义了一个 @MyAnnotation 注解,并在注解中添加了一个 value 属性。我们在 UserController 的 getUser 方法上添加了 @MyAnnotation 注解,并设置了 value 属性为 "user_id"。 然后,在 MyAspect 类中,我们定义了一个切面方法,使用 @Around 注解指定需要拦截的方法,并使用 @annotation(com.example.MyAnnotation) 表达式获取被 @MyAnnotation 注解修饰的方法。我们通过反射获取方法上的注解,并调用注解对象的 value() 方法获取 value 属性的值,最终可以进行处理。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值