微信自定义分享的签名版实现

如果你没有微信公众号,那文章就不需要看了。此文介绍的是微信新版本的分享功能,2015年1月,微信已经抛弃了旧版本的分享。

微信的自定义分享功能,是病毒式传播的一把利剑。

demo

demo 请在微信中打开
demo2 请在微信中打开

分享接口应用,最常见的莫过于公众号文章分享。通过分享按钮,用户可以将自己喜欢的文章分享给微信好友,也可分享到微信朋友圈。
可以在用户分享时,为其设置个性化的分享图片、标题、描述等,从而使分享的内容更生动有趣,以获得更好的传播效果

有时候,你可能只需要做一个H5页面,没有相关的后台。但是微信的签名功能,又必须使用。所以,独立的后台是很有必要的,这个后台,能为任意公众号生成签名信息,微信的签名只有2个小时,所有缓存签名信息也是必须要实现的。

签名 signature

然而在使用这些牛逼的功能之前,有一座大山困在了开发者前面--signature。

分享的 web 页面需要先配置好微信的 js 才能正常使用分享等的功能。且看代码,

wx.config({
    appId: '', // 必填,公众号的唯一标识
    timestamp: , // 必填,生成签名的时间戳
    nonceStr: '', // 必填,生成签名的随机串
    signature: '',// 必填,签名,见附录1
    jsApiList: [] // 必填,需要使用的JS接口列表,所有JS接口列表见附录2
});

参数 timestampnonceStrsignature ,都由后台传递过来。不能硬编码到页面,因为 signature 的有效期为 2个小时。所以一个再简单的页面,都需要使用一个后台前面生成来支持。

再看 signature 的生成方法,

  1. 配置微信公众号
  2. 获取access_token
  3. 获取jsapi_ticket
  4. 签名算法
    复杂度可以吓尿你,算法参考微信JS-SDK官网。简单点描述
    noncestrjsapi_ticketurl 等参数连接 进行 sha1 加密。微信也给出了部分语言的实现源码) .

完整的实现

然后,生成这些东西都简单,可怎么和页面整合呢。 微信组件需要在页面加载后,初始化 wx的配置。

1. 引入微信 JS

<script src="http://res.wx.qq.com/open/js/jweixin-1.0.0.js"></script>
  1. 获取签名等参数
var sign;
  function jsonpCallback(data) {
    sign = data.sign;
    wx.config({
      debug: false,
      appId: 'wxd98888751036c960',
      timestamp: sign.timestamp,
      nonceStr: sign.nonceStr,
      signature: sign.signature,
      jsApiList: [
        // 所有要调用的 API 都要加到这个列表中
        'onMenuShareTimeline',
        'onMenuShareAppMessage',
        'onMenuShareQQ'
      ]
    });
  }
  // 根据当前页面路径动态获取token。 类似 url?timeline=user
  var str = "http://test.weixin.bigertech.com/api/sign?appId=wxd98888751036c960&callback=jsonpCallback&url="
  var href = encodeURIComponent(window.location.href);
  var script_elem = document.createElement("script");
  script_elem.src = str + href;
  document.body.appendChild(script_elem);

使用 JSONP的方式,传递参数 appidurl。因为一个appid 可能对应多个url,我有多个活动页面都需要使用到微信的分享。
因为js都是从上往下执行的,所以再jsonp回调之后,sign 被初始化了。sign中包含着签名、时间戳等信息。

需要注意的地方

url 是变化的。 页面分享到朋友圈后,微信会自动给链接加上

原链接 http://weixin.res.meizu.com/mx5story/index.html
分享到朋友圈后 http://weixin.res.meizu.com/mx5story/index.html?from=timeline&isappinstalled=0
分享给群组 http://weixin.res.meizu.com/mx5story/index.html?scene=4&from=groupmessage&isappinstalled=0

不同的url 需要再次申请一个签名

<script type="text/javascript">
  wx.config({
    debug: true,
    appId: 'wxd98888751036c960',
    timestamp: sign.timestamp,
    nonceStr: sign.nonceStr,
    signature: sign.signature,
    jsApiList: [
      // 所有要调用的 API 都要加到这个列表中
      'onMenuShareTimeline',
      'onMenuShareAppMessage',
      'onMenuShareQQ'
    ]
  });
</script>

后端

微信也给出了实现逻辑,后端唯一要做的,就是http请求的实现,和签名信息的缓存。说了这么多,直接上源码吧。
微信签名--源码实现

  1. clone 源码
  2. 安装nodejs环境
  3. npm install
  4. config/weixin.js 中配置自己的应用,这里需要配置自己的微信公众号,appid 和secret key。
  5. node app.js ok 已经运行了
  6. 实际上,一套这种系统,能为无数的 微信公众号提供签名信息服务,但是前提是你得把 secret key 给我,但是这种做法太不安全,不建议你这做。

完整的源码

微信签名--源码实现
html 5 源码例子

前端页面只能在公众号信任的域名下面运行,所以 html 5 源码例子 在你的服务器应该是不能运行 的。

附件:
微信朋友圈API分享代码自定义图标和分享链接。

微信JS-SDK 官方文档

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 159,015评论 4 362
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 67,262评论 1 292
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 108,727评论 0 243
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 43,986评论 0 205
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 52,363评论 3 287
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 40,610评论 1 219
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 31,871评论 2 312
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 30,582评论 0 198
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 34,297评论 1 242
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 30,551评论 2 246
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 32,053评论 1 260
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 28,385评论 2 253
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 33,035评论 3 236
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 26,079评论 0 8
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 26,841评论 0 195
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 35,648评论 2 274
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 35,550评论 2 270

推荐阅读更多精彩内容