只列前端需要做的工作
1、请确认公众号已经认证,只有认证的公众号才具有分享相关接口权限
2、登录微信公众平台进入“公众号设置”的“功能设置”里填写“JS接口安全域名”。(需要调用微信接口的h5域名)
3、在需要调用JS接口的页面引入如下JS文件,(支持https):http://res.wx.qq.com/open/js/jweixin-1.6.0.js
4、配置IP白名单,基本配置-公众号开发信息-IP白名单。(调用后台接口的域名)
var title = h5_title;//这里是标题
var desc = share_content;//这里是描述
var imgUrl = url_img + share_img;//这里是图片
$.ajax({
url:url_jk+"/html/wxgetjsapi?url=" + link,
type: "GET",
dataType: "json",
success: function (res) {
console.log(res);
wx.config({
debug: false,//开启调试模式,调用的所有api的返回值会在客户端alert出来,若要查看传入的参数,可以在pc端打开,参数信息会通过log打出,仅在pc端时才会打印。
appId: res.appid,// 必填,公众号的唯一标识
timestamp: res.timestamp,// 必填,生成签名的时间戳
nonceStr: res.nonceStr,// 必填,生成签名的随机串
signature: res.signature,// 必填,签名
jsApiList: ["onMenuShareTimeline", "onMenuShareAppMessage","updateTimelineShareData", "updateAppMessageShareData",]// 必填,需要使用的JS接口列表
});
wx.ready(function () {
// config信息验证后会执行ready方法,所有接口调用都必须在config接口获得结果之后,config是一个客户端的异步操作,
// 所以如果需要在页面加载时就调用相关接口,则须把相关接口放在ready函数中调用来确保正确执行。对于用户触发时才调用的接口,则可以直接调用,不需要放在ready函数中。
//分享到朋友圈
wx.onMenuShareTimeline({
title: title,// 分享标题
link: link,// 分享链接,该链接域名或路径必须与当前页面对应的公众号JS安全域名一致
imgUrl: imgUrl,// 分享图标
success: function () {
// 设置成功
}
});
//分享给微信好友
wx.onMenuShareAppMessage({
title: title,
desc: desc, // 分享描述
link: link,
imgUrl: imgUrl,
type: "",// 分享类型,music、video或link,不填默认为link
dataUrl: "",// 如果type是music或video,则要提供数据链接,默认为空
success: function () {}
});
// 自定义“分享到朋友圈”及“分享到QQ空间”按钮的分享内容
wx.updateTimelineShareData({
title: title,
link: link,
imgUrl: imgUrl,
success: function () {}
});
// 自定义“分享给朋友”及“分享到QQ”按钮的分享内容
wx.updateAppMessageShareData({
title: title,
desc: desc,
link: link,
imgUrl: imgUrl,
success: function () {}
})
})
},
error: function (res) {
// config信息验证失败会执行error函数,如签名过期导致验证失败,具体错误信息可以打开config的debug模式查看,也可以在返回的res参数中查看,对于SPA可以在这里更新签名。
console.log("通信失败");
}
})
问题:从别人分享的链接点进去再分享出来,自定义缩略图和内容丢失
原因:微信在分享的时候,会自动给你的地址后面加入参数,导致你分享的地址改变了,这时候再去用原来的地址获取签名,就不能用了。
后面带上了这一串参数:?from=singlemessage&isappinstalled=0
解决办法:截掉地址后面给你加的那一串参数,重置地址
var link = location.href.split("#")[0];//获取url替换#后面的部分hash值
if(link.indexOf("&")>-1){
link = link.substring(0,link.indexOf("&"))
window.location.href = link;
}
测试有效!!!
更多内容,请关注公众号