微信jssdk图片上传给服务器,使用微信JSSDK进行图片选择和上传

在使用PHP开发微信公众号时,作者遇到一个问题:在调用微信jssdk进行图片选择和上传时,脚本在选择图片未完成时就尝试上传,导致localId为空的错误。通过研究解决方案,作者发现将上传动作放入setTimeout()函数中可以解决问题。这样,当图片选择完成后,上传操作才会执行,从而避免了错误的发生。
摘要由CSDN通过智能技术生成

2015-04-28

2018-08-21 06:20:42

最近我在用 PHP 做某微信公众号的开发,其中用到了微信jssdk进行图片的选择和上传。在参考了微信官方提供的jssdk文档之后,大致有了思路,即先选图或拍照,获得 localIds,再上传图片,成功后获得 serverId,之后就可以根据 serverId,从微信服务器获取图像。 然而在选择图片后紧接着开始上传图片,却出现了问题:脚本总会在选择图片还没结束的时候直接就走到文件上传,导致上传时会出现localId为空的错误。动手搜索了一下,果然有解决方法,参考:

wx.chooseImage({

success: function (res) {

if(res.localIds.length == 1) {

//alert('开始上传!');

setTimeout(function (){

wx.uploadImage({

localId: res.localIds[0],

isShowProgressTips: 1,

success: function (res) {

//上传成功后的操作

},

fail: function (res) {

alert(JSON.stringify(res));

}

});

},100);

}

}

});

将上传动作放到setTimeout()里面就OK了!

参考:

low.bi 2018 | lowlog

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值