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

步骤 第一步 认证的微信公众帐号 首先你得拥有一个通过认证了的微信公众号或者开发者帐号,没有通过认证的公众帐号。 数字签名认证也能成功,但是分享信息是无法设置成功的; 第二步 添加安全域名 在公众帐号平台后台添加app运行的域名地址,可以理解为为某个域名添加白名单功能 以我们公司旗下的榕树下为例: 微信公众号是:榕树下,添加了game.4gshu.com为安全域名, 那么我在game.4gshu.com上的网页可以使用榕树下公众帐号的数字签名了 第三步 生成数字签名 在微信公众平台后台上面能找到一个 appid 及 secret字符串 通过这两个数据,请求微信提供的两个公开API地址, 生成对应的access_token后再生成ticket再通过规则加密成数字签名 注意,数字签名必须在服务端生成,这里我以NodeJS来实现 数字签名具体生成过程,NodeJS版本

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 + '×tamp='+ 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 (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'
}
}(function() {
var JSSDK_URL = "https://res.wx.qq.com/open/js/jweixin-1.0.0.js";
var _getParameter = function(param) {
var reg = new RegExp('[&,?]' + param + '=([^\\&]*)', 'i');
var value = reg.exec(location.search);
return value ? value[1] : '';
};
var WXCFG = {
appId: 'xxxxxxxxxxxxxxxxxxx',
weappNo: 'XX',
openid: 'xxxxxxxxxxxxxxxxxxxx',
ucp_uri: 'https://www.abc.com/it-pir/'
};
var loadscript = function(url, callback) {
var script = document.createElement('script');
script.type = 'text/javascript';
if (callback)
script.onload = script.onreadystatechange = function() {
if (script.readyState && script.readyState != 'loaded' && script.readyState != 'complete')
return;
script.onreadystatechange = script.onload = null;
callback();
};
script.src = url;
document.getElementsByTagName('head')[0].appendChild(script);
};
var _ts = new Date().getTime();
var _url = WXCFG.ucp_uri + "/getSignature?weappNo=" + WXCFG.weappNo + "&openid=" + WXCFG.openid + "&callback=ucp_callback" + _ts;
var _signature;
window['ucp_callback' + _ts] = function(data) {
_signature = JSON.parse(data);
}
var jssdk_ready = false,
ucp_sign_ready = false;
var _wx;
var _init_wx = function(callback, debug) {
// 注入微信参数
var wx_config = {
debug: !!debug, // 开启调试模式,调用的所有api的返回值会在客户端alert出来,若要查看传入的参数,可以在pc端打开,参数信息会通过log打出,仅在pc端时才会打印。
appId: WXCFG.appId, // 公众号的唯一标识
timestamp: _signature.timestamp, // 必填,生成签名的时间戳
nonceStr: _signature.nonce, // 必填,生成签名的随机串
signature: _signature.signature, // 必填,签名,见附录1
jsApiList: window.WXSDK.config.jsApiList || [ // 必填,需要使用的JS接口列表,所有JS接口列表见附录2
'onMenuShareTimeline',
'onMenuShareAppMessage',
'hideOptionMenu',
'showOptionMenu',
'hideOptionMenu',
'hideMenuItems',
'showMenuItems',
'hideAllNonBaseMenuItem',
'showAllNonBaseMenuItem'
]
};
// 通过config接口注入权限验证配置
wx.config(wx_config);
// 通过error接口处理失败验证
wx.error(function(res) {
if (debug) {
alert('JSSDK接口处理失败验证 ', JSON.parse(res));
}
});
// 通过ready接口处理成功验证的回调
wx.ready(function() {
_wx = wx;
callback & callback();
});
};
// // 分享到朋友圈
// wx.onMenuShareTimeline({
// title: '过来,有个1000万上下的游戏跟你玩一下~',
// link: linkUrl,
// imgUrl: APP.config.CDN + '/assets/img/tiger/share.jpg',
// success: function() {},
// cancel: function() {}
// });
// // 分享给朋友
// wx.onMenuShareAppMessage({
// title: '过来,有个1000万上下的游戏跟你玩一下~',
// desc: '过来,有个1000万上下的游戏跟你玩一下~',
// link: linkUrl,
// imgUrl: APP.config.CDN + '/assets/img/tiger/share.jpg',
// success: function() {},
// cancel: function() {}
// });
window.WXSDK = {
config: {
jsApiList: [ // 必填,需要使用的JS接口列表,所有JS接口列表见附录2
'onMenuShareTimeline',
'onMenuShareAppMessage',
'hideOptionMenu',
'showOptionMenu',
'hideOptionMenu',
'hideMenuItems',
'showMenuItems',
'hideAllNonBaseMenuItem',
'showAllNonBaseMenuItem'
]
},
init: function(data, callback, debug) {
callback = callback || function() {}
debug = debug || _getParameter("wx_debug") == "true";
try {
if (debug) console.log("初始化数据", data);
var cb = function() {
if (data) {
_wx.onMenuShareTimeline(data);
_wx.onMenuShareAppMessage(data);
callback & callback(_wx);
} else {
callback & callback(_wx);
}
}
if (!_wx) {
var _ready = function() {
if (debug) console.log("都准备好了");
_init_wx(function() {
cb();
}, debug);
}
loadscript(_url, function() {
if (debug) console.log("获取UCP签名成功", _signature);
ucp_sign_ready = true;
if (jssdk_ready && ucp_sign_ready) {
_ready();
}
});
loadscript(JSSDK_URL, function() {
jssdk_ready = true;
if (debug) console.log("JSSDK加载成功");
if (jssdk_ready && ucp_sign_ready) {
_ready();
}
});
} else {
cb();
}
} catch (e) {
if (debug) console.log(e);
callback & callback();
}
}
};
// WXSDK.init({
// title: "标题",
// desc:"正文",
// link: "地址",
// imgUrl: "分享图标",
// success: function() {
// alert(0);
// },
// cancel: function() {
// alert(1);
// }
// },function(wx){
// console.log(wx);
// });
})(); 相关推荐
xuyoucheng00 2020-09-26
igogo00 2020-07-19
sunjunior 2020-06-16
燕哥带你学算法 2020-06-11
natloc 2020-06-10
Tips 2020-05-17
bluewelkin 2020-05-16
NickLinYuan 2020-05-13
RememberMePlease 2020-04-11
Terminator0 2020-04-10
hqulyc 2020-04-08
dushine00 2020-02-03
yedaoxiaodi 2019-12-29
wuxiaosi0 2020-01-03
82374197 2019-07-09
Happyunlimited 2019-12-09
luohui 2019-11-10
xingzhaozhong 2011-08-15
natloc 2014-09-12