目录
-
1 概述
-
1.1 使用说明
- 1.1.1 步骤一:引入JS文件
- 1.1.2 步骤二:通过config接口注入权限验证配置
- 1.1.3 步骤三:通过ready接口处理成功验证
- 1.1.4 步骤四:通过error接口处理失败验证
- 1.2 接口调用说明
-
1.1 使用说明
-
2 基础接口
- 2.1 判断当前客户端版本是否支持指定JS接口
-
3 分享接口
- 3.1 获取“分享到朋友圈”按钮点击状态及自定义分享内容接口
- 3.2 获取“分享给朋友”按钮点击状态及自定义分享内容接口
- 3.3 获取“分享到QQ”按钮点击状态及自定义分享内容接口
- 3.4 获取“分享到腾讯微博”按钮点击状态及自定义分享内容接口
- 3.5 获取“分享到腾讯微博”按钮点击状态及自定义分享内容接口
-
4 图像接口
- 4.1 拍照或从手机相册中选图接口
- 4.2 预览图片接口
- 4.3 上传图片接口
- 4.4 下载图片接口
-
5 音频接口
- 5.1 开始录音接口
- 5.2 停止录音接口
- 5.3 监听录音自动停止接口
- 5.4 播放语音接口
- 5.5 暂停播放接口
- 5.6 停止播放接口
- 5.7 监听语音播放完毕接口
- 5.8 上传语音接口
- 5.9 下载语音接口
-
6 智能接口
- 6.1 识别音频并返回识别结果接口
-
7 设备信息
- 7.1 获取网络状态接口
-
8 地理位置
- 8.1 使用微信内置地图查看位置接口
- 8.2 获取地理位置接口
-
9 界面操作
- 9.1 隐藏右上角菜单接口
- 9.2 显示右上角菜单接口
- 9.3 关闭当前网页窗口接口
- 9.4 批量隐藏功能按钮接口
- 9.5 批量显示功能按钮接口
- 9.6 隐藏所有非基础按钮接口
- 9.7 显示所有功能按钮接口
-
10 微信扫一扫
- 10.1 调起微信扫一扫接口
-
11 企业号会话
- 11.1 创建企业号会话
- 12 附录1-JS-SDK使用权限签名算法
- 13 附录2-所有JS接口列表
- 14 附录3-所有菜单项列表
- 15 附录4-常见错误及解决方法
- 16 附录5-DEMO页面和示例代码
- 17 附录6-问题反馈
概述
微信JS-SDK是微信公众平台面向网页开发者提供的基于微信内的网页开发工具包。
通过使用微信JS-SDK,网页开发者可借助微信高效地使用拍照、选图、语音、位置等手机系统的能力,同时可以直接使用微信分享、扫一扫等微信特有的能力,为微信用户提供更优质的网页体验。
此文档面向网页开发者介绍微信JS-SDK如何使用及相关注意事项。
使用说明
在使用微信JS-SDK对应的JS接口前,需确保已获得使用对应JS接口的权限,可在下表中根据自己的帐号角色查看。 企业号帐号角色分为注册号和认证号,其中认证号拥有更多的JS-SDK权限,具体详见下方表格:
功能1 | 接口 | 注册号 | 认证号 |
---|---|---|---|
基础接口 | 判断当前客户端版本是否支持指定JS接口 | 有 | 有 |
分享接口 | 获取“分享到朋友圈”按钮点击状态及设置分享内容接口 | 无 | 有 |
获取“分享给朋友”按钮点击状态及设置分享内容接口 | 无 | 有 | |
获取“分享到QQ”按钮点击状态及设置分享内容接口 | 无 | 有 | |
获取“分享到腾讯微博”按钮点击状态及设置分享内容接 | 无 | 有 | |
图像接口 | 本地选图或拍照接口 | 有 | 有 |
图片预览接口 | 有 | 有 | |
上传图片接口 | 有 | 有 | |
下载图片接口 | 有 | 有 | |
音频接口 | 开始录音接口 | 有 | 有 |
停止录音接口 | 有 | 有 | |
播放音频接口 | 有 | 有 | |
暂停播放接口 | 有 | 有 | |
停止播放接口 | 有 | 有 | |
上传语音接口 | 有 | 有 | |
下载语音接口 | 有 | 有 | |
智能接口 | 识别音频并返回识别结果接口 | 有 | 有 |
设备信息 | 获取网络状态接口 | 有 | 有 |
地理位置 | 查看地理位置地图接口 | 有 | 有 |
获取地理位置接口 | 有 | 有 | |
界面操作 | 隐藏右上角菜单接口 | 有 | 有 |
显示右上角菜单接口 | 有 | 有 | |
关闭当前窗口接口 | 有 | 有 | |
批量隐藏菜单项接口 | 有 | 有 | |
批量显示菜单项接口 | 有 | 有 | |
隐藏所有非基本菜单项接口 | 有 | 有 | |
显示所有被隐藏的非基本菜单项接口 | 有 | 有 | |
微信扫一扫 | 扫一扫接口 | 有 | 有 |
注意: 所有的JS接口只能在企业号应用的可信域名下调用(包括子域名),可在企业号应用中心里设置应用可信域名。
步骤一:引入JS文件
在需要调用JS接口的页面引入如下JS文件,(支持https):/open/js/jweixin-1.0.
备注:支持使用 AMD/CMD 标准模块加载方法加载
步骤二:通过config接口注入权限验证配置
所有需要使用JS-SDK的页面必须先注入配置信息,否则将无法调用(同一个url仅需调用一次,对于变化url的SPA的web app可在每次url变化时进行调用,目前Android微信客户端不支持pushState的H5新特性,所以使用pushState来实现web app的页面会导致签名失败,此问题会在Android6.2中修复)。
({
debug: true, // 开启调试模式,调用的所有api的返回值会在客户端alert出来,若要查看传入的参数,可以在pc端打开,参数信息会通过log打出,仅在pc端时才会打印。
appId: '', // 必填,企业号的唯一标识,此处填写企业号corpid
timestamp: , // 必填,生成签名的时间戳
nonceStr: '', // 必填,生成签名的随机串
signature: '',// 必填,签名,见附录1
jsApiList: [] // 必填,需要使用的JS接口列表,所有JS接口列表见附录2
});
步骤三:通过ready接口处理成功验证
(function(){
// config信息验证后会执行ready方法,所有接口调用都必须在config接口获得结果之后,config是一个客户端的异步操作,所以如果需要在页面加载时就调用相关接口,则须把相关接口放在ready函数中调用来确保正确执行。对于用户触发时才调用的接口,则可以直接调用,不需要放在ready函数中。
});
步骤四:通过error接口处理失败验证
(function(res){
// config信息验证失败会执行error函数,如签名过期导致验证失败,具体错误信息可以打开config的debug模式查看,也可以在返回的res参数中查看,对于SPA可以在这里更新签名。
});
接口调用说明
所有接口通过wx对象(也可使用jWeixin对象)来调用,参数是一个对象,除了每个接口本身需要传的参数之外,还有以下通用参数:
- success:接口调用成功时执行的回调函数。
- fail:接口调用失败时执行的回调函数。
- complete:接口调用完成时执行的回调函数,无论成功或失败都会执行。
- cancel:用户点击取消时的回调函数,仅部分有用户取消操作的api才会用到。
- trigger: 监听Menu中的按钮点击时触发的方法,该方法仅支持Menu中的相关接口。
注意:不要尝试在trigger中使用ajax异步请求修改本次分享的内容,因为客户端分享操作是一个同步操作,这时候使用ajax的回包会还没有返回。
以上几个函数都带有一个参数,类型为对象,其中除了每个接口本身返回的数据之外,还有一个通用属性errMsg,其值格式如下:
- 调用成功时:"xxx:ok" ,其中xxx为调用的接口名
- 用户取消时:"xxx:cancel",其中xxx为调用的接口名
- 调用失败时:其值为具体错误信息
基础接口
判断当前客户端版本是否支持指定JS接口
({
jsApiList: ['chooseImage'] // 需要检测的JS接口列表,所有JS接口列表见附录2,
success: function(res) {
// 以键值对的形式返回,可用的api值true,不可用为false
// 如:{"checkResult":{"chooseImage":true},"errMsg":"checkJsApi:ok"}
});
备注:checkJsApi接口是客户端6.0.2新引入的一个预留接口,第一期开放的接口均可不使用checkJsApi来检测。
分享接口
请注意不要有诱导分享等违规行为,对于诱导分享行为将永久回收企业号接口权限,详细规则请查看:朋友圈管理常见问题 。
获取“分享到朋友圈”按钮点击状态及自定义分享内容接口
({
title: '', // 分享标题
link: '', // 分享链接
imgUrl: '', // 分享图标
success: function () {
// 用户确认分享后执行的回调函数
},
cancel: function () {
// 用户取消分享后执行的回调函数
}
});
获取“分享给朋友”按钮点击状态及自定义分享内容接口
({
title: '', // 分享标题
desc: '', // 分享描述
link: '', // 分享链接
imgUrl: '', // 分享图标
type: '', // 分享类型,music、video或link,不填默认为link
dataUrl: '', // 如果type是music或video,则要提供数据链接,默认为空
success: function () {
// 用户确认分享后执行的回调函数
},
cancel: function () {
// 用户取消分享后执行的回调函数
}
});
获取“分享到QQ”按钮点击状态及自定义分享内容接口
({
title: '', // 分享标题
desc: '', // 分享描述
link: '', // 分享链接
imgUrl: '', // 分享图标
success: function () {
// 用户确认分享后执行的回调函数
},
cancel: function () {
// 用户取消分享后执行的回调函数
}
});
获取“分享到腾讯微博”按钮点击状态及自定义分享内容接口
({
title: '', // 分享标题
desc: '', // 分享描述
link: '', // 分享链接
imgUrl: '', // 分享图标
success: function () {
// 用户确认分享后执行的回调函数
},
cancel: function () {
// 用户取消分享后执行的回调函数
}
});
获取“分享到腾讯微博”按钮点击状态及自定义分享内容接口
({
title: '', // 分享标题
desc: '', // 分享描述
link: '', // 分享链接
imgUrl: '', // 分享图标
success: function () {
// 用户确认分享后执行的回调函数
},
cancel: function () {
// 用户取消分享后执行的回调函数
}
});
图像接口
拍照或从手机相册中选图接口
({
count: 1, // 默认9
sizeType: ['original', 'compressed'], // 可以指定是原图还是压缩图,默认二者都有
sourceType: ['album', 'camera'], // 可以指定来源是相册还是相机,默认二者都有
success: function (res) {
var localIds = ; // 返回选定照片的本地ID列表,localId可以作为img标签的src属性显示图片
}
});
预览图片接口
({
current: '', // 当前显示图片的http链接
urls: [] // 需要预览的图片http链接列表
});
上传图片接口
({
localId: '', // 需要上传的图片的本地ID,由chooseImage接口获得
isShowProgressTips: 1// 默认为1,显示进度提示
success: function (res) {
var serverId = ; // 返回图片的服务器端ID
}
});
备注:
- 上传图片有效期3天,可用微信多媒体接口下载图片到自己的服务器,此处获得的 serverId 即 media_id,参考文档
- 目前多媒体文件下载接口的频率限制为10000次/天,如需要调高频率,请邮件weixin-open@,邮件主题为【申请多媒体接口调用量】,请对你的项目进行简单描述,附上产品体验链接,并对用户量和使用量进行说明。
下载图片接口
({
serverId: '', // 需要下载的图片的服务器端ID,由uploadImage接口获得
isShowProgressTips: 1// 默认为1,显示进度提示
success: function (res) {
var localId = ; // 返回图片下载后的本地ID
}
});
音频接口
开始录音接口
();
停止录音接口
({
success: function (res) {
var localId = ;
}
});
监听录音自动停止接口
({
// 录音时间超过一分钟没有停止的时候会执行 complete 回调
complete: function (res) {
var localId = ;
}
});
播放语音接口
({
localId: '' // 需要播放的音频的本地ID,由stopRecord接口获得
});
暂停播放接口
({
localId: '' // 需要暂停的音频的本地ID,由stopRecord接口获得
});
停止播放接口
({
localId: '' // 需要停止的音频的本地ID,由stopRecord接口获得
});
监听语音播放完毕接口
({
serverId: '', // 需要下载的音频的服务器端ID,由uploadVoice接口获得
success: function (res) {
var localId = ; // 返回音频的本地ID
}
});
上传语音接口
({
localId: '', // 需要上传的音频的本地ID,由stopRecord接口获得
isShowProgressTips: 1// 默认为1,显示进度提示
success: function (res) {
var serverId = ; // 返回音频的服务器端ID
}
});
备注:
- 上传语音有效期3天,可用微信多媒体接口下载语音到自己的服务器,此处获得的 serverId 即 media_id,参考文档
- 目前多媒体文件下载接口的频率限制为10000次/天,如需要调高频率,请邮件weixin-open@,邮件主题为【申请多媒体接口调用量】,请对你的项目进行简单描述,附上产品体验链接,并对用户量和使用量进行说明。
下载语音接口
({
serverId: '', // 需要下载的音频的服务器端ID,由uploadVoice接口获得
isShowProgressTips: 1// 默认为1,显示进度提示
success: function (res) {
var localId = ; // 返回音频的本地ID
}
});
智能接口
识别音频并返回识别结果接口
({
localId: '', // 需要识别的音频的本地Id,由录音相关接口获得
isShowProgressTips: 1, // 默认为1,显示进度提示
success: function (res) {
alert(); // 语音识别的结果
}
});
设备信息
获取网络状态接口
({
success: function (res) {
var networkType = ; // 返回网络类型2g,3g,4g,wifi
}
});
地理位置
使用微信内置地图查看位置接口
({
latitude: 0, // 纬度,浮点数,范围为90 ~ -90
longitude: 0, // 经度,浮点数,范围为180 ~ -180。
name: '', // 位置名
address: '', // 地址详情说明
scale: 1, // 地图缩放级别,整形值,范围从1~28。默认为最大
infoUrl: '' // 在查看位置界面底部显示的超链接,可点击跳转
});
获取地理位置接口
({
type: 'wgs84', // 默认为wgs84的gps坐标,如果要返回直接给openLocation用的火星坐标,可传入'gcj02'
success: function (res) {
var latitude = ; // 纬度,浮点数,范围为90 ~ -90
var longitude = ; // 经度,浮点数,范围为180 ~ -180。
var speed = ; // 速度,以米/每秒计
var accuracy = ; // 位置精度
}
});
界面操作
隐藏右上角菜单接口
();
显示右上角菜单接口
();
关闭当前网页窗口接口
();
批量隐藏功能按钮接口
({
menuList: [] // 要隐藏的菜单项,所有menu项见附录3
});
批量显示功能按钮接口
({
menuList: [] // 要显示的菜单项,所有menu项见附录3
});
隐藏所有非基础按钮接口
();
显示所有功能按钮接口
();
微信扫一扫
调起微信扫一扫接口
({
desc: 'scanQRCode desc',
needResult: 0, // 默认为0,扫描结果由微信处理,1则直接返回扫描结果,
scanType: ["qrCode","barCode"], // 可以指定扫二维码还是一维码,默认二者都有
success: function (res) {
var result = ; // 当needResult 为 1 时,扫码返回的结果
}
});
企业号会话
创建企业号会话
1.接口描述
名称:openEnterpriseChat
功能:通过JS-SDK创建企业号会话
2.请求参数
参数 | 必填 | 说明 |
---|---|---|
userIds | 是 | 参与会话的成员列表。格式为userid1;userid2;...,用分号隔开,最大限制为1000个。userid单个时为单聊,多个时为群聊。 |
groupName | 是 | 会话名称。单聊时该参数不需要传。 |
3.代码示例
({
userIds: ‘zhangshan;lisi;wangwu’,
groupName: ‘openEnterpriseChat讨论组’,
success: function(res){
// 回调
},
error: function(res){
if(('function_not_exist') > 0){
alert('版本过低请升级')
}
}
});
备注:引入新版js文件 /open/js/jweixin-1.1. 。微信客户端6.3.5支持该接口,可通过function_not_exist错误信息提示用户升级微信。
4.返回码
返回码 | 说明 |
---|---|
10001 | appid无效 |
10002 | 用户未关注企业号 |
10003 | 消息服务未开启 |
10004 | 用户不在消息服务可见范围 |
10005 | 存在无效的消息会话成员 |
10006 | 消息会话成员数不合法 |
-1 | 系统出错 |
附录1-JS-SDK使用权限签名算法
jsapi_ticket
生成签名之前必须先了解一下jsapi_ticket,jsapi_ticket是企业号号用于调用微信JS接口的临时票据。正常情况下,jsapi_ticket的有效期为7200秒,通过access_token来获取。由于获取jsapi_ticket的api调用次数非常有限,频繁刷新jsapi_ticket会导致api调用受限,影响自身业务,开发者必须在自己的服务全局缓存jsapi_ticket。
- 参考以下文档获取access_token(有效期7200秒,开发者必须在自己的服务全局缓存access_token):/wiki/?title=%E4%B8%BB%E5%8A%A8%E8%B0%83%E7%94%A8
- 用第一步拿到的access_token 采用http GET方式请求获得jsapi_ticket(有效期7200秒,开发者必须在自己的服务全局缓存jsapi_ticket):/cgi-bin/get_jsapi_ticket?access_token=ACCESS_TOKE
成功返回如下JSON:
{
"errcode":0,
"errmsg":"ok",
"ticket":"bxLdikRXVbTPdHSM05e5u5sUoXNKd8-41ZO3MhKoyN5OfkWITDGgnr2fwJ0m9E8NYzWKVZvdVtaUgWvsdshFKA",
"expires_in":7200
}
获得jsapi_ticket之后,就可以生成JS-SDK权限验证的签名了。
签名算法
签名生成规则如下:参与签名的字段包括noncestr(随机字符串), 有效的jsapi_ticket, timestamp(时间戳), url(当前网页的URL,不包含#及其后面部分) 。对所有待签名参数按照字段名的ASCII 码从小到大排序(字典序)后,使用URL键值对的格式(即key1=value1&key2=value2…)拼接成字符串string1。这里需要注意的是所有参数名均为小写字符。对string1作sha1加密,字段名和字段值都采用原始值,不进行URL 转义。
即signature=sha1(string1)。 示例:
- noncestr=Wm3WZYTPz0wzccnW
- jsapi_ticket=sM4AOVdWfPE4DxkXGEs8VMCPGGVi4C3VM0P37wVUCFvkVAy_90u5h9nbSlYy3-Sl-HhTdfl2fzFy1AOcHKP7qg
- timestamp=1414587457
- url=
步骤1. 对所有待签名参数按照字段名的ASCII 码从小到大排序(字典序)后,使用URL键值对的格式(即key1=value1&key2=value2…)拼接成字符串string1:
jsapi_ticket=sM4AOVdWfPE4DxkXGEs8VMCPGGVi4C3VM0P37wVUCFvkVAy_90u5h9nbSlYy3-Sl-HhTdfl2fzFy1AOcHKP7qg&noncestr=Wm3WZYTPz0wzccnW×tamp=1414587457&url=
附录2-所有JS接口列表
版本1.0.0接口
- onMenuShareTimeline
- onMenuShareAppMessage
- onMenuShareQQ
- onMenuShareWeibo
- onMenuShareQZone
- startRecord
- stopRecord
- onVoiceRecordEnd
- playVoice
- pauseVoice
- stopVoice
- onVoicePlayEnd
- uploadVoice
- downloadVoice
- chooseImage
- previewImage
- uploadImage
- downloadImage
- translateVoice
- getNetworkType
- openLocation
- getLocation
- hideOptionMenu
- showOptionMenu
- hideMenuItems
- showMenuItems
- hideAllNonBaseMenuItem
- showAllNonBaseMenuItem
- closeWindow
- scanQRCode
附录3-所有菜单项列表
基本类
- 举报: "menuItem:exposeArticle"
- 调整字体: "menuItem:setFont"
- 日间模式: "menuItem:dayMode"
- 夜间模式: "menuItem:nightMode"
- 刷新: "menuItem:refresh"
- 查看企业号(已添加): "menuItem:profile"
- 查看企业号(未添加): "menuItem:addContact"
传播类
- 发送给朋友: "menuItem:share:appMessage"
- 分享到朋友圈: "menuItem:share:timeline"
- 分享到QQ: "menuItem:share:qq"
- 分享到QQ空间: "menuItem:share:QZone"
- 分享到Weibo: "menuItem:share:weiboApp"
- 收藏: "menuItem:favorite"
- 分享到FB: "menuItem:share:facebook"
- 分享到QQ空间:"menuItem:share:QZone"
保护类
- 调试: "menuItem:jsDebug"
- 编辑标签: "menuItem:editTag"
- 删除: "menuItem:delete"
- 复制链接: "menuItem:copyUrl"
- 原网页: "menuItem:originPage"
- 阅读模式: "menuItem:readMode"
- 在QQ浏览器中打开: "menuItem:openWithQQBrowser"
- 在Safari中打开: "menuItem:openWithSafari"
- 邮件: "menuItem:share:email"
- 一些特殊企业号: "menuItem:share:brand"
附录4-常见错误及解决方法
调用config 接口1的时候传入参数 debug: true 可以开启debug模式,页面会alert出错误信息。以下为常见错误及解决方法:
- invalid url domain当前页面所在域名与使用的corpid没有绑定(可在该企业号的应用可信域名中配置域名)。
- invalid signature签名错误。建议按如下顺序检查:
- 确认签名算法正确,可用 /debug/cgi-bin/sandbox?t=jsapisign 页面工具进行校验。
- 确认config中nonceStr(js中驼峰标准大写S), timestamp与用以签名中的对应noncestr, timestamp一致。
- 确认url是页面完整的url(请在当前页面alert(('#')[0])确认),包括'http(s)://'部分,以及'?'后面的GET参数部分,但不包括'#'hash后面的部分。
- 确认 config 中的 appid 与用来获取 jsapi_ticket 的 appid 一致。
- 确保一定缓存access_token和jsapi_ticket。
- 确保你获取用来签名的url是动态获取的,动态页面可参见实例代码中php的实现方式。如果是html的静态页面在前端通过ajax将url传到后台签名,前端需要用js获取当前页面除去'#'hash部分的链接(可用('#')[0]获取,而且需要encodeURIComponent),因为页面一旦分享,微信客户端会在你的链接末尾加入其它参数,如果不是动态获取当前链接,将导致分享后的页面签名失败。
- the permission value is offline verifying这个错误是因为config没有正确执行,或者是调用的JSAPI没有传入config的jsApiList参数中。建议按如下顺序检查:
- 确认config正确通过。
- 如果是在页面加载好时就调用了JSAPI,则必须写在的回调中。
- 确认config的jsApiList参数包含了这个JSAPI。
- permission denied该公众号没有权限使用这个JSAPI(部分接口需要认证之后才能使用)。
- function not exist当前客户端版本不支持该接口,请升级到新版体验。
- 为什么6.0.1版本config:ok,但是6.0.2版本之后不ok(因为6.0.2版本之前没有做权限验证,所以config都是ok,但这并不意味着你config中的签名是OK的,请在6.0.2检验是否生成正确的签名以保证config在高版本中也ok。)
- 在iOS和Android都无法分享(请确认公众号已经认证,只有认证的公众号才具有分享相关接口权限,如果确实已经认证,则要检查监听接口是否在回调函数中触发)
- 服务上线之后无法获取jsapi_ticket,自己测试时没问题。(因为access_token和jsapi_ticket必须要在自己的服务器缓存,否则上线后会触发频率限制。请确保一定对token和ticket做缓存以减少2次服务器请求,不仅可以避免触发频率限制,还加快你们自己的服务速度。目前为了方便测试提供了1w的获取量,超过阀值后,服务将不再可用,请确保在服务上线前一定全局缓存access_token和jsapi_ticket,两者有效期均为7200秒,否则一旦上线触发频率限制,服务将不再可用)。
- uploadImage怎么传多图(目前只支持一次上传一张,多张图片需等前一张图片上传之后再调用该接口)
- 没法对本地选择的图片进行预览(chooseImage接口本身就支持预览,不需要额外支持)
- 通过a链接(例如先通过微信授权登录)跳转到b链接,invalid signature签名失败(后台生成签名的链接为使用jssdk的当前链接,也就是跳转后的b链接,请不要用微信登录的授权链接进行签名计算,后台签名的url一定是使用jssdk的当前页面的完整url除去'#'部分)
- 出现config:fail错误(这是由于传入的config参数不全导致,请确保传入正确的appId、timestamp、nonceStr、signature和需要使用的jsApiList)
- 如何把jsapi上传到微信的多媒体资源下载到自己的服务器(请参见文档中uploadVoice和uploadImage接口的备注说明)
- Android通过jssdk上传到微信服务器,第三方再从微信下载到自己的服务器,会出现杂音(微信团队已经修复此问题,目前后台已优化上线)
- 绑定父级域名,是否其子域名也是可用的(是的,合法的子域名在绑定父域名之后是完全支持的)
- 在iOS微信6.1版本中,分享的图片外链不显示,只能显示公众号页面内链的图片或者微信服务器的图片,已在6.2中修复
- 是否需要对低版本自己做兼容(jssdk都是兼容低版本的,不需要第三方自己额外做更多工作,但有的接口是6.0.2新引入的,只有新版才可调用)
- 该公众号支付签名无效,无法发起该笔交易(请确保你使用的是官方线上版本,不仅可以减少用户流量,还有可能对某些bug进行修复,拷贝到第三方服务器中使用,官方将不对其出现的任何问题提供保障,具体支付签名算法可参考 JSSDK微信支付一栏)
- 目前Android微信客户端不支持pushState的H5新特性,所以使用pushState来实现web app的页面会导致签名失败,此问题已在Android6.2中修复
- uploadImage在chooseImage的回调中有时候Android会不执行,Android6.2会解决此问题,若需支持低版本可以把调用uploadImage放在setTimeout中延迟100ms解决
- require subscribe错误说明你没有订阅该测试号,该错误仅测试号会出现
- getLocation返回的坐标在openLocation有偏差,因为getLocation返回的是gps坐标,openLocation打开的腾讯地图为火星坐标,需要第三方自己做转换,6.2版本开始已经支持直接获取火星坐标
- 查看公众号(未添加): “menuItem:addContact”不显示,目前仅有从公众号传播出去的链接才能显示,来源必须是公众号
附录5-DEMO页面和示例代码
DEMO页面:
/jssdk
示例代码:
/jssdk/
备注:链接中包含php、java、nodejs以及python的示例代码供第三方参考,第三方切记要对获取的accesstoken以及jsapi_ticket进行缓存以确保不会触发频率限制。
附录6-问题反馈
邮箱地址:weixin-open@
邮件主题:【微信JS-SDK反馈】
邮件内容说明:
用简明的语言描述问题所在,并交代清楚遇到该问题的场景,可附上截屏图片,微信团队会尽快处理你的反馈。