微信公众号开发

能享用微信公众号的API,比如分享给好友,分享到朋友圈,禁止菜单功能,选择图片,获取地址,以及支付

微信的功能有两种执行方式

一种是 wx.xx

一种是 WeixinJSBridge.call()

WeixinJSBridge是很老的方式,在微信网页才能使用的全局变量,不需要引入js插件,现在都不用了,但是去查资料会有很多,看了没用的,但是有两个是可以用的

// 禁止菜单功能
WeixinJSBridge.call('hideOptionMenu'); // 关闭当前页面
WeixinJSBridge.call('closeWindow');

除了上面的这两个,其他的功能都要用下面的写法

而且需要前提条件

  1. 公众号需要通过认证,认证之后才能在微信公众号后台的开发的接口权限里看到功能都是已获得,未获得就不配调用微信的API
  2. 需要有服务器域名,域名配置在公众号后台的JS接口安全域名名单里
  3. 需要引入wx的js插件,专业叫wxsdk文件

    js文件在微信公众号开发文档里下载,现在的版本是1.4

    如果是vue使用,weixin-js-sdk

配置阶段

// 引入js之后需要配置
// 除了jsApiList这个数组,其他的值都来自后端,就是跟后端拿值就行
wx.config({
debug: true, // 开启调试模式,调用的所有api的返回值会在客户端alert出来,若要查看传入的参数,可以在pc端打开,参数信息会通过log打出,仅在pc端时才会打印。
appId: '', // 必填,公众号的唯一标识
timestamp: , // 必填,生成签名的时间戳
nonceStr: '', // 必填,生成签名的随机串
signature: '',// 必填,签名
jsApiList: [] // 必填,需要使用的JS接口列表
});
// 跟config写在一起就行,如果config配置成功,就会执行这个
wx.ready(function(){
// config信息验证后会执行ready方法,所有接口调用都必须在config接口获得结果之后,config是一个客户端的异步操作,所以如果需要在页面加载时就调用相关接口,则须把相关接口放在ready函数中调用来确保正确执行。对于用户触发时才调用的接口,则可以直接调用,不需要放在ready函数中。
});
// 跟config写在一起就行,如果config配置出错,就会执行这个
wx.error(function(res){
// config信息验证失败会执行error函数,如签名过期导致验证失败,具体错误信息可以打开config的debug模式查看,也可以在返回的res参数中查看,对于SPA可以在这里更新签名。
}); // jsApiList需要传参需要的功能
// 内容在下载js的链接的最下面就能看到

分享功能

// 微信文档有两个分享
// 一个是onMenuShareTimeline 和 onMenuShareAppMessage (即将废弃)
// 一个是updateAppMessageShareData 和 updateTimelineShareData
// 用哪个,用废弃的那个,新的只能在苹果手机使用,废弃的苹果手机和安卓都没问题 // 先配置
jsApiList: ["onMenuShareTimeline","onMenuShareAppMessage"] // ready是配置完成后会自动执行的
// 不是所有的方法都需要写在ready里的
// 但这两个需要
wx.ready(function(){
wx.onMenuShareTimeline({
title: '参数传标题',
imgUrl: '参数传图片',
success: function(){ ... }
});
wx.onMenuShareAppMessage({
title: '参数传标题',
imgUrl: '参数传图片',
desc: '参数传副标题',
success: function(){ ... }
});
});

选择图片

这个是完美了解决了画布的兼容和BUG

// 需要用到的配置
jsApiList: ["chooseImage","getLocalImgData"]
// 当用户点击上传图片的按钮后
function ImgUpload(){
// 打开微信相册的功能
wx.chooseImage({
count: 1, // 默认9,如果选多个是返回的数组
sizeType: ['compressed'], // 可以指定是原图'original'还是压缩图,默认二者都有,这里屏蔽了原图
sourceType: ['album', 'camera'], // 可以指定来源是相册还是相机'camera',默认二者都有,这里屏蔽了相机
success: function (res) {
//这意味着只有IOS8以上的手机才能用这个本地图片接口,而以下的版本如果使用JSSDK1.2.0版本会导致无法获取图片数据,或者使用1.1.0又无法预览图片的尴尬场面,另外用了1.2.0版本后uploadImage会出现file not exists的错误
var localIds = res.localIds; //这是数组
getImgData(localIds[0]); //但是这个程序只要一张图片,所以取值arr[0]
}
})
} function getImgData(localIds){
// 选择图片后用微信的功能转成base64
wx.getLocalImgData({
localId:localIds,
success: function (res){
//base64
var localData = res.localData;
/*判断ios是不是用的 wkwebview 内核*/
if (window.__wxjs_is_wkwebview){
localData = localData.replace('data:image/jgp', 'data:image/jpeg');
}else{
if (localData.indexOf('data:image') != 0) {
//判断是否有这样的头部
localData = "data:image/jpeg;base64," + localData;
}
}
// 这个值就可以直接传给后端了
console.log(localData)
}
})
}

获取当前经纬度

这个配合腾讯地图使用,查看下一篇

支付

需要商家向微信申请开通支付

然后配置白名单,查看配置方式

WeixinJSBridge.invoke('getBrandWCPayRequest',{
"appId":appId, //公众号名称,由商户传入
"timeStamp":timeStamp, //时间戳,自1970年以来的秒数
"nonceStr":nonceStr, //随机串
"package":package,
"signType":signType, //微信签名方式:
"paySign":paySign //微信签名
},function(res){
methods.hideLoading();
if(res.err_msg == "get_brand_wcpay_request:ok" ) {
console.log('支付成功');
}else if(res.err_msg == "get_brand_wcpay_request:cancel"){
console.log('支付取消');
}else if(res.err_msg == "getBrandWCPayRequest:fail_nopermission"){
console.log('当前版本不支持,请检查升级或到微信中支付!');
}else if(res.err_msg == "get_brand_wcpay_request:fail_nopermission"){
console.log('当前版本不支持,请检查升级或到微信中支付!');
}else if(res.err_msg == "get_brand_wcpay_request:fail"){
console.log('支付失败');
}
});

微信公众号sdk的更多相关文章

  1. 微信公众号 SDK

    <?php /* 方倍工作室 http://www.fangbei.org/ CopyRight 2015 All Rights Reserved */ define("TOKEN&q ...

  2. python开发微信公众号SDK选择

    1.wechat-sdk sudo pip install wechat-sdk 文档地址:  http://ww2.wechat-python-sdk.com/ 2.wechat sudo pip ...

  3. 使用开源库MAGICODES.WECHAT.SDK进行微信公众号支付开发

    概要 博客使用Word发博,发布后,排版会出现很多问题,敬请谅解.可加群获取原始文档. 本篇主要讲解微信支付的开发流程,相关业务基于MAGICODES.WECHAT.SDK实现.通过本篇教程,您可以很 ...

  4. SAE微信公众号PHP SDK, token一直验证失败

    用的是SAE,创建的是微信公众号PHP SDK框架,里面example文件夹下有server.php用来验证token的.但是问题来了,无论我怎么输入URL和token,一直告诉我token验证失败. ...

  5. VopSdk一个高逼格微信公众号开发SDK

    一.我们的目标 分离基础参数和业务参数. 具有高重用和扩展性. 轻量级. 二.实现目标 (一)分离基础参数和业务参数 仔细分析所有接口,抽离出每个模块接口的公共参数. A.针对微信公众号所有接口分析( ...

  6. VopSdk一个高逼格微信公众号开发SDK(源码下载)

    看之前回复很多说明大家很有热情&文章被误删掉了,不想让有的朋友错失这个高逼格的东西,现在重新发布,这次就直接放出源码,文章最末下载地址. 看之前回复很多说明大家很有热情&文章被误删掉了 ...

  7. VopSdk一个高逼格微信公众号开发SDK:自动化生产(装逼模式开启)

    VopSdk一个高逼格微信公众号开发SDK(源码下载) VopSdk一个高逼格微信公众号开发SDK:自动化生产(装逼模式开启) 针对第一版,我们搞了第二版本,老规矩先定个目标. 一 我们的目标 a.移 ...

  8. Senparc.Weixin SDK 微信公众号 .NET 开发教程 索引

    Senparc.WeixinSDK从一开始就坚持开源的状态,这个过程中得到了许多朋友的认可和支持. 目前SDK已经达到比较稳定的版本,这个过程中我觉得有必要整理一些思路和经验,和大家一起分享.也欢迎大 ...

  9. 微信开发(3):微信公众号发现金红包功能开发,利用第三方SDK实现(转)

    最近需求是 用户兑换微信红包,需要一些验证,加密,以及证书: 工欲善其事必先利其器 感谢前辈的微信SDK 已经维护三年了,还在维护中! 官方文档走一波 文档还是一如既往的 坑人啊,写的很简单,对简单明 ...

随机推荐

  1. 【转】CentOS6开启BBR加速

    1.查看机器内核 BBR 算法需要 Linux 4.9 及以上的内核支持,所以想要使用该方式的需要先升级内核版本. 在 Cent OS 7 上的 Linux 内核是 3.10, 使用 uname -r ...

  2. Python基础-4 运算符

    运算符 运算符:以1 + 2为例,1和2被称为操作数,"+" 称为运算符. Python语言支持以下类型的运算符: 算术运算符 比较(关系)运算符 赋值运算符 逻辑运算符 位运算符 ...

  3. HTML标签,CSS简介

    一  http://www.w3school.com.cn/tags/tag_span.asp

  4. 「SP11470」TTM - To the moon

    题目描述 给定一段长度为 \(N\) 的序列 \(a\) 以及 \(M\) 次操作,操作有以下几种: C l r d :将区间 \([l,r]\) 中的数都加上 \(d\) Q l r :查询当前时间 ...

  5. 「CSP」第一届提高组考后总结

    「CSP」第一届提高组考后总结 问题分析+反思 成绩 心态 考前心态 考时心态 考后心态 方法 心灵鸡汤... 在学习了三年之后,我们信竞迎来了初中最后一次大考,也是第一次 CSPCSPCSP 考试. ...

  6. 当你输入一个url链接发生了什么?

    先看一张图 打开手机和pad的QQ 发送消息给QQ好友,此时发送了一个请求给服务器,服务器接受到后反馈给手机和pad发送消息成功,然后QQ好友就可以接受到消息了 电脑浏览器输入百度 打开台式电脑或者笔 ...

  7. AngularJS 官方启动文档

    参考:https://angular.io/guide/quickstart 中文:http://www.angularjs.net.cn/

  8. Ubuntu18.04--双显卡Nvida笔记本安装之各种问题

    (1)安装   出现卡logo或者黑屏 关机重启,按住esc键或shift键不放,进入选择模式,按F6进入选择,nomodeset模式 (2)循环的登陆,或者安装好后重启无法再次进入系统 关机重启,在 ...

  9. Vue二次精度随笔(1)

    1.button.input标签的disabled属性 该标签可以控制按钮是否可用,如果他的值为以上几种的话,则他都不会在标签上渲染出这个属性,一旦这个属性出现的话,就说明他是禁用的 2.移除动态绑定 ...

  10. [经验] HTML页面中子盒子溢出了怎么办

    背景: 在查询数据记录的一个页面上使用bootstar 框架的分页插件作为显示数据表格的工具. 问题: 当查询的范围在一个较短的时间内时, 子元素是乖乖的呆在父元素内部的, 但是一但将查询的时间范围扩 ...