zoukankan      html  css  js  c++  java
  • 关于component-scan中base-package包含通配符的问题探究

    今天在配置Spring的component-scan时,发现了一个有趣的问题。就是在指定base-package时,如果使用了星号通配符*,有时会出现类扫描不到的情况。下面研究一下这个问题。

    先介绍一下项目结构:
    为了演示,我在java文件夹下创建名为controller的包,并在该包下创建了一个名为IndexController的类。如图所示:


    先来看正常情况:
    在Spring配置文件中配置Component-Scan:
    <context:component-scan base-package="controller" />
    启动项目,访问localhost:8080/index.do,结果正常。

    但,当我把component-scan配置成这样时:
    <context:component-scan base-package="controller.*" />
    出现了404,说明Spring没有扫描到我的Controller,所以无法处理我们的请求。


    但,当我把component-scan配置成这样时:
    <context:component-scan base-package="controller.**" />
    又一切正常了。

    这是为啥呢,我们打个断点看一下:
    当base-package="controller"时,可见packageSearchPath为"classpath*:controller/**/*.class":
    这里写图片描述


    当base-package="controller.*"时,可见packageSearchPath为"classpath*:controller/*/**/*.class":

     
    当base-package="controller.**"时,可见packageSearchPath为"classpath*:controller/**/**/*.class":

     综上, 可以分析出,**匹配任意class文件和包,而*只能匹配包,因此无法扫描到包下的类,因此也就无法被Spring管理

    版权声明:本文为CSDN博主「陈夏明」的原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接及本声明。
    原文链接:https://blog.csdn.net/u012325167/article/details/75388990

    做产品的程序,才是好的程序员!
  • 相关阅读:
    区块链技术基础
    理解数字货币
    MySQL-插入更新 ON DUPLICATE KEY UPDATE
    Flume-Failover Sink Processor 故障转移与 Load balancing Sink 负载均衡
    Flume-Replicating Channel Selector 单数据源多出口
    Flume-几种拓扑结构
    Flume-事务与传输流程
    Java-JPDA 概述
    Navicat Premium
    Flume-Taildir Source 监控目录下多个文件的追加
  • 原文地址:https://www.cnblogs.com/asplover/p/12538993.html
Copyright © 2011-2022 走看看