vue 微信sdk的封装使用

1.引入JS文件
通过npm安装微信的js-sdk,或者在index.html页面中直接加script标签来引用,这里采用npm安装,
npm install weixin-js-sdk
在需要分享的页面中引入
import wx from 'weixin-js-sdk'
2.关于服务端 我就不做过多阐述了,自己也没了解过
3.通过config接口注入权限验证配置
所有需要使用JS-SDK的页面必须先注入配置信息,否则将无法调用(同一个url仅需调用一次,对于变化url的SPA的web app可在每次url变化时进行调用,目前Android微信客户端不支持pushState的H5新特性,所以使用pushState来实现web app的页面会导致签名失败,此问题会在Android6.2中修复)。

config配置里面的参数appid, timestamp, nonceStr, signature都是要后台接口返回的,前端可以通过axios发送接口请求获取

this.axios.get('/wx/get_signature?url=' + encodeURIComponent(location.href.split('#')[0])).then((res) => {
  wx.config({
    debug: true, // 开启调试模式
    appId: res.data.appId, // 必填,公众号的唯一标识
    timestamp: res.data.timestamp, // 必填,生成签名的时间戳
    nonceStr: res.data.nonceStr, // 必填,生成签名的随机串
    signature: res.data.signature,// 必填,签名
    jsApiList: [
      "updateAppMessageShareData",//自定义“分享给朋友”及“分享到QQ”按钮的分享内容
      "updateTimelineShareData",//自定义“分享到朋友圈”及“分享到QQ空间”按钮的分享内容
      "onMenuShareWeibo",//获取“分享到腾讯微博”按钮点击状态及自定义分享内容接口
    ] // 必填,需要使用的JS接口列表
  })
}).catch((error) => {
  console.log(error)
});

//通过ready接口处理成功验证
wx.ready(function(){
    this.wxShareTimeline();
    this.wxShareAppMessage();
// config信息验证后会执行ready方法,所有接口调用都必须在config接口获得结果之后,config是一个客户端的异步操作,所以如果需要在页面加载时就调用相关接口,则须把相关接口放在ready函数中调用来确保正确执行。对于用户触发时才调用的接口,则可以直接调用,不需要放在ready函数中。
});

wx.error(function(res){
//config信息验证失败会执行error函数,如签名过期导致验证失败,具体错误信息可以打开config的debug模式查看,也可以在返回的res参数中查看,对于SPA可以在这里更新签名。
});

可能咱们每次微信打开摄像头都得获取config的信息,不想每次验证一次,对入口文件中直接进行初始化签名和注入配置,针对每次需要微信sdk再重新签名和配置。


初始化签名

获取签名检测是否有效

分享封装

上面只是代码的部分截取,有需要的我一会放到csdn上方便大家下载
使用的话如下


mounted中直接this.share()使用

好了,基本上就是这样子了
分享给朋友 朋友圈都可以

常见错误及解决方法
调用config 接口的时候传入参数 debug: true 可以开启debug模式,页面会alert出错误信息。以下为常见错误及解决方法:
  1. invalid url domain当前页面所在域名与使用的appid没有绑定,请确认正确填写绑定的域名,仅支持80(http)和443(https)两个端口,因此不需要填写端口号(一个appid可以绑定三个有效域名,见 ]目录1.1.1)。

  2. invalid signature签名错误。建议按如下顺序检查
    1.确认config中nonceStr(js中驼峰标准大写S), timestamp与用以签名中的对应noncestr, timestamp一致。
    2.确认url是页面完整的url(请在当前页面alert(location.href.split('#')[0])确认),包括'http(s)://'部分,以及'?'后面的GET参数部分,但不包括'#'hash后面的部分。
    确认 config 中的 appid 与用来获取 jsapi_ticket 的 appid 一致。
    3确保一定缓存access_token和jsapi_ticket。
    4.确保你获取用来签名的url是动态获取的,动态页面可参见实例代码中php的实现方式。如果是html的静态页面在前端通过ajax将url传到后台签名,前端需要用js获取当前页面除去'#'hash部分的链接(可用location.href.split('#')[0]获取,而且需要encodeURIComponent),因为页面一旦分享,微信客户端会在你的链接末尾加入其它参数,如果不是动态获取当前链接,将导致分享后的页面签名失败
    对于上面的文件大家可以到csdn上面下载或者评论私聊我下 我给大家发文件。
    创作不易,大家可以点个赞。嘿嘿(https://blog.csdn.net/weixin_44021417/article/details/106668042)

你可能感兴趣的:(vue 微信sdk的封装使用)