问题
程序运行后报如下错误:
org.springframework.beans.factory.BeanCreationException:
Error creating bean with name 'resourceHandlerMapping' defined in class path resource [org/springframework/web/servlet/config/annotation/DelegatingWebMvcConfiguration.class]: Bean instantiation via factory method failed;
nested exception is org.springframework.beans.BeanInstantiationException: Failed to instantiate [org.springframework.web.servlet.HandlerMapping]: Factory method 'resourceHandlerMapping' threw exception;
nested exception is java.lang.IllegalStateException: No ServletContext set
排查与解决
谷歌了一番,并没有找到确切的解决方法,导致这个问题的根本原因应该是某个地方依赖了webMvc,但程序有没有开启webMvc支持。
想起前阵子加了一个配置:web-application-type:none
——因为我的程序只是一个定时任务,并不需要webMvc,于是先将该配置注释掉,再运行看看,果然,这回的错误信息变成了swagger缺少端口号配置之类的信息。——这样说来,是哪个地方把程序不需要的swagger引进来了,导致程序依赖webMvc。
查看程序的maven dependencies,发现是引入的common模块包含了swagger,于是在该子模块pom中添加并排除依赖swagger,同步maven,clean+install,重新运行,问题解决。