Springboot 拦截注解或方法 在普通类上不起作用 解决方法

30 篇文章 0 订阅
21 篇文章 0 订阅

https://www.cnblogs.com/yjmyzz/p/why-spring-aop-does-not-work.html

具体原因就是AOP的实现有二类,如果是基于接口的,会采用动态代理,生成一个代理类,如果是基于类的,会采用CGLib生成子类,然后在子类中扩展父类中的方法。

而普通的类并不是接口,所以aop并没起作用。

解决方法:

(1)通过注解将该类进行注入,然后在调用处使用注入的类

(1)首先是自定义注解

@Target({ElementType.METHOD,ElementType.TYPE})
@Retention(RetentionPolicy.RUNTIME)
public @interface WatcherInterface {
    /**
     * 功能描述
     */
    String description() default "";

    /**
     * 接受信息的手机号,中间用|隔开
     */
    String phone() default "18539270747|13610438456";
}

(2)定义切面 

@Aspect
@Component
@Slf4j
public class WatcherAdvice {

    @Pointcut("xxx.WatcherInterface")
    private void watchInter() {

    }
}

 (3)给需要用的地方加上注解,这里我注解打在了普通的方法上,因此需要将该类交由spring管理

@Slf4j
@Component
public class ExternalDataInterface {

    /**
     * 功能描述 通过车牌号获取保单信息
     *
     * @param licenseNo 车牌号
     * @param specifiedTime 报案日期
     * @date 2020/9/14 14:17
     */
    @WatcherInterface(description = "通过车牌号和报案日期获取保单信息")
    public List<LocalIds> getPolicyInfoForMy(String licenseNo,String specifiedTime){
       //具体内容省略。。。。
    }

}

(4)在用的地方必须通过注解注入进来 ,此处我是在controller层调用的,因此代码是下面的

@RequestMapping("/external")
@RestController
@Slf4j
public class ExternalInterfaceController extends BaseController {
    @Resource
    private ExternalDataInterface externalDataInterface;

   @PostMapping("listReportCaseInfos")
    public Map listReportCaseInfos() {
        return responseOk(externalDataInterface.getPolicyInfoForMy('A','B'), "获取数据成功");
    }


}

(2)通过ApplicationContext.getBean()获取制定注解的类,原理与上面相同

(3)利用AopContext

XXClass xx = (XXclass)AopContext.currentProxy();

不过这个方法要注意的是,主类入口上,必须加上exporseProxy=true,参考下图:

@SpringBootApplication(scanBasePackages = "cn.com.xx.pv.**")
@MapperScan("cn.com.xx.pv.mapper")
@EnableTransactionManagement
@EnableAspectJAutoProxy(exposeProxy = true)
public class PvApplication {
    public static void main(String[] args) {
        ApplicationContextManager.setApplicationContext(SpringApplication.run(PvApplication.class, args));
    }

}

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
在 Spring Boot 中,我们可以使用注解来定义拦截器。 首先,我们需要创建一个拦截器类,并实现 `HandlerInterceptor` 接口。例如: ```java import org.springframework.web.servlet.HandlerInterceptor; import org.springframework.web.servlet.ModelAndView; import javax.servlet.http.HttpServletRequest; import javax.servlet.http.HttpServletResponse; public class MyInterceptor implements HandlerInterceptor { @Override public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) throws Exception { // 在请求处理之前进行拦截处理 return true; // 返回 true 表示继续执行后续的拦截器或请求处理,返回 false 则表示中断请求处理 } @Override public void postHandle(HttpServletRequest request, HttpServletResponse response, Object handler, ModelAndView modelAndView) throws Exception { // 在请求处理之后、视图渲染之前进行拦截处理 } @Override public void afterCompletion(HttpServletRequest request, HttpServletResponse response, Object handler, Exception ex) throws Exception { // 在整个请求完成之后进行拦截处理,可以用来释放资源等操作 } } ``` 接下来,我们可以使用 `@Configuration` 注解创建一个配置类,然后通过 `addInterceptors()` 方法拦截器注册到拦截器链中。例如: ```java import org.springframework.context.annotation.Configuration; import org.springframework.web.servlet.config.annotation.InterceptorRegistry; import org.springframework.web.servlet.config.annotation.WebMvcConfigurer; @Configuration public class MyInterceptorConfig implements WebMvcConfigurer { @Override public void addInterceptors(InterceptorRegistry registry) { registry.addInterceptor(new MyInterceptor()) .addPathPatterns("/**"); // 设置拦截路径 } } ``` 在上述示例中,我们创建了一个名为 `MyInterceptorConfig` 的配置类,并通过 `addInterceptors()` 方法将 `MyInterceptor` 拦截器添加到拦截器链中,并设置了拦截的路径为 "/*",即匹配所有请求路径。 这样,当请求进入时,会首先经过拦截器的 `preHandle()` 方法,在请求处理前进行拦截处理。如果 `preHandle()` 方法返回 true,则继续执行后续的拦截器或请求处理;如果返回 false,则中断请求处理。 需要注意的是,拦截器的注册顺序与执行顺序是相关的,可以通过 `addInterceptor()` 方法的顺序来确定拦截器的执行顺序。 希望对你有帮助!如果还有其他问题,请随时提问。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值