vue 项目如何引入微信sdk,使用微信分享接口

写在前面:

作微信的网页基本上都要接入微信的sdk,我在作的时候,也颇费了一番功夫,而后就想记录一下,供本身往后翻阅,以及让有须要的朋友能够作一下参考,若是喜欢的能够点波赞,或者关注一下,但愿能够帮到你们。前端

本文首发于个人我的blog:obkoro1.comvue

安装sdk

npm install weixin-js-sdk --save
复制代码

开始以前你们能够先读一读微信公众号的 接入文档,vue是单页面项目,好比你想要接入微信分享功能,分享功能在每一个路由地址都要有,由于每一个路由的url是不同的,因此就须要在每一个路由地址都引入一遍。ios

总体步骤:

  1. vue引入sdk的话,就是在路由组件里面的,组件生命周期的:creatd()和mounted()里面放代码。算法

  2. 用伪代码,熟悉一下总体的流程,要作哪些事情:npm

    //wx是引入的微信sdk
     wx.config('这里有一些参数');//经过config接口注入权限验证配置
     
     wx.ready(function() { //经过ready接口处理成功验证
     // config信息验证成功后会执行ready方法
         wx.onMenuShareAppMessage({ // 分享给朋友  ,在config里面填写须要使用的JS接口列表,而后这个方法才能够用 
             title: '这里是标题', // 分享标题
             desc: 'This is a test!', // 分享描述
             link: '连接', // 分享连接
             imgUrl: '图片', // 分享图标
             type: '', // 分享类型,music、video或link,不填默认为link
             dataUrl: '', // 若是type是music或video,则要提供数据连接,默认为空
             success: function() {
                 // 用户确认分享后执行的回调函数
             },
             cancel: function() {
                 // 用户取消分享后执行的回调函数
             }
              });
             wx.onMenuShareTimeline({ //分享朋友圈
             title: '标题', // 分享标题
             link: '连接',
             imgUrl: '图片', // 分享图标
             success: function() {
                 // 用户确认分享后执行的回调函数
             },
             cancel: function() {
                 // 用户取消分享后执行的回调函数
             }
         });
     });
      wxx.error(function(res){//经过error接口处理失败验证
         // config信息验证失败会执行error函数
     });
    复制代码

上面的流程多看几遍,对整个流程有个概念,其中最重要的一步就是下面这个接口注入权限。axios

config接口注入权限

接入微信接口的最主要也是最重要一步步就是填写下面这些信息,填完这些信息以后,基本就行了。下面这些信息一般是经过后端接口来获取的。后端

wx.config({
    debug: true, // 开启调试模式,调用的全部api的返回值会在客户端alert出来,若要查看传入的参数,能够在pc端打开,参数信息会经过log打出,仅在pc端时才会打印。
    appId: '', // 必填,公众号的惟一标识
    timestamp: , // 必填,生成签名的时间戳
    nonceStr: '', // 必填,生成签名的随机串
    signature: '',// 必填,签名,见附录1
    jsApiList: [] // 必填,须要使用的JS接口列表,全部JS接口列表见附录2
});
复制代码

获取config配置信息:

前端要获取上面那些信息,不用作太多东西,只要调后端接口就能够了。后端会把那些信息处理好,而后经过一个接口返给你这些参数。你要给后端传一个当前路由页面的完整url,后端就会返回上述的那些信息给你,后面就能够根据本身的需求调用相应的接口,自定义里面的东西。api

坑点:url

这里要注意的就是url的问题,若是url没有正确传递,后端也会返回信息,可是签名信息会是错误的。微信

上面提到的完整url指的是:'http(s)://'部分,以及'?'后面的GET参数部分,但不包括'#'hash后面的部分。能够经过location.href来获取。app

注意: 若是你的vue项目,路由没有开启history 模式,也就是你的url上面包含“#”,这个时候要从后端正确获取签名,就须要去掉url上#后面的字符。(url去掉'#'hash部分,可用location.href.split('#')[0]

封装调用sdk注入:

由于要在每一个路由页面都注入sdk,这个确定要复用的,否则那么多代码,看着就头大。

我是这么作的:

  1. 由于我把axios包了一层,而后把axios接口,在main.js里面挂载到Vue实例。
  2. 而后在全局函数里面调用这个接口,而后在每一个路由页面的相应组件里面调用这个函数,把当前页面的url以及其余标题、图片什么的传进去。

里面的具体步骤就不说了,最重要的是参考上面的那个流程,函数里面的东西也都是基于那个流程的。

签名校验:

当你反复确认步骤都没有问题,微信sdk注入仍是签名失败的时候,这个时候你就要考虑是否是后端那边的算法有问题,能够把后端返回的签名和微信提供的JS 接口签名校验工具生成的签名对比一下,或许是后端那边算法的问题也不必定。

后话

实不相瞒,当时我作的时候就是被url这个坑了,第一次作这个东西,没有经验,折腾了很久。引入sdk并不难,重要的是那个配置信息要填写正确,而后其余的就根据实际需求来作了。

最后:如需转载,请放上原文连接并署名。码字不易,感谢支持!本人写文章本着交流记录的心态,写的很差之处,不撕逼,可是欢迎指点。而后就是但愿看完的朋友点个喜欢,也能够关注一下我。 我的blog and 掘金我的主页

以上2017.12.16

相关文章
相关标签/搜索