目录
article
Sails.js 之微信接口(wechat-oauth)
Sails.js 之微信接口(wechat-oauth)
wechat-oauth 接口的功能:
OAuth授权- 获取基本信息
安装:
打开 mac 终端,输入以下命令:
sudo npm install wechat-oauth
在终端中利用cd命令进入到sails.js工程所在文件夹,安装 API wechat
sails generate controller wechat
执行结果:
info: Created a new controller (“test”) at api/controllers/WechatController.js!
此时项目工程下的路径/api/controllers 中增加了一个 WechatController.js 的文件。
Controller
在 WechatController.js 中添加类似下面的代码
'use strict';
//引入 OAuth 并实例化
var oAuth = require('wechat-oauth');
//以下代码即可满足单进程使用
var client = new OAuth('your appid', 'your secret');
当多进程时,token需要全局维护,以下为保存token的接口。
var oauthApi = new OAuth('appid', 'secret', function (openid, callback) {
// 传入一个根据 openid 获取对应的全局 token 的方法
// 在 getUser 时会通过该方法来获取 token
fs.readFile(openid +':access_token.txt', 'utf8', function (err, txt) {
if (err) {return callback(err);}
callback(null, JSON.parse(txt));
});
}, function (openid, token, callback) {
// 请将 token 存储到全局,跨进程、跨机器级别的全局,比如写到数据库、redis 等
// 这样才能在 cluster 模式及多机情况下使用,以下为写入到文件的示例
// 持久化时请注意,每个 openid 都对应一个唯一的 token!
fs.writeFile(openid + ':access_token.txt', JSON.stringify(token), callback);
});
引导用户
生成引导用户点击的 URL。
var url = client.getAuthorizeURL('redirectUrl', 'state', 'scope');
如果是 PC 上的网页,请使用以下方式生成
var url = client.getAuthorizeURLForWebsite('redirectUrl');
获取Openid和AccessToken
用户点击上步生成的 URL 后会被重定向到上步设置的 redirectUrl,并且会带有code参数,我们可以使用这个code换取access_token和用户的openid
client.getAccessToken('code', function (err, result) {
var accessToken = result.data.access_token;
var openid = result.data.openid;
});
获取用户信息
如果我们生成引导用户点击的 URL 中scope参数值为snsapi_userinfo,接下来我们就可以使用openid换取用户详细信息(必须在getAccessToken方法执行完成之后
client.getUser(openid, function (err, result) {
var userInfo = result;
});