Spring Bootは静的資源にアクセスできません.
3893 ワード
Spring Boot 2.xに基づいて,いくつかの列依存性と配置を加えた後,工学は静的資源にアクセスできないことが分かった.調査の結果、Swaggarを導入する際に静的リソースプロセッサが修正されたため、静的リソースがアクセスできなくなりました.
Springbootは静的リソースにアクセスできません.
検査で自分でswaggarを設置していることが分かりました.静的資源プロセッサを修正しました.
私の静的な資源は全部staticファイルに添付されていますので、静的な資源経路を追加します. classipath:/static/最後のswagger配置のプロファイルは以下の通りです.
springbootはデフォルトで建設された泰資源はstaticフォルダの下に置くとアクセスできます.
したがって、自分のspringbootにアクセスできません.まず、他のコンポーネントを自分で構成しているかどうかチェックしてから、静的リソースプロセッサを修正しました.
Springbootは静的リソースにアクセスできません.
検査で自分でswaggarを設置していることが分かりました.静的資源プロセッサを修正しました.
@Override
protected void addResourceHandlers(ResourceHandlerRegistry registry) {
registry.addResourceHandler("swagger-ui.html")
.addResourceLocations("classpath:/META-INF/resources/");
registry.addResourceHandler("/webjars/**")
.addResourceLocations("classpath:/META-INF/resources/webjars/");
}
解決策私の静的な資源は全部staticファイルに添付されていますので、静的な資源経路を追加します. classipath:/static/最後のswagger配置のプロファイルは以下の通りです.
springbootはデフォルトで建設された泰資源はstaticフォルダの下に置くとアクセスできます.
したがって、自分のspringbootにアクセスできません.まず、他のコンポーネントを自分で構成しているかどうかチェックしてから、静的リソースプロセッサを修正しました.
import static springfox.documentation.schema.AlternateTypeRules.newRule;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
import org.springframework.http.ResponseEntity;
import org.springframework.web.context.request.async.DeferredResult;
import org.springframework.web.servlet.config.annotation.ResourceHandlerRegistry;
import org.springframework.web.servlet.config.annotation.WebMvcConfigurationSupport;
import com.fasterxml.classmate.TypeResolver;
import springfox.documentation.builders.ApiInfoBuilder;
import springfox.documentation.builders.PathSelectors;
import springfox.documentation.builders.RequestHandlerSelectors;
import springfox.documentation.schema.WildcardType;
import springfox.documentation.service.ApiInfo;
import springfox.documentation.service.Contact;
import springfox.documentation.spi.DocumentationType;
import springfox.documentation.spring.web.plugins.Docket;
import springfox.documentation.swagger2.annotations.EnableSwagger2;
@Configuration
@EnableSwagger2
public class Swagger2Config extends WebMvcConfigurationSupport {
@Autowired
private TypeResolver typeResolver;
@Bean
public Docket productApi() {
return new Docket(DocumentationType.SWAGGER_2)
.select()
.apis(RequestHandlerSelectors.basePackage("com.tianyuan.statistics.controller"))
.paths(PathSelectors.any())
.build()
.apiInfo(metaData())
.alternateTypeRules( // , DeferredResult, json
newRule(typeResolver.resolve(DeferredResult.class,
typeResolver.resolve(ResponseEntity.class, WildcardType.class)),
typeResolver.resolve(WildcardType.class)))
;
}
private ApiInfo metaData() {
return new ApiInfoBuilder()
.title("REST API")
.description("\"REST API for Online Store\"")
.version("1.0.0")
.license("Apache License Version 2.0")
.licenseUrl("https://www.apache.org/licenses/LICENSE-2.0\"")
.contact(new Contact("myname", "", "[email protected]"))
.build();
}
@Override
protected void addResourceHandlers(ResourceHandlerRegistry registry) {
registry.addResourceHandler("swagger-ui.html")
.addResourceLocations("classpath:/META-INF/resources/");
registry.addResourceHandler("/webjars/**")
.addResourceLocations("classpath:/META-INF/resources/webjars/");
// *** , static ***
registry.addResourceHandler("/**")
.addResourceLocations("classpath:/static/");
}
}