WeChat-Proxy 正在参加 2020 年度 OSC 中国开源项目评选,请投票支持!
WeChat-Proxy 在 2020 年度 OSC 中国开源项目评选 中已获得 {{ projectVoteCount }} 票,请投票支持!
投票让它出道
已投票
WeChat-Proxy 获得 2020 年度 OSC 中国开源项目评选「最佳人气项目」 !
WeChat-Proxy 获得 2020 年度 OSC 中国开源项目评选「最佳人气项目」「最积极运营项目」 !
WeChat-Proxy 获得 2020 年度 OSC 中国开源项目评选「最积极运营项目」 !
授权协议 GPL
开发语言 Google Go
操作系统 跨平台
软件类型 开源软件
开源组织
地区 国产
提 交 者 八风不动
适用人群 未知
收录时间 2017-09-14

软件简介

WeChat-Proxy 是微信代理服务。

功能

1、全局缓存微信 access_token, jsapi ticket等。
2、多路转发微信回调消息。
3、简化微信 oauth2 认证流程。
4、简化微信支付流程。
5、简化微信 JSSDK 签名流程。

使用说明:

1、公众号注册:

/register?key=...&appid=...&secret=...
&token=&aes=
&mch_id=&mch_key=&server_ip=
&expires=&call=/msg&call=/api&call=...

参数说明:

  • key: 自定义的app名称,支持中文,也可以是随机生成的字符串。(必填)

  • appid: 微信公众号的 appid。(必填)

  • secret: 微信公众号的 secret。(必填)

  • token, aes: 用于微信回调消息加解密的秘钥。(/msg接口)

  • 如果设置了此项参数,后台应用可以直接以json明文格式接收和回复微信回调消息。(/msg/json接口)

  • mch_id, mch_key, server_ip: 用于微信支付的账号、秘钥和服务器IP。(/pay接口) 如果设置了此项参数, 可以使用简单的 url 请求实现微信支付功能。

  • expires: 过期时间,单位秒。如果设置此项参数,注册信息会在到期后自动删除。 call: 可用API,可以重复多次。如果设置此项参数,该app注册信息仅可用于已列出的api接口。

2、access_token 全局缓存:

access_token 全局缓存自动获取最新的 access_token 值缓存在代理服务器内存中。
access_token 全局缓存支持多进程、多服务器共享 access_token,还可以无限次获取,简化后台服务的开发难度。

调用/register接口完成注册后,使用已注册的 test 名称调用 /api 接口:

/app/test/api /app/test/qyapi

强制刷新 access_token:

/app/test/api/new /app/test/qyapi/new

3、微信回调消息的多路转发:

微信回调消息的多路转发可以将微信公众号的回调消息转发给多个后台服务,按照call参数的设置顺序返回第一个非空的处理结果。

如果在/register接口中设置了token和aes参数,/msg/json 接口支持微信消息的自动加解密服务,后台call网址可直接使用 json 明文协议实现交互。

/app/test/msg?call=...&call=...   /app/test/msg/json?call=...&call=...

4、微信登录:

snsapi_base 方式登录验证:

/app/test/auth?call=...&state=&lang=

snsapi_info 方式登录验证:

/app/test/auth/info?call=...&state=&lang=

验证成功时,call网址将收到 json 数据包(POST),包含用户的 openid, unionid, 以及用户的其他信息。
state和lang是可选参数,具体含义请参考微信官方文档。

5、微信支付:

微信支付二维码:直接返回二维码图片,用户使用微信扫码后即可付款。

/app/test/pay/qrcode?fee=...&name=&call=&...

公众号网页支付:公众号网页内调起支付窗口完成支付。(参考实现:/example/jspay.html)

/app/test/pay/js?openid=...&fee=...&name=&call=&...

统一下单:服务端可调用统一下单接口获得支付订单,省去签名计算等步骤。

/app/test/pay?fee=...&name=&call=&...

参数说明:

  • fee: 订单金额,单位分。(必填)

  • openid: 用户在该公众号下的 openid。(网页支付必填) 允许使用客户端 cookie 传递此参数。

  • name: 订单名称。 call: 回调通知网址。订单支付成功后将支付结果发送至此网址。(JSON)

  • 其他参数(高级用法):支持微信统一下单接口 所列举的其他订单参数。具体请参考微信官方文档。(sign, sign_type 由程序自动生成,不可覆盖)

6、JSSDK:

jsapi_ticket 全局缓存:

/app/test/jsapi

JSSDK 权限验证配置:直接返回 wx.config({...}); 默认获取全部API权限。

可选参数:

debug: true或false。

apilist: 逗号分隔的 JSSDK API 列表。

<script src="/app/test/js/config?debug=true"></script>

微信卡券签名:

/app/test/js/card
展开阅读全文

代码

的 Gitee 指数为
超过 的项目

评论 (2)

加载中
留一个阿里云免费优惠券->http://aliyun.izhuanyer.com
2017/09/18 05:56
回复
举报
留一个阿里云免费优惠券->http://aliyun.izhuanyer.com
2017/09/15 07:13
回复
举报
更多评论
暂无内容
发表了博客
2020/05/08 11:55

【wechat login】

https://lucent.blog/passages/vue%E5%AE%9E%E7%8E%B0%E5%86%85%E5%B5%8C%E4%BA%8C%E7%BB%B4%E7%A0%81%E5%BE%AE%E4%BF%A1%E7%99%BB%E5%BD%95/ https://developers.weixin.qq.com/doc/oplatform/Website_App/WeChat_Login/Wechat_Login.html...

0
0
没有更多内容
加载失败,请刷新页面
点击加载更多
加载中
下一页
暂无内容
2 评论
29 收藏
分享
OSCHINA
登录后可查看更多优质内容
返回顶部
顶部