SpringBoot2.0集成Swagger2訪(fǎng)問(wèn)404的解決操作
最近使用最新的SpringBoot2.0集成Swagger2的時(shí)候遇到一個(gè)問(wèn)題,集成之后打開(kāi)Swagger頁(yè)面的時(shí)候出現(xiàn)404,后臺(tái)提示找不到swagger-ui的頁(yè)面。
于是我看了下項(xiàng)目依賴(lài)swagger的結(jié)構(gòu):

可以看到 swagger-ui.html 在META-INF/resources目錄下,所以我們需要手動(dòng)的將靜態(tài)資源路徑指向這里,在java中配置為:
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
import org.springframework.web.servlet.config.annotation.ResourceHandlerRegistry;
import org.springframework.web.servlet.config.annotation.WebMvcConfigurationSupport;
import springfox.documentation.builders.ApiInfoBuilder;
import springfox.documentation.builders.PathSelectors;
import springfox.documentation.builders.RequestHandlerSelectors;
import springfox.documentation.service.ApiInfo;
import springfox.documentation.spi.DocumentationType;
import springfox.documentation.spring.web.plugins.Docket;
import springfox.documentation.swagger2.annotations.EnableSwagger2;
/**
* @author xiaqing
*/
@Configuration
@EnableSwagger2
public class SwaggerConfig extends WebMvcConfigurationSupport {
@Bean
public Docket createRestApi() {
return new Docket(DocumentationType.SWAGGER_2)
.apiInfo(apiInfo())
.select()
.apis(RequestHandlerSelectors.basePackage("com.xqnode.controller"))
.paths(PathSelectors.any())
.build();
}
private ApiInfo apiInfo() {
return new ApiInfoBuilder()
.title("接口總覽")
.description("測(cè)試")
.version("1.0")
.build();
}
/**
* 防止@EnableMvc把默認(rèn)的靜態(tài)資源路徑覆蓋了,手動(dòng)設(shè)置的方式
*
* @param registry
*/
@Override
protected void addResourceHandlers(ResourceHandlerRegistry registry) {
// 解決靜態(tài)資源無(wú)法訪(fǎng)問(wèn)
registry.addResourceHandler("/**").addResourceLocations("classpath:/static/");
// 解決swagger無(wú)法訪(fǎng)問(wèn)
registry.addResourceHandler("/swagger-ui.html").addResourceLocations("classpath:/META-INF/resources/");
// 解決swagger的js文件無(wú)法訪(fǎng)問(wèn)
registry.addResourceHandler("/webjars/**").addResourceLocations("classpath:/META-INF/resources/webjars/");
}
}
在swagger的配置類(lèi)中繼承WebMvcConfigurationSupport,實(shí)現(xiàn)addResourceHandlers方法,設(shè)置靜態(tài)資源可訪(fǎng)問(wèn)。
設(shè)置完成后重啟項(xiàng)目,就可以通過(guò) http://localhost:8080/swagger-ui.html 正常訪(fǎng)問(wèn)了。
===== 2019.03.13更新 =====
有的同學(xué)說(shuō)配置swagger后靜態(tài)資源目錄無(wú)法訪(fǎng)問(wèn),我自己試了下,確實(shí)訪(fǎng)問(wèn)不了。原來(lái)的配置是:
@Override
protected void addResourceHandlers(ResourceHandlerRegistry registry) {
// 解決swagger無(wú)法訪(fǎng)問(wèn)
registry.addResourceHandler("/**").addResourceLocations("classpath:/META-INF/resources/").setCachePeriod(0);
}
這里是將所有的請(qǐng)求都指向了META-INF/resources/目錄,顯然是不對(duì)的,會(huì)導(dǎo)致項(xiàng)目的其他靜態(tài)文件目錄無(wú)法正常訪(fǎng)問(wèn),于是做了修改:
@Override
protected void addResourceHandlers(ResourceHandlerRegistry registry) {
// 解決靜態(tài)資源無(wú)法訪(fǎng)問(wèn)
registry.addResourceHandler("/**")
.addResourceLocations("classpath:/static/");
// 解決swagger無(wú)法訪(fǎng)問(wèn)
registry.addResourceHandler("/swagger-ui.html")
.addResourceLocations("classpath:/META-INF/resources/");
// 解決swagger的js文件無(wú)法訪(fǎng)問(wèn)
registry.addResourceHandler("/webjars/**")
.addResourceLocations("classpath:/META-INF/resources/webjars/");
}
測(cè)試一下:
在resource的static文件夾下新建index.html

啟動(dòng)項(xiàng)目訪(fǎng)問(wèn) http://localhost:8080/index.html

訪(fǎng)問(wèn)正常,接下來(lái)再訪(fǎng)問(wèn)swagger:

也是正常的。
以上這篇SpringBoot2.0集成Swagger2訪(fǎng)問(wèn)404的解決操作就是小編分享給大家的全部?jī)?nèi)容了,希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
相關(guān)文章
Java如何獲取HttpServletRequest請(qǐng)求參數(shù)
我們常需要接口接收第三方推送的數(shù)據(jù),由于第三方可能不具備開(kāi)發(fā)能力,我們需要自行解析推送的數(shù)據(jù)格式,通過(guò)HttpServletRequest,我們可以解析字符串、JSON、XML以及文件等多種數(shù)據(jù)類(lèi)型,本文介紹了如何在Java中使用HttpServletRequest獲取請(qǐng)求參數(shù),感興趣的朋友一起看看吧2024-11-11
JDK數(shù)組阻塞隊(duì)列源碼深入分析總結(jié)
在這篇文章當(dāng)中,我們將通過(guò)源碼仔細(xì)為大家介紹一下JDK具體是如何實(shí)現(xiàn)數(shù)組阻塞隊(duì)列的,文中的示例代碼講解詳細(xì),感興趣的可以了解一下2022-08-08
SpringBoot多數(shù)據(jù)源配置的全過(guò)程記錄
在用SpringBoot開(kāi)發(fā)項(xiàng)目時(shí),隨著業(yè)務(wù)量的擴(kuò)大,我們通常會(huì)進(jìn)行數(shù)據(jù)庫(kù)拆分或是引入其他數(shù)據(jù)庫(kù),從而我們需要配置多個(gè)數(shù)據(jù)源,下面這篇文章主要給大家介紹了關(guān)于SpringBoot多數(shù)據(jù)源配置的相關(guān)資料,需要的朋友可以參考下2021-11-11
java 查找list中重復(fù)數(shù)據(jù)實(shí)例詳解
這篇文章主要介紹了java 查找list中重復(fù)數(shù)據(jù)實(shí)例詳解的相關(guān)資料,需要的朋友可以參考下2017-01-01
JAVA實(shí)現(xiàn)Excel和PDF上下標(biāo)的操作代碼
這篇文章主要介紹了JAVA實(shí)現(xiàn)Excel和PDF上下標(biāo),本文通過(guò)示例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2023-09-09

