微信的朋友圈分享是现在流行的推广模式,最近两天尝试了一下使用微信进行商品的分享,分享结束后我可以在自己的数据库中查询到用户是否分享成功,包括用户使用微信进行支付时的成功验证。个人觉得微信上的教程有些绕,因为学习时间比较短,方法不尽详细和完善。

1.注册微信服务号/订阅号(微信公众平台

2.订阅号企业认证(个人认证无法操作分享接口,非服务号企业认证无法操作支付接口)

3.手里需要有自己的服务器,申请域名及解析至服务器。(网站上线流程)

4.进行服务端的开发,监听服务端80端口,接收微信参数(在成为微信开发者时,微信将以get方式请求域名,开发者需接收微信传来的参数,并使用排序、加密等算法验证其是否来源于微信)

5.在微信公众平台申请成为开发者,首先会获得appid、appsecret,在配置信息中会要求填入url和token

url:www.xxx.com       token:任意字符串(此字符串用户验证消息)  加密方式:随机即可

6.填写完配置信息后,点击提交,微信会向服务器发送请求,接受参数并验证。

微信首次验证开发者将传递4个参数,获取代码如下:

var http = require('http');
var url = require('url');
//微信返回接收变量
var weixinReturn = {
signature:'',
timestamp:'',
nonce:'',
echostr:'',
state:'验证失败'
};
//启动服务,监听配置路径及端口
http.createServer(function (req, res) {//获取访问路径
var urlObj = url.parse(req.url,true);
//json格式的参数列表
var param = urlObj.query
//获取路径
var pathName = urlObj.pathname;
//编码
res.setHeader('content-type', 'text/html;charset=utf-8'); /*
* 验证信息是否来自于微信
*/
if(pathName === '/'){ weixinReturn.signature = param.signature;
weixinReturn.timestamp = param.timestamp;
weixinReturn.nonce = param.nonce;
weixinReturn.echostr = param.echostr; weichat.isFromWeiChat(
weixinReturn.signature,
weixinReturn.timestamp,
weixinReturn.nonce,
'用户自定义的token字符串', function (right) {
/**
* 如果数据验证成功
* 状态修改为成功
* 否则修改为失败
*/
if(right){
weixinReturn.state = '验证成功';
}else{
weixinReturn.state = '验证失败';
}
//控制台打印成功消息
console.log('数据验证完毕,已成为微信开发者,基础数据存入./weiChatReturn.json');
/*
*将数据写入文件
* 如文件不存在 则在运行目录下创建文件
*/
fs.writeFileSync('weiCaht.json',JSON.stringify(weixinReturn)); //为微信服务器返回echostr参数 以告知验证成功
res.end(weixinReturn.echostr);
});
}
}).listen(conn.hostPort);

weichat.js

/**
* 验证信息是否来源于微信
* @param signature
* @param timestamp
* @param nonce
* @param token
* @param callback
*/
weiChat.isFromWeiChat = function(signature,timestamp,nonce,token,callback){
var array=new Array();
array[0]=timestamp;
array[1]=nonce;
array[2]=token;
array.sort();
var hasher=crypto.createHash("sha1");
var msg=array[0]+array[1]+array[2];
hasher.update(msg);
var msg=hasher.digest('hex');//计算SHA1值
if(msg==signature){
callback(true);
}else{
callback(false);
}
}

7.获取 access_token、jsapi_ticket

/**
* 获取token\ticket
* @param callback
* @constructor
* ticket path: '/cgi-bin/ticket/getticket?access_token={0}&type=jsapi'.format(token),
* token path: '/cgi-bin/token?grant_type=client_credential&appid={0}&secret={1}'.format(appId,secret),
*/
weiChat.GetChatMessage = function (path,callback){
var options = 'https://api.weixin.qq.com{0}'.format(path); var req = http.request(options, function (res) {
//状态码
console.log('STATUS: ' + res.statusCode);
//头文件
console.log('HEADERS: ' + JSON.stringify(res.headers));
//编码模式
res.setEncoding('utf8');
res.on('data', function (chunk) {
console.log('BODY: ' + chunk);
callback(chunk);
});
}); req.on('error', function (e) {
console.log(' 获取失败,错误信息: ' + e.message);
}); req.end();
}

注:微信对于access_token、jsapi_ticket 有7200秒的过期时间,解决方案是将方法放入setInterval函数中定时执行,将获取到的access_token、jsapi_ticket缓存在程序,或存储在数据库中。

8.生成签名signature

/**
* 获取签名
* @param currUrl 当前页面地址
* @param timestamp 时间截
* @param nonceStr 获取的nonce字符串
* @param ticket
* @param callback
*/
weiChat.getSignature = function (currUrl,timestamp,nonceStr,ticket,callback) {
var string1 = 'jsapi_ticket={0}&nonceStr={1}&timestamp={2}&url={3}'.format(ticket,nonceStr,timestamp,currUrl);
var hasher=crypto.createHash("sha1");
hasher.update(string1);
var msg=hasher.digest('hex');//计算SHA1值
callback(msg);
}

9.以上完成了微信的开发者需求,接下来进行分享页面的配置。(微信JSSDK的使用

注:在页面js中为保证分享成功,须获取实时最新的token和ticket,解决方法是前台html页面中使用jQuery ajax请求后台node服务端,将最新的值返回后,进行jweixin/wx 的各接口方法配置。

node.weiChat的更多相关文章

  1. babeljs源码

    babel.min.js!function(e,t){"object"==typeof exports&&"object"==typeof mo ...

  2. NPM (node package manager) 入门 - 基础使用

    什么是npm ? npm 是 nodejs 的包管理和分发工具.它可以让 javascript 开发者能够更加轻松的共享代码和共用代码片段,并且通过 npm 管理你分享的代码也很方便快捷和简单. 截至 ...

  3. node服务的监控预警系统架构

    需求背景 目前node端的服务逐渐成熟,在不少公司内部也开始承担业务处理或者视图渲染工作.不同于个人开发的简单服务器,企业级的node服务要求更为苛刻: 高稳定性.高可靠性.鲁棒性以及直观的监控和报警 ...

  4. node.js学习(三)简单的node程序&&模块简单使用&&commonJS规范&&深入理解模块原理

    一.一个简单的node程序 1.新建一个txt文件 2.修改后缀 修改之后会弹出这个,点击"是" 3.运行test.js 源文件 使用node.js运行之后的. 如果该路径下没有该 ...

  5. 细说WebSocket - Node篇

    在上一篇提高到了 web 通信的各种方式,包括 轮询.长连接 以及各种 HTML5 中提到的手段.本文将详细描述 WebSocket协议 在 web通讯 中的实现. 一.WebSocket 协议 1. ...

  6. 高大上的微服务可以很简单,使用node写微服务

    安装 npm install m-service --save 使用 编写服务处理函数 // dir1/file1.js // 使用传入的console参数输出可以自动在日志里带上request id ...

  7. 构建通用的 React 和 Node 应用

    这是一篇非常优秀的 React 教程,这篇文章对 React 组件.React Router 以及 Node 做了很好的梳理.我是 9 月份读的该文章,当时跟着教程做了一遍,收获很大.但是由于时间原因 ...

  8. 利用Node.js的Net模块实现一个命令行多人聊天室

    1.net模块基本API 要使用Node.js的net模块实现一个命令行聊天室,就必须先了解NET模块的API使用.NET模块API分为两大类:Server和Socket类.工厂方法. Server类 ...

  9. Node.js:进程、子进程与cluster多核处理模块

    1.process对象 process对象就是处理与进程相关信息的全局对象,不需要require引用,且是EventEmitter的实例. 获取进程信息 process对象提供了很多的API来获取当前 ...

随机推荐

  1. ajax完成list无刷新返回

    ajax完成list无刷新返回 ajax无刷新技术总结,以下是一段我写的ajax应用的js脚本.其中提交的data刚开始我采用的是$('#formId').serialize();但是出现乱码问题,为 ...

  2. php配置redis支持

    在php.ini里面添加下面两行,注意这两行的顺序一定不要颠倒(扩展库下载网址https://github.com/phpredis/phpredis/downloads),同时注意这2个文件的版本一 ...

  3. C语言Printf格式

    使用printf打印时发现,如果数据类型和打印使用的类型不一致,结果就是混乱的. 这是因为printf本身并不进行数据的类型转换,他只是把输入按照给定的数据格式输出,如果二者不匹配,那么由于不同数据类 ...

  4. 详细比较三个 CSS 预处理器(框架):Sass、LESS 和 Stylus

    [大伽说]如何运维千台云服务器 »   CSS 预处理器技术已经非常的成熟,而且也涌现出了越来越多的 CSS 的预处理器框架.本文向你介绍使用最为普遍的三款 CSS 预处理器框架,分别是 Sass.L ...

  5. 占成本85% SSD深度选购教你如何看颗粒

    颗粒是固态硬盘负责容量和传输的介质,在这一方面上与优盘产品是相同的,从外观上看,颗粒占据了整个固态硬盘内部70%左右的空间,其同样做为成本技术,根据厂商的用料不同,成为了固态硬盘内部核心材料. 颗粒的 ...

  6. 鼠标进入与离开的消息(覆盖CM_MOUSEENTER与CM_MOUSELEAVE消息)——Windows本身没有这样的消息

    unit Unit1; interface uses Windows, Messages, SysUtils, Classes, Graphics, Controls, Forms, Dialogs, ...

  7. Android中pendingIntent的深入理解

    pendingIntent字面意义:等待的,未决定的Intent.要得到一个pendingIntent对象,使用方法类的静态方法 getActivity(Context, int, Intent, i ...

  8. 柯南君:看大数据时代下的IT架构(2)消息队列之RabbitMQ-基础概念详细介绍

    一.基础概念详细介绍 1.引言 你是否遇到过两个(多个)系统间需要通过定时任务来同步某些数据?你是否在为异构系统的不同进程间相互调用.通讯的问题而苦恼.挣扎?如果是,那么恭喜你,消息服务让你可以很轻松 ...

  9. Day1_PHP快速入门

    本人知识背景:行业软件C/C++开发两年经验,了解PHP, 所以学习日志偏向记录PHP相对于C的特性 测试环境:EasyPHP13.1 Day 1 学习时间:3小时 1. HTML触发PHP HTML ...

  10. CodeForces - 61E Enemy is weak

    Description The Romans have attacked again. This time they are much more than the Persians but Shapu ...