spring mvc表单多文件混合异步上传

1. 后端示例代码:
@RequestMapping(value="/upload",method=RequestMethod.POST)
public List<File> uploadFile(MultipartHttpServletRequest request) throws IOException{
    //首先定义了一个List<File>用于保存所有文件上传后所在位置,以便后续做出一系列处理。
    List<File> uploadFileList = new ArrayList<File>();
    //拿到name为files的文件上传表单内容(支持多文件)
    List<MultipartFile> files = request.getFiles("files");
    //拿到name为test的表单项
    String test = request.getParameter("test");
    //获取项目真实路径
    String path = request.getSession().getServletContext().getRealPath("");
    //指定temp文件夹
    String tmpPath = path + File.separator + "temp";
    File filePath = new File(tmpPath);
    if(!filePath.exists() || !filePath.isDirectory()){
        filePath.mkdirs();
    }
    //上传等同于输入输出流的正常操作,拿到输入流的bytes往输出流送
    for (MultipartFile multipartFile : files) {
        if(!multipartFile.isEmpty()){
            File tempFile = new File(filePath + File.separator + multipartFile.getOriginalFilename());
            FileOutputStream fos = new FileOutputStream(tempFile);
            BufferedOutputStream bos = new BufferedOutputStream(fos);
            bos.write(multipartFile.getBytes());
            bos.close();
            fos.close();
            uploadFileList.add(tempFile);
        }
    }
    return uploadFileList;
}

注:以上示例可以混合读取表单多文件以及普通字段,并拿到一个文件的真实路径List。

2. 前端示例代码
  • 表单同步方式:

    <form action="http://localhost:8080/upload" method="post" enctype="multipart/form-data" id="form">
      <input type="text" name="test" id="test" value="" />
      <input type="file" name="files" id="files" value="" multiple="multiple" />
      <input type="submit" value="上传"/>
    </form>
    

form必须标注enctype属性为multipart/form-data,如需支持多文件,可以设置file控件的multiple属性为multiple(H5支持)。

  • ajax异步方式:

    var formData = new FormData(document.getElementById("form"));
    $.ajax({
      url: 'http://localhost:8080/upload',
      type: 'POST',
      data: formData,
      async: true,
      cache: false,
      contentType: false,
      processData: false,
      success: function (returndata) {
          alert("上传成功:"+returndata);
      }
    });
    
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值