微信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 ...
随机推荐
- shell 常用命令
Terminal是Mac OS X系统中的字符控制界面,可以更灵活地控制苹果电脑以下看到 “>“ 就是打指令的地方,prompt,指令列>pwd列出路径>ls列出此档案夹里所有的东西 ...
- ThoughtWorks 2016年第1期DNA活动总结
今天受邀参加了2016年ThoughtWorks公司成都分公司的2016年第一期DNA活动. 什么是DNA? DNA 即 Design And Analysis.设计与分析.这个活动主要是针对产品经理 ...
- oracle rac理解和用途扩展
Oracle RAC的优势在于利用多个节点(数据库实例)组成一个数据库,这样在保证了数据库高可用性的情况下更充分的利用了多个主机的性能,而且可以通过增加节点进行性能的扩展.实现Oracle RAC需要 ...
- SQL优化方案
1:建立中间表,将步骤分解. 2:避免全字段查询,只查需要的字段 3:限定条件查询,避免先关联后写条件, --优化交货数据 --建临时表T_JHinfo select A.VBELN,C.VBEL ...
- 【转】mysql如何跟踪执行的sql语句
转自http://blog.csdn.net/testcs_dn/article/details/18791815 在SQL SERVER下跟踪sql采用事件探查器,而在mysql下如何跟踪sql呢? ...
- Android 学习笔记之使用多线程实现断点下载...
PS:莫名其妙的迷茫... 学习内容: 1.使用多线程实现文件下载... 多线程下载是加快下载速度的一种方式..通过开启多个线程去执行一个任务..可以使任务的执行速度变快..多线程的任务下载时常都 ...
- linux 系统管理 使用技巧
一.这篇文章讲了什么? 这篇文章很有参考性哈.本来是想等一段时间有更多条技巧后在发布的,不过,突然发现,我是去年的今天在博客园落户了,祝我的博客一周岁快乐,希望以后多分享一些文章啦.所以就把草稿箱的其 ...
- 初涉SQL Server性能问题(2/4):列出等待资源的会话
在初涉SQL Server性能问题(1/4)里,我们知道了如何快速检查服务器实例上正运行的任务数和IO等待的任务数.这个是轻量级的脚本,不会给服务器造成任何压力,即使服务器在高负荷下,也可以正常获得结 ...
- html5中的大纲
html5中的大纲 前言: 在html5中我们可以使用结构元素来编排一份大纲,这样我们就可以通过这个网页的大纲来了解网页中有哪些内容,网页中以什么样的形式来组织这些内容有更清楚的认识. 1.html5 ...
- Java集合框架源码剖析:LinkedHashSet 和 LinkedHashMap
Java LinkedHashMap和HashMap有什么区别和联系?为什么LinkedHashMap会有着更快的迭代速度?LinkedHashSet跟LinkedHashMap有着怎样的内在联系?本 ...