url
转码官方文档描述: https://developers.weixin.qq.com/doc/offiaccount/OA_Web_Apps/JS-SDK.html#62javascript
确认url
是页面完整的url
(请在当前页面alert(location.href.split('#')[0])
确认),包括'http(s)😕/'
部分,以及'?'后面的GET
参数部分,但不包括'#'hash
后面的部分
即获取url
完成地址的方法为html
let url = window.location.href.split('#')[0];
若是连接带有中文字符或者特殊符号,前端须要使用encodeURIComponent
编码,同时后端须要配合解码前端
let url = encodeURIComponent(window.location.href.split('#')[0]);
config
注入官网文档描述: https://developers.weixin.qq.com/doc/offiaccount/OA_Web_Apps/JS-SDK.html#4vue
同一个url
仅需调用一次,对于变化url
的SPA
的web app
可在每次url
变化时进行调用,
注意,每次使用jssdk
方法前都要先注入配置信息,而且,每使用一次,就要注入config
一次.java
在vue
里,能够写在每次路由变化时web
router.beforeEach((to, from, next) => { // 获取权限验证配置(签名) 后端返回 getConfig, 注意返回字段的大小写! let res // 注入配置信息 wx.config({ debug: false, // 调试开关 appId: res.appId, // 必填,公众号的惟一标识 timestamp:res.timestamp , // 必填,生成签名的时间戳 nonceStr: res.nonceStr, // 必填,生成签名的随机串 signature: res.signature,// 必填,签名 jsApiList: ["updateAppMessageShareData","updateTimelineShareData"] // 必填,须要使用的JS接口列表 }); wx.ready(() => { // doSoming }); })
必定要再三确认安全域名等微信公众号配置信息,如分享连接link
字段后端
不少时候的错误并非前端方法或者sdk
等问题,而是后台有没有设置正确的安全域名和白名单等.安全
wx.updateAppMessageShareData({ title: '', // 分享标题 desc: '', // 分享描述 link: '', // 分享连接,该连接域名或路径必须与当前页面对应的公众号JS安全域名一致 imgUrl: '', // 分享图标 success: function () { // 设置成功 } })
参考微信官网文档-附录5
微信
地址: https://developers.weixin.qq.com/doc/offiaccount/OA_Web_Apps/JS-SDK.html#62app
在开发过程遇到
invalid signature
the permission value is offline verifying
permission denied
先参考文档,排除基本因素,仍是不行,再查找搜索引擎的答案.