《Spring Boot开发:从0到1》第13章 常见问题与解决

作者: 光剑书架上的书 | 来源:发表于2017-04-23 02:05 被阅读530次

    第13章 常见问题与解决方案

    13.1 Spring MVC 关于controller的字符编码
    13.2 Spring Boot启动报错
    13.3 javax.servlet.ServletException
    13.4 库依赖冲突问题
    13.5 org.apache.catalina.LifecycleException
    13.6 @EnableMongoRepositories路径配置
    13.7 Logging system failed to initialize using configuration from 'logback.xml '
    13.8 java.lang.IllegalArgumentException: Request header is too large

    13.9 No handler found for GET /swagger-ui.html

    我们在使用SpringBoot集成Swagger2中,访问:http://127.0.0.1:8188/swagger-ui.html

    问题描述

    可能出现两种错误:
    1.页面显示默认报错页面。后台报错:

    No handler found for GET /swagger-ui.html
    

    2.显示Swagger空白页面:

    后台报错:

    No mapping found for HTTP request with URI [/swagger-resources/configuration/ui] in DispatcherServlet with name 'dispatcherServlet'
    

    解决方案

    这个错误,是因为资源映射问题导致。
    我们在访问http://127.0.0.1:8188/swagger-ui.html 时,这个swagger-ui.html相关的所有前端静态文件都在springfox-swagger-ui-2.6.1.jar里面。目录如下:

    Spring Boot自动配置本身不会自动把/swagger-ui.html这个路径映射到对应的目录META-INF/resources/下面。我们加上这个映射即可。代码如下:

    @Configuration
    class WebMvcConfig extends WebMvcConfigurerAdapter {
        @Override
        void addResourceHandlers(ResourceHandlerRegistry registry) {
            registry.addResourceHandler("swagger-ui.html")
                    .addResourceLocations("classpath:/META-INF/resources/")
    
            registry.addResourceHandler("/webjars/**")
                    .addResourceLocations("classpath:/META-INF/resources/webjars/")
        }
    
    
    }
    

    同时,在启动类上添加注解@EnableWebMvc。完整的Spring Boot集成Swagger2构建自动化Rest API文档工程示例,源码参考:

    当然,为了更加方便使用SpringBoot集成swagger,这个工作可以直接通过定制swagger-starter来完成。

    相关文章

      网友评论

        本文标题:《Spring Boot开发:从0到1》第13章 常见问题与解决

        本文链接:https://www.haomeiwen.com/subject/rbuezttx.html