微信jssdk,实现多图上传的一点心得
一.首先在common.js里封装一个函数,在需要调用jsSDK的页面引用此方法即可实现微信的信息配置
function signatureJSSDK() {
var url = window.location.href.split('#')[0];//后台需要此页面的url来生成参数
$.ajax({
url:IPWeiXinJssdk,//调用后台接口,用后台返回的结果来进行微信接口的基础配置
type:"post",
dataType:"json",
data:{"url":url},
success:function (result) {
if (result) {
//后台接口调用成功,开始配置微信
wx.config({
debug : false, // 开启调试模式,调用的所有api的返回值会在客户端alert出来,若要查看传入的参数,可以在pc端打开,参数信息会通过log打出,仅在pc端时才会打印。
appId : result.appid, // 必填,公众号的唯一标识
timestamp : result.timestamp, // 必填,生成签名的时间戳
nonceStr : result.noncestr, // 必填,生成签名的随机串
signature : result.signature,// 必填,签名,见附录1
jsApiList : [// 必填,需要使用的JS接口列表,所有JS接口列表见附录2
/*
* 所有要调用的 API 都要加到这个列表中
* 这里以图像接口为例
*/
"chooseImage",
"previewImage",
"uploadImage",
"downloadImage" ]
});
}
}
})
}
//微信配置失败会执行wx.error函数
wx.error(function(res) {
confirmBox2("wx.config.error");
console.log(res);
});
二.在需要使用微信多图上传的页面编写如下代码
$(function () {
signatureJSSDK();//微信jssdk配置
// config信息验证失败会执行error函数,如签名过期导致验证失败,具体错误信息可以打开config的debug模式查看,
// 也可以在返回的res参数中查看,对于SPA可以在这里更新签名。
wx.ready(function() {//微信配置成功执行此函数
//localIdsArr 用来存放localIds,serverIdsArr用来存放serverIds
var localIdsArr = [];var serverIdsArr = [];
$(".BImgContent").click(function () {//点击事件触发微信拍照
var that = $(this);
wx.chooseImage({//调用微信拍照功能
count: 1, // 默认9
sizeType: ['compressed'], // 可以指定是原图还是压缩图,默认二者都有
sourceType: ['camera'], // 可以指定来源是相册还是相机,默认二者都有
success: function(res) {
localIds = res.localIds; // 返回选定照片的本地ID列表,localId可以作为img标签的src属性显示图片
$(that).find(".ago").attr('src', localIds);//本地预览,localIds可以当做img标签的src属性
wx.uploadImage({//用户预览的同时,上传至微信服务器
localId:""+localIds,
success: function(res) {
var i =0;
if($(that).hasClass("img1")){
i = 1;
}else if($(that).hasClass("img2")){
i = 2;
}else if($(that).hasClass("img3")){
i = 3;
}
localIdsArr[i] = localIds;//将此图片的localIds存入数组
serverIdsArr[i] = res.serverId;//将此图片在微信服务器上的werverID存入数组
}
});
}
});
});
$("#nextStep").click(function () {//用户点击下一步时,调用后台接口,传给后台serverIdsArr,后台可通过此id从微信服务器下载这些图片到后台
var flag = 0;
$(".ago").each(function (index,val) { //判断前台页面需要上传的部分是否都上传完
var localIds = $(val).attr("src");
if(localIds === "./img/photoAddContent1.png"){
flag = 1;
return false;
}
});
if(flag === 0){//验证通过,传送serverID至后台
// alert("开始发送serverID至后台");
$(this).unbind("click");
for(var i=0;i<serverIdsArr.length;i++){
pushSeverId(serverIdsArr[i]);
}
}else{
confirmBox2("请完善以上资料");
}
});
});
//将serverId发至后台,后台从微信服务器下载图片,然后反馈图片在我们服务器上的相对路径
var urlList = [];
function pushSeverId(serverId) {
$.post('http://XXX.XXX', { serverId: serverId },function (text, status) {
var obj = {"imgStr":"","imgType":""};
obj.imgStr = text;//text为后台返回的图片url
urlList.push(obj);
// alert(JSON.stringify(urlList));//可以在手机上打印此数组,调试用,看看是否全部上传成功
});
}
})
以上是我在使用微信jssdk,实现多图上传的代码,因为每个人的需求不尽相同,有的部分代码被我删除,希望能帮到大家!
微信jssdk,实现多图上传的一点心得的更多相关文章
- Java企业微信开发_07_JSSDK多图上传
一.本节要点 1.1可信域名 所有的JS接口只能在企业微信应用的可信域名下调用(包括子域名),可在企业微信的管理后台“我的应用”里设置应用可信域名.这个域名必须要通过ICP备案,不然jssdk会配置失 ...
- 【原创】.Net 微信 JS-SDK图片、语音上传接口的实现(MVC)-(一 、上传图片)
前段时间在做一个微信的项目,遇到了一个上传图片的问题,花了一下午,解决了这个问题,然后把总结出来的代码,分享了出来. 最近又有一个图片+语音的功能, 更是蛋疼, 本次采用的不是File文件上传,然后转 ...
- 微信小程序 多图上传解决方案
为了使代码体积小 我这里将多图上传 封装到单独的一个js 页面的js调用他 我们看firhealth.js文件内容 // pages/home/home.js var upload = requir ...
- 微信小程序多图上传/朋友圈传图效果【附完整源码】
效果图 部分源代码 js文件: var uploadPicture = require('../Frameworks/common.js') //获取应用实例 const app = getApp() ...
- 微信企业号办公系统-JSSDK上传图片(多图上传)
在开发微信企业号办公系统中,涉及到了图片上传功能,一开始使用的flash插件上传方法,在苹果手机上可以调用相机直接拍摄照片,但在安卓手机上只能选择照片. 微信jssdk-api带有一套完整的调用选择本 ...
- vue 仿微信朋友圈9张图上传功能
项目需求要求用户上传商品的时候可以一次性上传9张图,多余9张提示‘只能上传9张图’,并且每张图右上角有个删除按钮,图片也可以点击放大. 出来的效果图如下: 话不多说,上代码: <el-form- ...
- yii2组件之多图上传插件FileInput的详细使用
作者:白狼 出处:http://www.manks.top/yii2_multiply_images.html 本文版权归作者,欢迎转载,但未经作者同意必须保留此段声明,且在文章页面明显位置给出原文连 ...
- iOS 使用AFN 进行单图和多图上传
图片上传时必要将图片进行压缩,不然会上传失败 1.单张图上传 AFHTTPRequestOperationManager *manager = [AFHTTPRequestOperationManag ...
- PHP之:多图上传
撰写日期:2016-6-30 15:17:35 Thursday 参考 http://a3147972.blog.51cto.com/2366547/1381136 (08-05ThinkPHP+sw ...
随机推荐
- Git 执行 「fork 出来的仓库」和「最新版本的原仓库」内容同步更新
当我们在 GitHub 上 fork 出一个仓库后,如果原仓库更新了,此时怎样才能保证我们 fork 出来的仓库和原仓库内容一致呢?我们一般关注的是仓库的 master(主干分支)的内容,通过以下步骤 ...
- Exploring Ionic Lists
Infinite Lists 由于手机不适合使用多页面显示posts,Infinite Lists成为各种新闻.咨询类app的标配.为了在ionic框架中使用到Infinite Lists,我们首先学 ...
- CSDN 2013年度博客之星评选——分享几张厦门杭州的美图
亲爱的小伙伴们,作者在6号至20号,一直在休假中,出去也没带电脑,今天回家意外的发现自己有幸成为“CSDN 2013年度博客之星评选”的候选人,在此也谢谢各位小伙伴们的支持,谢谢CSDN的鼓励.我的投 ...
- C# 通过WebService方式 IIS发布网站 上传文件到服务器
应用场景:要将本地的文件 上传到服务器的虚拟机上 网络环境:公司局域网(如下图中第二种) 开发环境:VS2010 服务器环境:WinServer2008 虚拟机环境:WinServer2008 ...
- JS基础回顾,小练习(实现each方法)
function each(arr, fn) { for(var i=0;i<arr.length;i++){ fn(arr[i],i); } } var arr = ['java', 'c', ...
- Understanding apps: mobile, native or responsive
Background Maybe you have decided to get an app built. You will not build it yourself (obviously!) s ...
- NOP登录验证管理
截取Nop登录代码如下: 其实 public ActionResult Login(LoginModel model, string returnUrl, bool captchaValid) { / ...
- IIS负载均衡的NLB解决方案
在现行的许多网络应用中,有时一台服务器往往不能满足客户端的要求,此时只能通过增加服务器来解决问题.那么,有没有一个办法或者技术来解决此类问题呢?使用Windows 2000或Windows Serve ...
- percona-toolkit介绍及安装
percona-toolkit是一组高级命令行工具的集合,用来执行各种通过手工执行非常复杂和麻烦的mysql和系统任务,包括: 1. 检查master和slave数据的一致性 2. 有效地 ...
- 暴力 + 贪心 --- Codeforces 558C : Amr and Chemistry
C. Amr and Chemistry Problem's Link: http://codeforces.com/problemset/problem/558/C Mean: 给出n个数,让你通过 ...