uni-app uni.uploadFile上传图片前后端(java)详解

uni-app uni.uploadFile上传图片前后端(java)详解近日在使用uni.uploadFile上传图片时,碰到后端收到不到文件的问题,网上没有写uni-appjava后端的处理实例,小程序到是有很多,但都是单文件上传,即使是多文件上传,也是采用一个for循环多次调用uploadFile函数,对文件一个一个提交。伪代码如下://微信小程序为例:for(vari=0;i<filePaths.length;i++){…

大家好,又见面了,我是你们的朋友全栈君。

近日在使用uni.uploadFile上传图片时,碰到后端收到不到文件的问题,网上没有写uni-app java后端的处理实例,小程序到是有很多,但都是单文件上传,即使是多文件上传,也是采用一个for循环多次调用uploadFile函数,对文件一个一个提交。伪代码如下:

// 微信小程序为例:
for (var i = 0; i < filePaths.length; i++){
    
    wx.uploadFile({
        url:this.url,    
        filePath:filePaths[i],
        name:'file',
        formData:data,
        header:{"Content-Type": "multipart/form-data"},
        success: (res) =>{
            if (res.data.code == 200){
                console.log('上传成功');
            }
        }
    })
}

uni-app的uni.uploadFile在5+APP支持多文件上传,后端处理多文件上传的时候与单文件上传有些不同之处。

一、单文件上传,首先是前端

uni.uploadFile({
    url:this.url,     // 后端api接口
    filePath: filePaths[0], // uni.chooseImage函数调用后获取的本地文件路劲
    name:'file',     //后端通过'file'获取上传的文件对象
    formData: this.sendDate,
    header:{"Content-Type": "multipart/form-data"},
    success:(res) => {
        if (res.data.code == 200){
            console.log('文件上传成功')
        }
    }
});

后端处理单文件上传比较简单,代码如下:

@RequestMapping("/uploadFile")
public Result uploadFile(HttpServeletRequest request, @RequestParam("file")MultipartFile [] files){
    
    // 这样就可以收到文件了,files.length == 1.
    System.out.println(files.length);

    // 后续操作省略
}

二、多文件上传

前端代码:

// 文件路劲封装
let imgs = this.imageList.map((value, index) => {
    return {
            name: "image" + index, 
            uri: value
        }
});
uni.uploadFile({
    url:this.url, 
    files: imgs,
    formData: this.sendDate,
    header:{"Content-Type": "multipart/form-data"},
    success: (res) => {
        if (res.statusCode === 200) {
            uni.showToast({
                title: "反馈成功!"
            });
        }
    }
})

不一样的地方在于:单文件上传的filePath和name参数没有了,取而代之的是files,官方文档有明确说明

uni-app uni.uploadFile上传图片前后端(java)详解

后端代码:

java后端处理多文件上传时,如果仍用单文件上传的后端代码,files.length总等于0,因为注解@ReqeustParam(”file”)里面的file在前端并没有这样设置并提交。

仔细分析uni-app官方文档对于uni.uploadFile函数的说明,知道该函数发起的请求,Content-type为multipart/form-data,于是便可以从request对象中获取MultipartFile。源码如下:

// 如下代码只保留了主逻辑
@RequestMapping("/uploadFile")
public Result uploadFile(HttpServletRequest request, FormData formData) throws IOException{
		
    CommonsMultipartResolver commonsMultipartResolver = new CommonsMultipartResolver(request.getSession().getServletContext());
		
	
    commonsMultipartResolver.setDefaultEncoding("utf-8");

    if (commonsMultipartResolver.isMultipart(request)){
        MultipartHttpServletRequest mulReq = (MultipartHttpServletRequest) request;
	Map<String, MultipartFile> map = mulReq.getFileMap();
			
        // key为前端的name属性,value为上传的对象(MultipartFile)
        for (Map.Entry<String, MultipartFile> entry : map.entrySet()) {
            // 自己的保存文件逻辑
            saveOrUpdateImageFile(feedback.getId(), entry.getKey(), entry.getValue());
        }  
    }      

    return Result.success();
	
}

以上便是uni-app在5+APP上多文件上传的前后端处理代码,如有其他方法,欢迎留言交流。

 

 

 

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/147987.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • eclipse+selenium谷歌浏览器驱动配置

    eclipse+selenium谷歌浏览器驱动配置1.各种Selenium-java的包都在此网址http://www.seleniumhq.org/download/2.各种浏览器驱动的下载地址:3.尤其注意浏览器驱动与浏览器版本之间的匹配情况,还有注意驱动与selenium之间的匹配情况火狐暂时还没有配置成功,这里记录谷歌的匹配情况1.查看谷歌浏览器版本2.谷歌驱动,见百度网盘3.将谷歌驱动放到谷歌浏览

    2022年5月31日
    58
  • 跳频介绍_跳频功能

    跳频介绍_跳频功能跳频是最常用的扩频方式之一,其工作原理是指收发双方传输信号的载波频率按照预定规律进行离散变化的通信方式,也就是说,通信中使用的载波频率受伪随机变化码的控制而随机跳变。从通信技术的实现方式来说,“跳频”是一种用码序列进行多频频移键控的通信方式,也是一种码控载频跳变的通信系统。从时域上来看,跳频信号是一个多频率的频移键控信号;从频域上来看,跳频信号的频谱是一个在很宽频带上以不等间隔随机跳变的。其中:跳

    2025年8月12日
    2
  • linux 新建文件的命令

    图形界面下就不用说了,终端下键入:touchtest.java就创建了一个新文件test.javahttp://hovertree.com/menu/linux/http://www.cnbl

    2021年12月24日
    45
  • js中将json字符串转换成json对象_字符串零终止符

    js中将json字符串转换成json对象_字符串零终止符今天遇到一个奇怪的问题,解析二维码后获得了一个JSON字符串,将JSON字符串转换成JSON对象的时候报错了。报错如下:代码如下:检查了无数次数据,数据是JSON字符串,引号也都是英文的,就是莫名其妙的转换不了。最后无奈了,终于找到一个解决办法,不用JSON.parse(xx)转换,用eval(‘(‘+xx+’)’)方法转换,最终解决了这个问题,虽然我还是不明白为什么JSON.parse转换会报错,有知道原因的大神吗?解决方法:数据如下:language{“ID”:”98-FA-9B

    2022年9月26日
    3
  • windows自动关机命令_windows取消自动关机命令

    windows自动关机命令_windows取消自动关机命令##设置定时关机bat####1.首先在桌面新建一个记事本txt####2.打开记事本,输入shutdown-s-t1260;1260是指1260秒,即21分钟内关机。可以修改成别的时间

    2022年8月4日
    3
  • 服务器性能监视器_性能计数器感叹号

    服务器性能监视器_性能计数器感叹号文章来源:http://blog.csdn.net/lhfzd2004/article/details/1722379上一篇文章《服务器性能监控之WMI》介绍了通过远程com获取服务器性能(当然也可用于本地),那么这篇主要说说windows系统自带的性能监视功能—–>performancecouonter.打开管理工具–>性能,我们可以立即看到服务器的CPU,进程运行时间,磁盘容量

    2022年10月8日
    2

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号