Springboot aop不起作用的问题

最近在研究Springboot切面编程,碰到一个莫名其妙的问题,aop怎么都不起作用。自定义的注解使用到了aop,却是有效的。

网上查找了几个小时, 各种方式都试了(使用的是InteliJ IDEA编辑器)。

首先确认了pom.xml文件里是载入了aop的

其次,确认了切面类是没有问题的,

package com.jeealfa.aspect;

import org.aspectj.lang.JoinPoint;
import org.aspectj.lang.annotation.*;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;

import org.springframework.stereotype.Component;
import org.springframework.web.context.request.RequestContextHolder;
import org.springframework.web.context.request.ServletRequestAttributes;

import javax.servlet.http.HttpServletRequest;

@Aspect
@Component
public class AopLog {
    private Logger log = LoggerFactory.getLogger(this.getClass());

    //线程局部变量,用于解决多线程中相同变量的访问冲突问题
    ThreadLocal<Long> startTime = new ThreadLocal<>();

    @Pointcut("execution(* com.jeealfa.controller..*.*(..))")
    public void aopWebLog() {

    }

    @Before("aopWebLog()")
    public void doBefore(JoinPoint joinPoint) throws Throwable {
        startTime.set(System.currentTimeMillis());
        //接手到请求,记录请求内容
        ServletRequestAttributes attributes = (ServletRequestAttributes) RequestContextHolder.getRequestAttributes();
        HttpServletRequest request = attributes.getRequest();

        log.info("URL:" + request.getRequestURI().toString());
        log.info("HTTP Method:" + request.getMethod());
        log.info("IP:" + request.getRemoteAddr());
        log.info("类的方法:" + joinPoint.getSignature().getDeclaringTypeName() + "." + joinPoint.getSignature().getName());
        log.info("参数:" + request.getQueryString());
        System.out.println(request.getRequestURI().toString());
    }
}

再次,根据网上查的资料在启动类加了注解,且aspect文件夹与JeealfaBootApplication处于平级

package com.jeealfa;



import org.springframework.boot.SpringApplication;

import org.springframework.boot.autoconfigure.SpringBootApplication;

import org.springframework.context.annotation.ComponentScan;

import org.springframework.context.annotation.EnableAspectJAutoProxy;



@SpringBootApplication

@EnableAspectJAutoProxy(proxyTargetClass=true)

@ComponentScan({"com.jeealfa.*"})

public class JeealfaBootApplication {



public static void main(String[] args) {

SpringApplication.run(JeealfaBootApplication.class, args);

}

}

 

实际@SpringBootApplication包含了@CompentScan

另外,HelloController类hello方法如下

package com.jeealfa.controller; 

import lombok.extern.slf4j.Slf4j; 
import org.springframework.web.bind.annotation.GetMapping; 
import org.springframework.web.bind.annotation.RestController; 
import java.util.HashMap; 

@RestController 
@Slf4j 
public class HelloController { 

    @GetMapping("/hello") 
    public String hello(){ return "hello world"; } 
}

网上各种方法都试了, aop就是始终不起作用。 运行 /hello时,AopLog里的doBefore方法始终没有运行。并且发现一个奇怪现象,其他文件修改,springboot的热启动都会自动更新启动,修改这个切面类时,却无反应。

不过最终经过多次折腾终于发现了问题所在。

在创建这个切面类时,直接选择了 Aspect, 见下图

 

创建了之后, 然后在把aspect修改为class,

修改为class后,左边最前面的A标会自动变成C标,这样就跟从Java Class创建的切面类看起来一模一样,但就是不起作用。

 

正确的做法: 通过Java Class创建aspect类,然后加上 @Aspect和@Component注解。 我试了从Java Class创建aspect类,把之前无效的代码完整拷贝到这个新建的文件里,就生效了。至于上面那种创建aspect类为何会导致无效的内在原因,还不清楚,有知情的朋友请留言回复。 虽然两种创建方式不同,但最终代码呈现完全是一样的,就是一个有用一个无用。

 

 

  • 3
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 3
    评论
Spring BootAOP不生效时,可能有以下几个原因: 1. 切面定义错误:确保正确定义切面,并且切面的注解和切点的表达式是正确的。可以参考的内容来解决这个问题。 2. Bean没有被Spring管理:如果切面所在的Bean没有被Spring管理,那么AOP将无法生效。请确保切面所在的Bean已经添加了@Component或者其他相关的注解来让Spring管理。 3. 配置问题:可能是由于配置问题导致AOP不生效。请确保在Spring Boot的配置文件中已经开启了AOP的自动代理功能。例如,在application.properties文件中添加"spring.aop.auto=true"。 4. 包扫描问题:请确保切面所在的包已经被正确地配置在Spring Boot的包扫描范围内。如果切面所在的包没有被扫描到,那么AOP将无法生效。 5. 方法访问权限问题:请确保被切面拦截的方法是public的,否则AOP将无法生效。如果方法的访问权限不是public,那么切面将无法拦截到该方法的调用。 请根据上述问题逐一排查,以确保Spring BootAOP能够正常生效。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* [解决springbootaop切面不起作用问题(失效的排查)](https://download.csdn.net/download/weixin_38607311/12725893)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 33.333333333333336%"] - *2* [SpringBootAop失效解决办法](https://blog.csdn.net/liuchongming/article/details/117469977)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 33.333333333333336%"] - *3* [spring boot实现声明式事物的三种方式以及spring aop事物不生效问题的解决](https://blog.csdn.net/u012643122/article/details/106686859)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 33.333333333333336%"] [ .reference_list ]
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值