Sails.js 之微信接口(wechat-oauth)

wechat-oauth 接口的功能:

  1. OAuth授权
  2. 获取基本信息

安装:

打开 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');
  

获取OpenidAccessToken

用户点击上步生成的 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;
});