demo项目包扫描配置如下(部分):
@Configuration
@ComponentScan(basePackages = {"org.jackson.mvc.web"},
excludeFilters = {@ComponentScan.Filter(type = FilterType.ANNOTATION, classes = {WebFilter.class})})
@EnableWebMvc
public class ServletConfig implements WebMvcConfigurer
新增的类如下:
org.jackson.mvc.web.controllers.simple.LogLevelController
//配置代码
@Controller
@RequestMapping(path = "v1/logger/")
public class LogLevelController
这个demo我之前用的好好的,闲置了一两周。最近想写一些新的东西所以新增了一个Controller,一切逻辑写完想要测试一下,访问居然报404(小朋友你是不是有很多问号)?跟踪了一下发现我新增的Controller和对应的方法并没有在Spring容器中,但是之前的又是都在的(我丢!)。再次看了Spring的官网相关知识点确定之前的配置没有问题,也去度娘上搜索了半天无结果,差一点怀疑人生........。然后看到项目的target目录,心想会不会是新增的类没有被build到classpath路径下,看一下果然没有我新增的class文件。检查IDEA(我使用的是2018版本)Tomcat(版本9.0)的配置,配置如下:
使用默认配置按理说每次运行的时候都会重新Build一次我们的工程(除非你把上面的两个配置都删除了),但是从最终的结果来看好像并没有Rebuild我的工程,导致我新增的类没有被编译到classpath路径下。使用mvn clean命令清除target目录后重新启动Tomcat再次访问一切回到正常。不小心就踩到一个小坑了,在此记录一下^ - ^。