有关formData上传文件时遇到的问题

一、正常上传文件的步骤。

  1.设置表单form属性:enctype="multipart/form-data"

  2.js代码:

    

    var file = document.getElementById("file2");
    var fileList = file.files; //获取的文件数组

  1. function uploadFile(obj){//这是我的方法
  2. var form=document.getElementById('record'); //record是form的id
  3. var formData = new FormData(form);//将form放入formdata中
  4. for(var i=0;i<fileArr.length;i++){//这两个是我的要上传的文件数组
  5. //将数组中的file放入,传到后台
  6. formData.append("picfile",fileArr[i]);
  7. }
  8. for(var i=0;i<otherFile.length;i++){
  9. //将数组中的file放入,传到后台
  10. formData.append("otherfile",otherFile[i]);
  11. }
  12. $.ajax({
  13. dataType : "json",
  14. url : "/service/record/ajaxUploadUpdate",
  15. method : "post",
  16. data :formData,
  17. // 告诉jQuery不要去处理发送的数据
  18. processData : false,
  19. // 告诉jQuery不要去设置Content-Type请求头
  20. contentType : false,
  21. success : function(data){
  22. //成功之后的操作
  23. },
  24. error:function(){
  25. obj.disabled=false;
  26. }
  27. })
  28. }

  3.我的后台参数列表

  

@RequestMapping(value = "upload", method = RequestMethod.POST)
@ResponseBody
public String upload(@RequestParam("picFile") MultipartFile picFile,@RequestParam("otherfile") MultipartFile otherfile,
@ModelAttribute("form") EvaluationReportForm form)'

  picFile,otherfile这两个参数是我用来接收文件数组的。后面一个是用来接收其他的参数

二、我遇到的问题

  在选择文件的情况下,一切ok,没什么问题。

  但是在我修改的时候,没有选择文件的情况下,直接404,报错。

三、解决方法

  我也是在网上看到别人的文章试了下,可以。

  获取文件数组的方式,不要通过参数列表获取,换一种通过request的方式来,代码如下:

  

  MultipartHttpServletRequest multipartRequest = (MultipartHttpServletRequest) request;//这个request是HttpServletRequest request
  List<MultipartFile> picfile=multipartRequest.getFiles("picfile");
  List<MultipartFile> otherfile=multipartRequest.getFiles("otherfile");

  这样就解决问题了。

 

转载于:https://www.cnblogs.com/zf2926/p/8341005.html

前端开发中,我们经常会遇到需要上传文件的场景,而 FormData 就是一种能够方便实现文件上传的技术手段。而后端 Qt 则是一种强大的跨平台开发框架,具有良好的可移植性和高效性能,能够轻松地实现各种类型的应用开发。 在前端使用 FormData 进行文件上传的过程中,需要使用 JavaScript API 来获取文件并将其添加到 FormData 中。在上传文件,我们可以通过 XMLHttpRequest(XHR)对象或者 Fetch API 对 formData 对象进行异步请求发送。而后端 Qt 中,则需要使用相应的网络模块来处理收到的文件上传请求,同需要完成文件的存储和相关的逻辑处理。 首先,在进行文件上传前,我们需要明确前后端传输数据的格式和类型,并且确保前后端约定的接口名称和参数格式一致。对于文件上传,我们还需要注意文件格式和大小的限制,以及如何处理上传失败、重复上传等问题。 其次,前端 FormData 对象在上传文件需要注意以下几点: 1.通过使用append() 方法将文件数据添加到 FormData 中; 2.设置 xhr 发送的请求头,包括 Content-Type 等参数; 3.监听 xhr 上传进度,根据上传进度显示进度条等信息; 4.对于上传失败的情况,需要进行错误处理并给出相应的提示。 最后,在后端 Qt 中,我们需要使用相应的文件上传接口处理收到的请求。同样需要注意以下几点: 1.获取 FormData 中的文件数据,并保存到指定的目录下; 2.对上传的文件进行必要的内容验证和格式检查; 3.根据实际需求,进行文件命名、保存路径等调整; 4.根据上传的文件数据完成后续的逻辑处理和响应。 通过以上步骤,前端FormData 文件上传和后端 Qt 的文件处理可以得到成功的协同。同,在实际项目中,我们还需要考虑安全、兼容性等方面的因素,确保系统的可靠性和稳定性。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值