为什么说要慎用SpringBoot @ComponentScan

 更新时间:2021年07月15日 10:05:47   作者:神韵499  
本文主要介绍了为什么说要慎用SpringBoot @ComponentScan,文中通过示例代码介绍的非常详细,需要的朋友们下面随着小编来一起学习学习吧

场景复现

为了统一定制一个过滤器(Filter),所以在另外一个工程里面创建了一个过滤器,并通过jar包的方法导入当前项目,通过@ComponentScan({"org.example.config"})指定扫描包路径。

下面的我的启动类

 导入的jar

问题

预期效果是这样,正常加载 

启动后,原来的Swagger目录进去是这样的,原来的Controller全部都没有被加载进来

解密

以为过滤器导致所有路径没有加载,后面百度了解BasicErrorController是在没有定义SwaggerConfig配置时默认的controller

那我的SwaggerConfig就没有生效了呀???

水落石出了,SwaggerConfig没有被加载到容器中,原来是启动类惹的货,为了加载一个启动类外的bean-MyFilterBean到容器中导致--启动类配置@ComponentScan({"org.example.config"})

如果启动类不加@ComponentScan注解,那它默认是扫描启动类及子包下的类。我这配置不就是改变了最初的功能吗,真的是基础不牢地洞山摇~~~

解决方案

1、多加个@ComponentScan,这样也扫描启动类及子包下的类了

2、直接将当前启动类路径加入扫描路径中

3、

在resourecs资源目录下创建META-INF文件夹,在文件夹中创建spring.factories文件

 文件内容:

org.springframework.boot.autoconfigure.EnableAutoConfiguration=\
org.example.config.MyFilterBean

启动后发现MyFilterBean也被加载到bean中了(在调用api时,通过日记/断点等验证) 

注:

由于直接在过滤器类上使用@Compont注解注册过滤器默认会过滤所有的URL请求生效,上面测试时都是为了方便。真实使用时,为了可以控制特定的URL才触发过滤器,我们通过FilterRegistrationBean来注册过滤器,过滤的URL模式通过FilterRegistrationBean类的addUrlPatterns方法设置,如下图所示:

到此这篇关于为什么说要慎用SpringBoot @ComponentScan的文章就介绍到这了,更多相关SpringBoot @ComponentScan 慎用内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • spring cloud服务之间的调用之ribbon详解

    spring cloud服务之间的调用之ribbon详解

    关于spring-cloud的服务调用,我们首先需要了解它的两个核心组件Ribbon和Feign。接下来通过本文给大家详细介绍spring-cloud服务之间的调用之ribbon,感兴趣的朋友一起看看吧
    2021-08-08
  • RabbitMQ 如何解决消息幂等性的问题

    RabbitMQ 如何解决消息幂等性的问题

    这篇文章主要介绍了RabbitMQ 如何解决消息幂等性的问题,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2021-07-07
  • springcloud微服务之Eureka配置详解

    springcloud微服务之Eureka配置详解

    这篇文章主要介绍了springcloud微服务之Eureka配置详解,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2020-08-08
  • Java Runnable和Thread实现多线程哪个更好你知道吗

    Java Runnable和Thread实现多线程哪个更好你知道吗

    这篇文章主要为大家详细介绍了Java Runnable和Thread实现多线程哪个更好,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下,希望能够给你带来帮助<BR>
    2022-03-03
  • JSP安全开发之XSS漏洞详解

    JSP安全开发之XSS漏洞详解

    XSS又叫CSS (Cross Site Script) ,跨站脚本攻击。它指的是恶意攻击者往Web页面里插入恶意脚本代码,而程序对于用户输入内容未过滤,当用户浏览该页之时,嵌入其中Web里面的脚本代码会被执行,从而达到恶意攻击用户的特殊目的。
    2016-09-09
  • Java中数据库加密的方式分享

    Java中数据库加密的方式分享

    在现今互联网时代,数据安全已经成为了我们必须要面对的重要课题,在本文中,我们将会介绍Java中常用的几种数据库加密方式并分析一下它们的优缺点,希望对大家有所帮助
    2023-05-05
  • java实现翻转单词顺序列

    java实现翻转单词顺序列

    这篇文章主要为大家详细介绍了java实现翻转单词顺序列,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2019-03-03
  • elasticsearch集群cluster discovery可配式模块示例分析

    elasticsearch集群cluster discovery可配式模块示例分析

    这篇文章主要为大家介绍了elasticsearch集群cluster discovery可配式模块示例分析,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2022-04-04
  • Java jvm垃圾回收详解

    Java jvm垃圾回收详解

    这篇文章主要介绍了JVM的垃圾回收总结,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2021-10-10
  • Java使用正则表达式截取重复出现的XML字符串功能示例

    Java使用正则表达式截取重复出现的XML字符串功能示例

    这篇文章主要介绍了Java使用正则表达式截取重复出现的XML字符串功能,涉及java针对xml字符串及指定格式字符串的正则匹配相关操作技巧,需要的朋友可以参考下
    2017-08-08

最新评论