微信多图上传解决android多图上传失败问题

 更新时间:2017年04月20日 13:52:57   作者:Y先僧  
这篇文章主要介绍了微信多图上传解决android多图上传失败问题,需要的朋友可以参考下

微信提供了文件上传的方法wx.uploadFile来上传我们的图片

wx.chooseImage({
 success: function(res) {
 var tempFilePaths = res.tempFilePaths
 wx.uploadFile({
  url: 'http://example.weixin.qq.com/upload', //仅为示例,非真实的接口地址
  filePath: tempFilePaths[0],
  name: 'file',
  formData:{
  'user': 'test'
  },
  success: function(res){
  var data = res.data
  //do something
  }
 })
 }
})

但是针对多图上传微信没有给出相应的方法来解决,如此我们只能消耗我们程序猿的脑细胞来解决了,最开始我使用了for循环来循环上传我的图片,恰好本人是苹果手机所以上传是没有问题的,本以为轻松解决了这个问题但是提交到测试以后坑了。测试MM说他那里提示上传失败。

于是借来测试手机打印出来错误消息

uploadFile:fail:the same task is working

wx.uploadFile不能并行,因为wx.uploadFile是一个异步函数,所以循环的时候在安卓手机上会出现并行

所以上面的通过循环wx.uploadFile方法进行多图上传肯定是不能行的了,既然不能并行我们是不是可以让wx.uploadFile执行完后再执行wx.uploadFile了。看下修改后的代码

这里为上传图片的方法,在里面作出判断上传完成以后重复调用upload_img

var img_index = 0;//上传带第几张
var image_list1 = new Array();
//上传图片
var upload_img = function (that, file_name) {
 that.setData({
  hidden: false
 });
 wx.uploadFile({
  url: '',
  filePath: file_name,
  name: 'file',
  success: function (res) {
   //此处判断是否上传成功
   var obj = JSON.parse(res.data);
   if (obj.ret_code == 1) {
    //上传成功以后将上传成功的图片加入数组显示出来,这样可以避免没有上传成功的图片就不显示
    var uploads = new Array();
    var image_list = new Array();
    //加入返回值
    uploads = that.data.upload;
    uploads.push(obj.data);
    //加入图片
    image_list = that.data.tempFilePaths;
    image_list.push(file_name);
    that.setData({
     upload: uploads,
     tempFilePaths: image_list
    });
    //上传成功一次img_index+1,下面再次调用upload_img上传图片就可以直接传image_list1[img_index],也就是下一张图片的链接
    img_index = img_index + 1;
    //这里需要作出判断图片是否上传完成,如果完成则取消缓冲框hidden
    if (img_index < image_list1.length) {
     upload_img(that, '' + image_list1[img_index]);
    } else {
     that.setData({
      hidden: true
     });
    }
    //刷新界面
    that.update();
   } else {
    that.setData({
     hidden: true
    });
    utils.show_toast(obj.msg);
   }
  },
  fail: function (res) {
   that.setData({
    hidden: true
   });
   utils.show_toast('加入失败');
  }
 })
}

选择图片方法

if (that.data.tempFilePaths.length < 9) {
   wx.chooseImage({
    count: 9 - that.data.tempFilePaths.length, // 最多可以选择的图片张数,默认9
    sizeType: ['compressed'], // original 原图,compressed 压缩图,默认二者都有
    sourceType: ['album', 'camera'], // album 从相册选图,camera 使用相机,默认二者都有
    success: function (res) {
     // success
     img_index = 0;
     image_list1=new Array();
     //将选择的图片放入要上传的数组中
     for (var i = 0; i < res.tempFilePaths.length; i++) {
      console.log(i + ';' + res.tempFilePaths[i]);
      image_list1.push(res.tempFilePaths[i]);
     }
     //最开始上传第一张图片
     upload_img(that, '' + image_list1[img_index]);
    },
    fail: function () {
      utils.show_toast('选取失败');
    }
   })
  } else {
   utils.show_toast('当前最多只能选择9张图片');
  }

通过上面的代码就可以完成多图上传了,这样也避免了Android手机报错的漏洞

这里封装了一个错误消息弹窗避免写重复的代码

utils.show_toast(‘当前最多只能选择9张图片')
//弹窗 
function show_toast(text) { 
wx.showToast({ 
title: text, 
icon: ‘success', 
duration: 2000 
}); 
}

以上所述是小编给大家介绍的微信多图上传解决android多图上传失败问题,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对脚本之家网站的支持!

相关文章

  • Android UI设计与开发之ViewPager介绍和简单实现引导界面

    Android UI设计与开发之ViewPager介绍和简单实现引导界面

    这篇文章主要为大家详细介绍了Android UI设计与开发之ViewPager介绍和简单实现引导界面,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2017-08-08
  • Android实现自定义飘雪效果

    Android实现自定义飘雪效果

    随着冬季的脚步越来越远,南方的我今年就看了一场雪,下一场雪遥遥无期,那我们来实现一个自定义的 View,它能模拟雪花飘落的景象,所以本文给大家介绍了基于Android实现自定义飘雪效果,感兴趣的朋友可以参考下
    2024-01-01
  • Android仿微博加载长图滚动查看效果

    Android仿微博加载长图滚动查看效果

    这篇文章主要为大家详细介绍了Android仿微博加载长图滚动查看效果,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2017-12-12
  • 详解OpenGL Shader抗锯齿的实现

    详解OpenGL Shader抗锯齿的实现

    普通绘制圆形形状时可以看到图形边缘会有明显锯齿现象并不像真实圆形形状一样圆润边缘平滑。本文将介绍如何通过自制函数实现抗锯齿,需要的可以参考一下
    2022-02-02
  • AndroidQ(10)分区存储完美适配方法

    AndroidQ(10)分区存储完美适配方法

    这篇文章主要介绍了AndroidQ(10)分区存储完美适配方法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2019-12-12
  • Android Handler runWithScissors 梳理流程解析

    Android Handler runWithScissors 梳理流程解析

    这篇文章主要为大家介绍了Android Handler runWithScissors 梳理流程解析,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2022-10-10
  • Android图片实现压缩处理的实例代码

    Android图片实现压缩处理的实例代码

    本篇文章主要介绍了Android图片实现压缩处理的实例代码,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2017-07-07
  • Android 仿余额宝数字跳动动画效果完整代码

    Android 仿余额宝数字跳动动画效果完整代码

    这篇文章主要介绍了Android 仿余额宝数字跳动动画效果完整代码,需要的朋友可以参考下
    2017-11-11
  • Android全局获取Context实例详解

    Android全局获取Context实例详解

    这篇文章主要介绍了Android全局获取Context实例详解的相关资料,需要的朋友可以参考下
    2017-06-06
  • Android获取窗体信息的Util方法

    Android获取窗体信息的Util方法

    这篇文章主要介绍了Android获取窗体信息的Util方法的相关资料,需要的朋友可以参考下
    2015-07-07

最新评论