文件上傳

2019-05-30 20:54 更新

關(guān)于文件上傳的支持,很多朋友詢問為何Ui界面不顯示上傳選擇頁面元素,而是輸入框,這里做一個(gè)統(tǒng)一的說明

SwaggerBootstrapUi以前的版本中(1.8.9之前),如果需要使用文件上傳,界面顯示,需要做如下代碼設(shè)置:

@ApiOperation(value = "多文件MultipartFile上傳")
@ApiImplicitParams({@ApiImplicitParam(name = "file[]", value = "文件流對(duì)象,接收數(shù)組格式", required = true,dataType = "MultipartFile",allowMultiple = true),
                    @ApiImplicitParam(name = "title", value = "title", required = true)}
                  )
@RequestMapping(value="/uploadMaterial",method = RequestMethod.POST)
@ResponseBody
public RestMessage uploadMaterial(@RequestParam(value="file[]",required = true) MultipartFile[] files,@RequestParam(value = "title") String title, HttpServletRequest request) throws IOException {
    //int mul=1*1024*1024;
    List<Map> uploadFiles= upload(request,files);
    RestMessage rm=new RestMessage();
    rm.setData(uploadFiles);
    return rm;
}

需要指定dataType="MultipartFile",并且allowMultiple = true必須設(shè)置,該屬性從字面意思能知道,允許多文件上傳,這里需要說明一下,因?yàn)樵谝郧暗陌姹咀髡卟⒉恢牢募念愋?所以特意強(qiáng)加了MultipartFile類型,來達(dá)到Ui的線上顯示效果,所以單文件的上傳一直并未支持.

1.9.0版本中,添加了對(duì)單文件上傳的支持,多文件上傳不需要多個(gè)input元素,開發(fā)者只需要按住Ctrl鍵即可多選文件進(jìn)行上傳,三種情況供大家參考使用:

多文件MultipartFile類型上傳

這種類型在以前的版本中都支持,需要指定dataType="MultipartFile",并且allowMultiple = true,示例代碼如下:

@ApiOperation(value = "多文件MultipartFile上傳")
@ApiImplicitParams({@ApiImplicitParam(name = "file[]", value = "文件流對(duì)象,接收數(shù)組格式", required = true,dataType = "MultipartFile",allowMultiple = true),
                    @ApiImplicitParam(name = "title", value = "title", required = true)}
                  )
@RequestMapping(value="/uploadMaterial",method = RequestMethod.POST)
@ResponseBody
public RestMessage uploadMaterial(@RequestParam(value="file[]",required = true) MultipartFile[] files,@RequestParam(value = "title") String title, HttpServletRequest request) throws IOException {
    //more.....


}

在Ui的界面中,顯示效果如下:

多文件File類型上傳

除了dataType類型設(shè)置為MultipartFile外,開發(fā)者還可以設(shè)置為__File類型,代碼示例如下:

@ApiOperation(value = "多文件File上傳")
@ApiImplicitParams({@ApiImplicitParam(name = "file[]", value = "文件流對(duì)象,接收數(shù)組格式", required = true,dataType = "__File",allowMultiple = true),
                    @ApiImplicitParam(name = "title", value = "title", required = true)}
                  )
@RequestMapping(value="/uploadMaterial1",method = RequestMethod.POST)
@ResponseBody
public RestMessage uploadMaterial1(@RequestParam(value="file[]",required = true) MultipartFile[] files,@RequestParam(value = "title") String title, HttpServletRequest request) throws IOException {
    //more....
}

單文件File類型上傳

和多文件File類型上傳類似,只需要去掉allowMultiple = true屬性即可,代碼示例如下:

@ApiOperation(value = "單文件File上傳")
@ApiImplicitParams({@ApiImplicitParam(name = "file", value = "文件流對(duì)象,接收數(shù)組格式", required = true,dataType = "__File"),
                    @ApiImplicitParam(name = "title", value = "title", required = true)}
                  )
@RequestMapping(value="/uploadMaterial2",method = RequestMethod.POST)
@ResponseBody
public RestMessage uploadMaterial2(@RequestParam(value="file",required = true) MultipartFile file,@RequestParam(value = "title") String title, HttpServletRequest request) throws IOException {
    //more...
}

以上三種情況示例可參考demo代碼UploadController.java

以上內(nèi)容是否對(duì)您有幫助:
在線筆記
App下載
App下載

掃描二維碼

下載編程獅App

公眾號(hào)
微信公眾號(hào)

編程獅公眾號(hào)