SSM 前端使用AJAX方式,fromdata文件格式上传二进制流文件

这篇具有很好参考价值的文章主要介绍了SSM 前端使用AJAX方式,fromdata文件格式上传二进制流文件。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

今天在上课的时候,遇到了一个比较坑的问题,有个学生拿来了她的代码,让我给她看看为什么传值传不过来。
首先,前端是这样的:

function upload(){
    var formData = new FormData();
    formData.append('images', $('#previewImg')[0].files[0]);
    var id1=$("input[name='id']").val()
    formData.append('id', id1);
    $.ajax({
        type:"post",
        processData: false,
        contentType: false,
        url:"uploadImage",
        data:formData,
        success:function(data){
        }
    });
}

后端是这样的:

@PostMapping("/uploadImage")
    public Map uploadImage(Integer id,MultipartFile images,HttpSession session){
//        System.out.println(id);
//        System.out.println(images);
        }
    }

然后上传文件的配置器是这样的:

<bean id="CommonsMultipartResolver" class="org.springframework.web.multipart.commons.CommonsMultipartResolver">
<property name="defaultEncoding" value="utf-8"/>
<property name="maxUploadSize" value="1048675000"/>
<property name="maxUploadSizePerFile" value="1048675000"/>
</bean>

她遇到的第一个问题是,后端这里接受值的时候,接受到的id和文件都是null,然后再后续的使用中报空指针了。

看起来就是一个很简单的空指针问题,我拿来查的时候,先看了一下她这边的前段,开始我没有注意到是使用的fromdata,我以为是普通的json传输,而且在network中也很明显能看到请求头和带的参数。

后端可以报空指针,说明后端的代码也进去了,说明请求头也没问题。
所以我觉得问题原因可能出在请求头接受值的地方(事实证明,老中医的直觉是对的)
所以我把她的后端代码头做了修改。:

public Map uploadImage(HttpServletRequest request,HttpSession session){

用HttpServletRequest 来接受试试(这时候我还没注意到fromdata)然后发现,在req中也获取不到id,我有点麻了,我觉得可能是写法问题,导致这个数据不在req里面,我再换个写法:

    public Map uploadImage(@RequestParam Integer id,@RequestParam MultipartFile images,HttpSession session){

可能是我对HttpServletRequest 忘记的多,找不到值在哪儿,我直接用注解去取值看看,结果发现还是null。我当时就无语了,这他妈的。

然后我就又回头去看前段,既然这里折腾半天没效果,不如换个阵地。之前前端传后端没见过二进制的文件流啊,是不是因为这玩意的原因?我去前段把她这里set文件的地方给她注掉了,我心想,这不就变成了一个普通的ajax了么,这不应该有问题吧。

然后我就去后端看,上面的三板斧又转了一圈,还不行。我真是见了鬼了。
然后学生和我说,老师是不是fromdata的问题。
我一看,这里怎么还不一样呢,我以为这里就是个普通的json。
完了又看了俩眼这个fromdata的用法,很简单啊,前段传值,后端接收,没毛病啊。这还有什么问题不成?
搜了一下fromdata使用的时候注意事项,有文章说要加个注解@MultipartConfig,但是我试过了,发现还是null,这怎么可能啊!我要颜面扫地了。
这个时候这个问题已经看了接近2个小时了,这个时候学生吐槽说,一般这种一看看一天的问题,八成是什么小问题,不知道哪儿写错了。
我也同意这种想法,于是,我的目光又回到了后端的接受请求的地方:

public Map uploadImage(Integer id,MultipartFile images,HttpSession session){

她这里前端fromdata设置值的时候,先塞的file,后塞的id,会不会是这里接受参数的顺序有影响?
然后我把这句改了一下:

  public Map uploadImage(MultipartFile images,Integer id,HttpSession session){

对,没错,我调换了俩个参数的位置试了一下(死马当活马医了)
然后,然后,然后这个问题就解决了,他的报错终于跳到下一步了!!!!

调换了参数位置以后,出现了新的报错,说她没有配置文件解析器,但是她这里是有配置MultipartFilte上传文件解析器的,然后这个问题比较简单,看了一下,解析器的id不对。应该是:

<bean id="multipartResolver" class="org.springframework.web.multipart.commons.CommonsMultipartResolver">
<property name="defaultEncoding" value="utf-8"/>
<property name="maxUploadSize" value="1048675000"/>
<property name="maxUploadSizePerFile" value="1048675000"/>
</bean>

一下午这就过去了,看了一个问题看了快2个半小时,所以必须写个文章记录一下。文章来源地址https://www.toymoban.com/news/detail-685244.html

到了这里,关于SSM 前端使用AJAX方式,fromdata文件格式上传二进制流文件的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • 前端上传大文件使用分片上传

    前提:分片上传针对于一些大的文件、普通大小的文件使用element中的上传组件可以实现效果,例如几G的文件就会比较卡,所以这时候就需要用到分片上传~ 前端及后端分片上传笔记 效果:(上传进度展示) 效果:(上传成功的效果展示)

    2024年01月25日
    浏览(34)
  • 前端使用axios上传文件

    不用脚手架,引入vue,上传文件实现代码? 要在不使用脚手架的情况下,引入 Vue 并实现上传文件的功能,可以按照以下步骤进行: 在 HTML 文件中引入 Vue 和 Axios 库: 在 HTML 文件中定义 Vue 实例,并编写上传文件相关的代码: 在上述示例中,我们首先在 HTML 文件中定义了一

    2024年02月04日
    浏览(34)
  • 【H5】文件上传(ajax)

    【移动设备】iData 50P 技术规格 本文链接:https://blog.csdn.net/youcheng_ge/article/details/130604517 【H5】Promise的用法 本文链接:https://blog.csdn.net/youcheng_ge/article/details/131634038 【H5】文件下载(javascript) 本文链接:https://blog.csdn.net/youcheng_ge/article/details/131539397 【H5】文件上传(ajax) 本

    2024年02月12日
    浏览(22)
  • SpringBoot使用post方式上传文件

    file.transferTo(dest):将文件file存到dest这个文件位置。 设置header的 Content-Type为multipart/form-data 设置Body为form-data,设置key为file,点value的输入框,去选择要上传的文件

    2024年02月11日
    浏览(37)
  • 前端使用FormData上传多个文件

    FormData: 文档介绍 https://developer.mozilla.org/zh-CN/docs/Web/API/FormData 当接口需要文件格式的参数进行文件上传时,前端上传的文件需要使用 FormData FormData主要作用:网络请求中处理用来异步的上传文件 例如: 前端调用方法如下:  页面调用结果如下图  

    2024年02月15日
    浏览(88)
  • AJAX | 拦截器、文件上传和下载

    💗wei_shuo的个人主页 💫wei_shuo的学习社区 🌐Hello World ! Ajax即Asynchronous Javascript And XML(异步JavaScript和XML);Ajax技术网页应用能够快速地将增量更新呈现在用户界面上,不需要重载(刷新)整个页面,使程序能够更快地回应用户的操作 web.xml applicationContext.xml ​ AjaxControlle

    2023年04月21日
    浏览(18)
  • 前端终止请求的三种方式(ajax、axios)

    一、原生ajax终止请求 1、abort() ​ XMLHttpRequest.abort() 方法用于终止 XMLHttpRequest 对象的请求,该方法没有参数,也没有返回值。当调用该方法时,如果对应 XMLHttpRequest 对象的请求已经被发送并且正在处理中,则会中止该请求;如果请求已经完成(即已经接收到完整的响应),则

    2024年02月09日
    浏览(35)
  • 【AI绘画】Stable Disffusion文件格式及使用方式

    1.模型:尾缀为 cpkt 、 safetensors ,文件容量较大(往往几个G) 存放路径: ./models/Stable-diffusion ​ 2.美化模型:名字中带有 vae 存放路径: ./models/VAE ​ 3.lora文件:尾缀为 safetensors ,文件容量较小 (1)存放路径: ./extensions/sd-webui-additional-networks/models/lora ​ 使用时需要在这个

    2024年03月15日
    浏览(57)
  • JS-27 前端数据请求方式;HTTP协议的解析;JavaScript XHR、Fetch的数据请求与响应函数;前端文件上传XHR、Fetch;安装浏览器插件FeHelper

    早期的网页都是通过后端渲染来完成的,即服务器端渲染(SSR,server side render): 客户端发出请求 - 服务端接收请求并返回相应HTML文档 - 页面刷新,客户端加载新的HTML文档; 服务器端渲染的缺点: 当用户点击页面中的某个按钮向服务器发送请求时,页面本质上只是一些数

    2024年02月16日
    浏览(48)
  • 后端:使用easyExcel实现解析Excel文件读取数据。前端:Excel模板下载、前端上传文件

            本篇是EasyExcel快速入门知识,讲解如何读取Excel文件,对Excel中错误信息如空字符、必填项为空、表格格式校验做到处理 ,并给出了实际项目中示例代码;为什么要使用easyexcel;原因是相比于poi,easyexcel更加轻量级,读取写入API方便,并且在工作中占用内存较小;

    2024年02月05日
    浏览(53)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包