设为首页 收藏本站
查看: 946|回复: 0

[经验分享] 微信JS-SDK“分享信息设置”API及数字签名生成方法(NodeJS版本)

[复制链接]

尚未签到

发表于 2017-2-22 13:04:18 | 显示全部楼层 |阅读模式
  先上测试地址以示成功:
  用微信打开下面地址测试
  http://game.4gshu.com/deep-love/index.html
  获直接扫二维码君
DSC0000.png


用异步ajax的方式获取数字签名

  异步的方式好
  1、前后端分离啊
  2、一个服务可以供多个微信公众帐号的数字签名服务
  在服务器端用NodeJS跑起一个数字签名生成服务,web端用ajax方式请求NodeJS服务获取数字签名信息
  得到信息后配置微信JS-SDK
DSC0001.png


步骤


第一步 认证的微信公众帐号


首先你得拥有一个通过认证了的微信公众号或者开发者帐号,没有通过认证的公众帐号。数字签名认证也能成功,但是分享信息是无法设置成功的;


第二步 添加安全域名


在公众帐号平台后台添加app运行的域名地址,可以理解为为某个域名添加白名单功能

以我们公司旗下的榕树下为例:

微信公众号是:榕树下,添加了game.4gshu.com为安全域名,那么我在game.4gshu.com上的网页可以使用榕树下公众帐号的数字签名了


第三步 生成数字签名


在微信公众平台后台上面能找到一个 appid 及 secret字符串

通过这两个数据,请求微信提供的两个公开API地址,生成对应的access_token后再生成ticket再通过规则加密成数字签名

注意,数字签名必须在服务端生成,这里我以NodeJS来实现

数字签名具体生成过程,NodeJS版本

DSC0002.png

1、获取微信签名所需的access_token




https.get('https://api.weixin.qq.com/cgi-bin/token?grant_type=client_credential&appid=你的appid写在这里&secret=你的secret写在这里', function(_res) {
// 这个异步回调里可以获取access_token
})
  2、获取微信签名所需的ticket



https.get('https://api.weixin.qq.com/cgi-bin/ticket/getticket?access_token=上一步中获取的access_token&type=jsapi', function(_res){
// 这个异步回调里可以获取ticket
});

3、生成数字签名具体方法

ticket、 noncestr、timestamp、url通过微信的规则用sha1加密

noncestr和timestamp在微信官方sample包中有具体的生成方法函数




// noncestr
var createNonceStr = function() {
return Math.random().toString(36).substr(2, 15);
};
// timestamp
var createTimeStamp = function () {
return parseInt(new Date().getTime() / 1000) + '';
};
  也可以参考我代码中的代码



// 计算签名方法
var calcSignature = function (ticket, noncestr, ts, url) {
var str = 'jsapi_ticket=' + ticket + '&noncestr=' + noncestr + '&timestamp='+ ts +'&url=' + url;
shaObj = new jsSHA(str, 'TEXT');
return shaObj.getHash('SHA-1', 'HEX');
}
var signature = calcSignature(ticket, noncestr, timestamp, url);

4、返回输出signature数字签名以及在生成数字签名时用到的timestamp、nonceStr、url、及appid

因为在客户内初始化微信JS-SDK中还要用到



5、至此数字签名生成成功


第四步 在web中如何使用数字签名?




1、引入微信JS-SDK

http://res.wx.qq.com/open/js/jweixin-1.0.0.js



2、请求服务器获取数字签名

在web上用ajax方式请求NodeJS服务地址,请求时将当前web地址url上传至服务器

服务器生成数字签名后返回:

signature,timestamp, appid, nonceStr

这四个数据用于配置微信JS-SDK


wx.config({
debug: true,
appId: appid,
timestamp: timestamp,
nonceStr: nonceStr,
signature: signature,
jsApiList: [
'checkJsApi',
'onMenuShareTimeline',
'onMenuShareAppMessage',
'onMenuShareQQ',
'onMenuShareWeibo',
'hideMenuItems',
'chooseImage'
]
});
  3、在wx.ready内调用API



wx.ready(function(){
var sdata = {
title: '那年|时光遗忘了,文字却清晰地复刻着',
desc: '那年|时光遗忘了,文字却清晰地复刻着',
link: 'http://game.4gshu.com/deep-love/index2.html',
imgUrl: 'http://game.4gshu.com/xuangedan/other-project/2015-01-06/img/share-wx-logo.jpg',
success: function () {
alert('用户确认分享后执行的回调函数');
},
cancel: function () {
alert('用户取消分享后执行的回调函数');
}
};
wx.onMenuShareTimeline(sdata);
wx.onMenuShareAppMessage(sdata);
});
  4、搞定

关于数字签名过期与微信API的1w次请求的限制问题




由于微信提供的两个数字签名生成API有7200秒的有效期,并且暂时有1w次的限制,所以在我们自己服务器上需要将数字签名缓存



逻辑是:

如果用户请求时没缓存中没有数字签名,那么请求执行第三步 生成数字签名

如果缓存中有,并且是在2小时内那么直接返回数字签名信息,不去请求微信服务器

如果缓存中的数字签名过期了(超过2小时)则还是执行第三步 生成数字签名





注意:由于微信规定地址栏中的参数发生变化都认作是新的请求地址,数字签名也需要重新生成。



新生成的数字签名将存入cachedSignatures对象内

缓存中的数据结构将url设为key

数据结构如下:


var cachedSignatures =  {
'http://game.4gshu.com/': {
appid: ’微信认证帐号的的appid'
,secret: '微信认证帐号的secret'
,timestamp: '1421135250'
,noncestr: 'ihj9ezfxf26jq0k'
}
}

测试项目源码

  我的项目源码已经放到Github上了,有需要的可以pull下来看一看,
  NodeJS我也是一知半解,将就着用,多有不足之处,欢迎交流
  源码地址:https://github.com/willian12345/wechat-JS-SDK-demo


======== ======== ======== ======== ======== ======== ======== ======== ======== ========

博客园willian12345

by sheldon.wang

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-345801-1-1.html 上篇帖子: 大熊君大话NodeJS之------基于Connect中间件的小应用(Bigbear记事本应用之第一篇) 下篇帖子: nodejs-基本语法
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表