Skip to content

lijicheng123/node-weixin-auth

 
 

Repository files navigation

NPM version Build Status Dependency Status Coveralls Status

微信服务器Auth模块是(node-weixin-api 或者 node-weixin-express)的一个子项目。 它提供了几个重要的方法

tokenize: 用于跟服务器验证配置信息

determine: 用于自动tokenize所有的api请求,而不需要手动在超时时重新请求

ips: 获取服务IP列表

ack: 用于服务器有效性验证

交流QQ群: 39287176

注:

node-weixin-express是基于node-weixin-*的服务器端参考实现。

node-weixin-api是基于node-weixin-*的API接口SDK。

它们都是由下列子项目组合而成:

  1. node-weixin-config 用于微信配置信息的校验,

  2. node-weixin-auth 用于与微信服务器握手检验

  3. node-weixin-util 一些常用的微信请求,加密,解密,检验的功能与处理

  4. node-weixin-request 微信的各类服务的HTTP请求的抽象集合

  5. node-weixin-oauth 微信OAuth相关的操作

  6. node-weixin-pay 微信支付的服务器接口

  7. node-weixin-jssdk 微信JSSDK相关的服务器接口

  8. node-weixin-menu 微信菜单相关的操作与命令

Install

$ npm install --save node-weixin-auth

Usage

var nodeWeixinAuth = require('node-weixin-auth');

var app = {
  id: '',
  secret: '',
  token: ''
};

//手动得到accessToken
nodeWeixinAuth.tokenize(app, function (error, json) {
  var accessToken = json.access_token;
});

//自动获得accessToken,并发送需要accessToken的请求
nodeWeixinAuth.determine(app, function () {
  //这里添加发送请求的代码
});

//获取服务器IP
nodeWeixinAuth.ips(app, function (error, data) {
  //error == false
  //data.ip_list获取IP列表
});


//与微信对接服务器的验证
var errors = require('web-errors').errors;
var request = require('supertest');
var express = require('express');
var bodyParser = require('body-parser');

var server = express();

server.use(bodyParser.urlencoded({extended: false}));
server.use(bodyParser.json());

server.post('/weixin/ack', function (req, res) {
  var data = nodeWeixinAuth.extract(req.body);
  nodeWeixinAuth.ack(app.token, data, function (error, data) {
    if (!error) {
      res.send(data);
      return;
    }
    switch (error) {
      case 1:
        res.send(errors.INPUT_INVALID);
        break;
      case 2:
        res.send(errors.SIGNATURE_NOT_MATCH);
        break;
      default:
        res.send(errors.UNKNOWN_ERROR);
        break;
    }
  });
});

License

MIT © node-weixin

About

node-weixin服务器沟校验模块

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • JavaScript 100.0%