1.描述
我用springboot整合了swagger,同時又做了文件上傳的功能。代碼如下(代碼功能沒有問題,已測試過):
//文件上傳
@Api(value = "文件上傳", description = "文件上傳API")
@RestController
public class UploadController {
@Autowired
private FileUploadService fileUploadService;
@ApiOperation(value = "文件上傳", notes = "文件上傳")
@RequestMapping(value = "/api/upload", method = RequestMethod.POST, consumes = "multipart/form-data")
public RestResult upload(@RequestParam MultipartFile file) {
String fileFullPath = fileUploadService.upload(file);
return RestResultGenerator.getSuccessResult(fileFullPath);
}
}
//swagger2配置
@ConditionalOnProperty(prefix = "swagger2", value = {"enable"}, havingValue = "1")
@EnableSwagger2
@Configuration
public class Swagger2Config {
@Bean
public Docket createRestApi() {
return new Docket(DocumentationType.SWAGGER_2)
.apiInfo(apiInfo())
.select()
.apis(RequestHandlerSelectors.basePackage("com.freedom.clothing.controller"))
.paths(PathSelectors.any())
.build();
}
private ApiInfo apiInfo() {
return new ApiInfoBuilder()
.title("Restful API列表")
.contact(new Contact("xx", "", ""))
.version("1.0")
.description("")
.build();
}
}
//DisPatcherServlet配置
@Configuration
@EnableWebMvc//(【開啟,會攔截swagger2頁面】【不開啟,文件上傳不了】)
public class WebMVCConfig extends WebMvcConfigurerAdapter {
@Bean
public CommonsMultipartResolver multipartResolver() {
CommonsMultipartResolver resolver = new CommonsMultipartResolver();
resolver.setDefaultEncoding("utf-8");
resolver.setMaxInMemorySize(40960);
resolver.setMaxUploadSize(10485760);
return resolver;
}
}
2.我遇到的問題
①但是,當我開啟@EnableWebMvc注解時,文件能夠上傳,但是swagger2訪問不了。
②而關(guān)閉@EnableWebMvc注解時,swagger2能訪問,文件上傳不了,壓根就不進入upload方法,拋出org.springframework.web.HttpMediaTypeNotSupportedException異常。
3.我想問的問題
我排查到這個原因花了很長時間,之前一直以為是上傳哪里出了問題。
我的思考:
上面加@EnableWebMvc時,顯然swagger的靜態(tài)資源被攔截了,不加@EnableWebMvc就不攔截。
①不都是設(shè)置的DispatcherServlet嗎,兩種情況的mapping映射不同嗎?
②@EnableWebMvc到底起什么作用?為什么有時加或不加貌似都沒什么影響(應該跟springboot的@EnableAutoConfiguration沒什么關(guān)系吧,我沒開啟這個注解)?
開啟@EnableWebMvc時,加入以下代碼,讓DispatcherServlet不攔截swagger的靜態(tài)資源就行了。
/**
* 過濾Swagger2的靜態(tài)資源
*/
@Override
public void addResourceHandlers(ResourceHandlerRegistry registry) {
registry.addResourceHandler("swagger-ui.html")
.addResourceLocations("classpath:/META-INF/resources/");
registry.addResourceHandler("/webjars/**")
.addResourceLocations("classpath:/META-INF/resources/webjars/");
}
至于@EnableWebMvc到底做了些什么事情,我還沒搞清楚。
北大青鳥APTECH成立于1999年。依托北京大學優(yōu)質(zhì)雄厚的教育資源和背景,秉承“教育改變生活”的發(fā)展理念,致力于培養(yǎng)中國IT技能型緊缺人才,是大數(shù)據(jù)專業(yè)的國家
達內(nèi)教育集團成立于2002年,是一家由留學海歸創(chuàng)辦的高端職業(yè)教育培訓機構(gòu),是中國一站式人才培養(yǎng)平臺、一站式人才輸送平臺。2014年4月3日在美國成功上市,融資1
北大課工場是北京大學校辦產(chǎn)業(yè)為響應國家深化產(chǎn)教融合/校企合作的政策,積極推進“中國制造2025”,實現(xiàn)中華民族偉大復興的升級產(chǎn)業(yè)鏈。利用北京大學優(yōu)質(zhì)教育資源及背
博為峰,中國職業(yè)人才培訓領(lǐng)域的先行者
曾工作于聯(lián)想擔任系統(tǒng)開發(fā)工程師,曾在博彥科技股份有限公司擔任項目經(jīng)理從事移動互聯(lián)網(wǎng)管理及研發(fā)工作,曾創(chuàng)辦藍懿科技有限責任公司從事總經(jīng)理職務負責iOS教學及管理工作。
浪潮集團項目經(jīng)理。精通Java與.NET 技術(shù), 熟練的跨平臺面向?qū)ο箝_發(fā)經(jīng)驗,技術(shù)功底深厚。 授課風格 授課風格清新自然、條理清晰、主次分明、重點難點突出、引人入勝。
精通HTML5和CSS3;Javascript及主流js庫,具有快速界面開發(fā)的能力,對瀏覽器兼容性、前端性能優(yōu)化等有深入理解。精通網(wǎng)頁制作和網(wǎng)頁游戲開發(fā)。
具有10 年的Java 企業(yè)應用開發(fā)經(jīng)驗。曾經(jīng)歷任德國Software AG 技術(shù)顧問,美國Dachieve 系統(tǒng)架構(gòu)師,美國AngelEngineers Inc. 系統(tǒng)架構(gòu)師。