Skip to content

liwenyue/co-wechat-open-api

 
 

Repository files navigation

微信第三方平台Node库API,ES6版本,基于https://github.com/node-webot/co-wechat-api 3.3.0版本(ES6版)

功能列表

  • 发送客服消息(文本、图片、语音、视频、音乐、图文)
  • 菜单操作(查询、创建、删除、个性化菜单)
  • 二维码(创建临时、永久二维码,查看二维码URL)
  • 分组操作(查询、创建、修改、移动用户到分组)
  • 用户信息(查询用户基本信息、获取关注者列表)
  • 媒体文件(上传、获取)
  • 群发消息(文本、图片、语音、视频、图文)
  • 客服记录(查询客服记录,查看客服、查看在线客服)
  • 群发消息
  • 公众号支付(发货通知、订单查询)
  • 微信小店(商品管理、库存管理、邮费模板管理、分组管理、货架管理、订单管理、功能接口)
  • 模版消息
  • 网址缩短
  • 语义查询
  • 数据分析
  • JSSDK服务端支持
  • 素材管理
  • 摇一摇周边

Installation

$ npm install co-wechat-open-api
// or
$ npm install https://github.com/liwenyue/co-wechat-open-api.git

Usage

var OpenWechatAPI = require('co-wechat-open-api');

async function() {
  var api = new OpenWechatAPI('component_appid', 'component_appsecret', 'authorizer_appid', 'authorizer_refresh_token', 'componentVerifyTicket');
  var result = await api.updateRemark('open_id', 'remarked');
}

多进程

当多进程时,当多进程时,component token和access token需要全局维护,以下为保存component token和access token的接口。:

var api = new API('component_appid', 'component_appsecret', 'authorizer_appid', 'authorizer_refresh_token', 'component_verify_ticket', async function () {
   // 传入一个获取全局component_token的方法
   var txt = await fs.readFile('component_token.txt', 'utf8');
   return JSON.parse(txt);
 }, async function (component_token) {
   // 请将component_token存储到全局,跨进程、跨机器级别的全局,比如写到数据库、redis等
   // 这样才能在cluster模式及多机情况下使用,以下为写入到文件的示例
   await fs.writeFile('component_token.txt', JSON.stringify(component_token));
 }, async function () {
   // 传入一个获取全局token的方法
   var txt = await fs.readFile('appid_token.txt', 'utf8');
   return JSON.parse(txt);
 }, async function (token) {
  // 请将token存储到全局,跨进程、跨机器级别的全局,比如写到数据库、redis等
  // 这样才能在cluster模式及多机情况下使用,以下为写入到文件的示例
   await fs.writeFile('appid_token.txt', JSON.stringify(token));
 });

详细API

原始API文档请参见:消息接口指南

License

The MIT license.

About

Wechat API. Support Async Functions

Resources

Stars

Watchers

Forks

Packages

No packages published

Languages

  • JavaScript 99.8%
  • Makefile 0.2%