大橙子网站建设,新征程启航
为企业提供网站建设、域名注册、服务器等服务
本文实例为大家分享了nodeJS微信分享的具体代码,供大家参考,具体内容如下
创新互联建站专注为客户提供全方位的互联网综合服务,包含不限于做网站、网站建设、番禺网络推广、重庆小程序开发公司、番禺网络营销、番禺企业策划、番禺品牌公关、搜索引擎seo、人物专访、企业宣传片、企业代运营等,从售前售中售后,我们都将竭诚为您服务,您的肯定,是我们最大的嘉奖;创新互联建站为所有大学生创业者提供番禺建站搭建服务,24小时服务热线:18980820575,官方网址:www.cdcxhl.com
一、接入微信JSSDK
直接引用或者下载本地都行
二、JS请求node后台签名、随机数、时间戳之类的
function getWxSignature() { $.ajax({ url: "/activityWxShaer", type: 'post', data: { urlhref:location.href }, success: function(jsons) { var data = JSON.parse(jsons); wx.config({ debug: false, // 开启调试模式,调用的所有api的返回值会在客户端alert出来,若要查看传入的参数,可以在pc端打开,参数信息会通过log打出,仅在pc端时才会打印。 appId: 'xxxxxxxxx', // 必填,公众号的唯一标识 timestamp: data.timestamp, // 必填,生成签名的时间戳 nonceStr: data.nonceStr, // 必填,生成签名的随机串 signature: data.signature, // 必填,签名,见附录1 jsApiList: [ 'onMenuShareTimeline', 'onMenuShareAppMessage', 'onMenuShareQQ', 'onMenuShareWeibo', 'onMenuShareQZone' ] // 必填,需要使用的JS接口列表,所有JS接口列表见附录2 }); shareFunc();// 微信的分享接口 里面为ready } }); }
三、nodeJS express 路由
/** * 分享 */ router.post('/activityWxShaer', function(req, res, next) { let hrefURL = req.body.urlhref; wxShare.prototype.accessToken(hrefURL, function(data) { res.json(data); }); });
四、nodeJS签名,微信重点签名,我是采用sha1 ,我看了好多都是用sha-1,HEX之类的不知道是不是我环境的问题,我不能用最后只能自己写了
/**
* 签名
* @param {*} url
*/
sign(url) {
let _this = this;
var ret = {
jsapi_ticket: configEnd.ticket,
nonceStr: configEnd.nonceStr,
timestamp: configEnd.timestamp,
url: url
};
var string = _this.rawString(ret);
var shaObjs = sha1(string);
return shaObjs;
};
四、nodeJS后台代码直接上整体代码
[javascript] view plain copy
var url = require('url');
var request = require('request');
var sha1 = require('sha1');
let config = {
appID: "",// 微信公众号ID
appSecret: "" //微信公众号里有
},
configEnd = {
appID: '',
access_token: '',
ticket: '',
timestamp: '', // 必填,生成签名的时间戳
nonceStr: '', // 必填,生成签名的随机串
signature: '', // 必填,签名,见附录1
};
/**
* 微信分享
*/
class wxShare {
/**
* 请求获取access_token 方法入口
* @param {* URL链接} hrefURL
* @param {* 回调请求方法} callback
*/
accessToken(hrefURL, callback) { // 获取access_token
let _this = this;
var tokenUrl = 'https://api.weixin.qq.com/cgi-bin/token?grant_type=client_credential&appid=' + config.appID + '&secret=' + config.appSecret;
request(tokenUrl, function(error, response, body) {
if (response.statusCode && response.statusCode === 200) {
body = JSON.parse(body);
configEnd.access_token = body.access_token;
_this.upJsapiTicket(hrefURL, body.access_token, callback)
}
});
};
/**
* 获取Jsapi_Ticket
* @param {* URL链接} hrefURL
* @param {* token} access_Ttoken
* @param {* 回调请求方法} callback
*/
upJsapiTicket(hrefURL, access_Ttoken, callback) { // Jsapi_ticket
let _this = this;
var ticketUrl = 'https://api.weixin.qq.com/cgi-bin/ticket/getticket?access_token=' + access_Ttoken + '&type=jsapi';
request(ticketUrl, function(err, response, content) {
content = JSON.parse(content);
if (content.errcode == 0) {
configEnd.ticket = content.ticket; // ticket
configEnd.timestamp = _this.createTimestamp(); // 时间戳
configEnd.nonceStr = _this.createNonceStr(); // 随机数
configEnd.signature = _this.sign(hrefURL); // 签名
callback && callback(configEnd); // 回调前端JS方法
}
})
};
/**
* 随机字符串
*/
createNonceStr() {
return Math.random().toString(36).substr(2, 15);
};
/**
* 时间戳
*/
createTimestamp() {
return parseInt(new Date().getTime() / 1000).toString();
};
/**
* 拼接字符串
* @param {*} args
*/
rawString(args) {
var keys = Object.keys(args);
keys = keys.sort()
var newArgs = {};
keys.forEach(function(key) {
newArgs[key.toLowerCase()] = args[key];
});
var string = '';
for (var k in newArgs) {
string += '&' + k + '=' + newArgs[k];
}
string = string.substr(1);
return string;
};
/**
* 签名
* @param {*} url
*/
sign(url) {
let _this = this;
var ret = {
jsapi_ticket: configEnd.ticket,
nonceStr: configEnd.nonceStr,
timestamp: configEnd.timestamp,
url: url
};
var string = _this.rawString(ret);
var shaObjs = sha1(string);
return shaObjs;
};
}
module.exports = wxShare;
就一普通的ajax请求nodeJS后台,后台返回封装好的数据。
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持创新互联。