2015最新微信分享功能开发,自定义分享内容。
程序员文章站
2022-07-14 21:14:17
...
在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";
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秒,晕啊
详细可以参考下面链接
你的分享页面必须引入腾讯的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×tamp=1414587457&url=http://mp.weixin.qq.com?params=value //timestamp是时间戳,在服务端获取,并存储传入页面中 url是你展示页面的完整url地址
这样把上面字符串sha1加密后,传入客户端,并写入wx.config配置的signature中即可完成操作。