在2015年之前很长一段时间,微信分享功能,只需要页面埋几段js代码即可捕获用户点击分享按钮的事情,并且自定义。

但后来微信的新版本里已经屏蔽了次方法直接调用分享接口

需要在服务端坐一点开发工作。

当然你的呈现页面,比如html最终还是需要js代码,不过js代码需要做一个signature的签名处理。

只有这个正确的signature腾讯微信才允许你调用分享接口,并自定义分享菜单的内容。

页面代码如下:

写道
<script type="text/javascript">

var signature = "8cd09386c103dee9c2c98a8t49a126drea39f1ad";
var timestampNum = "1442538327"; //这里是时间戳,需要在服务端获取后传到客户端中。加密需要用到
wx.config({
debug: true, // 开启调试模式,调用的所有api的返回值会在客户端alert出来,若要查看传入的参数,可以在pc端打开,参数信息会通过log打出,仅在pc端时才会打印。
appId: 'wxex020f1cb01435e9', // 必填,公众号的唯一标识
timestamp: timestampNum, // 必填,生成签名的时间戳
nonceStr: timestampNum, // 必填,生成签名的随机串
signature: signature,// 必填,签名,见附录1
jsApiList: ['checkJsApi','onMenuShareTimeline','onMenuShareAppMessage','onMenuShareAppMessage','onMenuShareQQ'] // 必填,需要使用的JS接口列表,所有JS接口列表见附录2
});

wx.ready(function(){
// config信息验证后会执行ready方法,所有接口调用都必须在config接口获得结果之后,config是一个客户端的异步操作,所以如果需要在页面加载时就调用相关接口,则须把相关接口放在ready函数中调用来确保正确执行。
//对于用户触发时才调用的接口,则可以直接调用,不需要放在ready函数中。
//分享到朋友圈
wx.onMenuShareTimeline({
title: '中秋祝福2015', // 分享标题
link: 'http://weixin.xxxx.com/xxxx.php', // 分享链接
imgUrl: 'http://images.xxxx.com/xxxx/M00/00/0C/wKgF9FX2sad3f5tAAkrdgEd3146.jpg', // 分享图标
desc: "这里你可以写你需要分享的内容简介",
success: function () {
// 用户确认分享后执行的回调函数
alert("分享到朋友圈成功.");
},
cancel: function () {
// 用户取消分享后执行的回调函数
}
});

//获取“分享给朋友”按钮点击状态及自定义分享内容接口
wx.onMenuShareAppMessage({
title: '中秋祝福2015', // 分享标题
desc: '这里写分享的内容简介', // 分享描述
link: 'http://weixin.xxxx.com/xxx.php', // 分享链接
imgUrl: 'http://images.xxxx.com/xxxx/M00/00/0C/wKgF9d2dff3t5tAA4fxts146.jpg', // 分享图标
type: '', // 分享类型,music、video或link,不填默认为link
dataUrl: '', // 如果type是music或video,则要提供数据链接,默认为空
success: function () {
// 用户确认分享后执行的回调函数
alert("分享给朋友成功.");
},
cancel: function () {
// 用户取消分享后执行的回调函数
}
});
});

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

});

</script>

上述代码最关键的就是获取正确的

var signature = "8cd09386c103dee9c2c98a8t49a126drea39f1ad";

腾讯微信开发文档里有介绍,比较麻烦,需要多步骤,我感觉腾讯做这个真是蛋疼,就不能简化步骤吗?

获取服务端的token还需要2次,时间也就只有7200秒,晕啊

详细可以参考下面链接

http://mp.weixin.qq.com/wiki/7/aaa137b55fb2e0456bf8dd9148dd613f.html#.E6.AD.A5.E9.AA.A4.E4.B8.80.EF.BC.9A.E7.BB.91.E5.AE.9A.E5.9F.9F.E5.90.8D

你的分享页面必须引入腾讯的js文件

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

要得到上面的signature签名,比较麻烦,这里要吐槽腾讯的技术人员

首先要通过下面链接获取一个token

http请求方式: GET
https://api.weixin.qq.com/cgi-bin/token?grant_type=client_credential&appid=APPID&secret=APPSECRET

这个token有效期7200秒,得到后

在拿到这个token以后,还需要通过这个token到下面链接

https://api.weixin.qq.com/cgi-bin/ticket/getticket?access_token=ACCESS_TOKEN&type=jsapi

获取一个新的token,也就是jsapi_ticket

然后通过最后这个新的token

使用sha1加密

下面是需要加密的串

jsapi_ticket=sM4AOVdWfPE4DxkXGEs8VMCPGGVi4C3VM0P37wVUCFvkVAy_90u5h9nbSlYy3-Sl-HhTdfl2fzFy1AOcHKP7qg&noncestr=Wm3WZYTPz0wzccnW&timestamp=1414587457&url=http://mp.weixin.qq.com?params=value//timestamp是时间戳,在服务端获取,并存储传入页面中  url是你展示页面的完整url地址

这样把上面字符串sha1加密后,传入客户端,并写入wx.config配置的signature中即可完成操作。

2015最新微信分享功能开发,自定义分享内容。相关推荐

  1. 微信公众号开发 自定义分享 从前台到Java后台 调用微信JS接口分享朋友圈

    20180811写在前面的话 有很多人遇到问题之后问我,结果大多数是因为配置问题,所以请详细阅读前面的配置步骤. 20181016注意事项 收到反馈,之前写的接口即将废弃,源代码中的js接口需要修改, ...

  2. 公众号分享页面php,微信公众号网页分享功能开发的示例代码

    现在每天都可以看到很多微信分享的链接上面有网站或者商家的自定义的分享标题,和分享链接的描述及分享出去的图像,例如下面的分享出去的链接: 上面这个是微信的js-SDK页面分享给微信好友在聊天列表中显示的 ...

  3. 【安卓开发】调用系统原生的文件分享功能将文件分享给QQ或微信好友

    调用系统原生的文件分享功能将文件分享给QQ或微信好友 核心代码: //传入的fileName是文件名的全路径@SuppressLint("QueryPermissionsNeeded&quo ...

  4. 微信内 H5 页面自定义分享

    起源: 最近公司在做一个活动的h5页面,在微信内打开时需要进行微信授权,然后后端会重定向到这个页面并且携带了一些参数(openid等).问题是点击微信的原生分享时,会把携带的这些参数一起分享出去,等于 ...

  5. 微信公众号开发之分享接口实现

    微信公众号开发之分享接口实现 第一步:先登录微信公众平台进行设置JS接口安全域名("域名不能包含http://"). 如图: 第二步:配置config接口权限验证 首先需要通过获取 ...

  6. 微信小程序之——自定义分享按钮(完整版)

    声明 onShareAppMessage 函数 onShareAppMessage() { return {          title: '弹出分享时显示的分享标题'        desc: ' ...

  7. 语音朗读html的源码,网页中文本朗读功能开发实现分享

    网页中文本朗读功能开发实现分享 前几天完成了一个需求,在网页中完成鼠标指向哪里,就用语音读出所指的文本.如果是按钮.链接.文本输入框,则还还要给出是什么的提醒.同时针对大段的文本,不能整段的去读,要按 ...

  8. java自定义菜单跳转页面_微信公众号开发 自定义菜单跳转页面并获取用户信息实例详解...

    微信公众号开发 自定义菜单 请先读完本文再进行配置开发 请先前往微信平台开发者文档阅读"网页授权获取用户基本信息"的接口说明 在微信公众账号开发中,往往有定义一个菜单,然后用户点击 ...

  9. 微信公众号开发,微信支付功能开发(网页JSAPI调用)

    1.微信支付的流程 如下三张手机截图,我们在微信网页端看到的支付,表面上看到的是 "点击支付按钮 - 弹出支付框 - 支付成功后出现提示页面",实际上的核心处理过程是: 点击支付按 ...

  10. java 微信自动回复功能开发

    java 微信自动回复功能开发 准备文件: JCE无限制权限策略文件,里面是对应jdk6和7的文件 官网下载地址是http://www.oracle.com/technetwork/java/java ...

最新文章

  1. 显示来自多个表的数据——JOIN
  2. Git学习笔记07-删除文件
  3. 深入浅出 Javascript API(五)--Query Find 查询
  4. 信息系统项目管理知识--计算机网络基础
  5. 深入理解了MySQL,你才能说熟悉数据库
  6. vue将文本渲染html,vue2.0 之文本渲染-v-html、v-text
  7. Allocate aligned memory
  8. 【图像处理】MATLAB:亮度变换
  9. 发展需要大师,繁荣更需批评——GIS现状堪忧
  10. git回滚到某个版本操作
  11. vb语言和python语言_用VB“写”Python程序
  12. 《网络协议从入门到底层原理》学习笔记
  13. java简单的猜数字游戏
  14. 一杯苦咖啡 | 公司来了个漂亮女实习程序员
  15. CUDA C编程(三十)OpenACC的使用
  16. Rancher 2.2 GA:企业进入应用跨多K8S集群、混合云部署新时代
  17. 一文读懂区块链与大数据的关系
  18. 智慧医院三维可视化决策系统平台(数字孪生)-解决方案开发案例
  19. php 加载 java.so,请教,php扩展加载第三方.so文件时出错
  20. 什么是软件测试?软件测试的目的是什么?划分为哪几个阶段?

热门文章

  1. 《C++程序设计语言》5.9_11输入读一系列的单词,使用quit作为输入的结束单词
  2. “鸿蒙之父”王成录重申:鸿蒙系统不是安卓套壳;苹果多款产品电池修理费将涨价;Debian移除Python 2|极客头条
  3. 玩转论坛营销巧获永久自然流量
  4. 家用PC机打造VSphere5.1 测试环境:之部署VCenter Server 5.1
  5. 七步教你从0到1创建客户服务团队
  6. 7-52 输出字符画:HAUT
  7. 量子计算机不是永动机,几种人类设计的永动机,最后一个是谁设计的!彻底服了!...
  8. easyswoole和mixphp_关于thinkphp5和swoole通过SMTP方式实现异步邮件群发的详解 - easyswoole...
  9. routeros 3322电信联通脚本
  10. c语言录取分数线,近三年各省市录取分数线