分类: Java开发

微信公众号开发框架

本文是项目 WeiXin 的说明文档。

参考: [接口文档] [第三方公众平台文档] [测试地址] [本机公网发布]

起步

在 web.xml 中配置如下信息:

<servlet>
    <servlet-name>weixin</servlet-name>
    <servlet-class>com.chn.wx.WeiXinServlet</servlet-class>
</servlet>
<servlet-mapping>
    <servlet-name>weixin</servlet-name>
    <url-pattern>/*</url-pattern>
</servlet-mapping>

同时在 classpath 下的 weixin.properties 里配置各项参数:

weixin.app.id=
weixin.app.name=
weixin.app.secret=
weixin.app.aeskey=
weixin.app.token=

weixin.service.package=

关于异步执行: 当 weixin.service.async 值为 true 时异步执行,会忽略 Service 返回的任何内容,如有下行需调用客服接口,可以缓解压力过大导致的“微信号暂时不能提供服务”等问题。

主流程

com.chn.wx.listener 中的所有实现 Service 接口的类会被组装成一棵流程树,目前结点如下:

GET
Servlet ─────> CertifyService
   |    POST                  RAW                                 event                         CLICK
   └─────────> EncryptRouter ─────> RawMessageRouter ────────────────────────────> EventRouter ─────────> ClickEventAdaptor
                     | AES            ↑         |  text                                 |       LOCATION
                     └────> AesMessageRouter    ├───────────> TextMessageAdaptor        ├───────────────> LocationEventAdaptor
                                                |  image                                |       SCAN
                                                ├───────────> ImageMessageAdaptor       ├───────────────> ScanQrCodeEventAdaptor
                                                |  video                                |       VIEW
                                                ├───────────> VideoMessageAdaptor       ├───────────────> ViewEventAdaptor
                                                |  voice                                |       subscribe
                                                ├───────────> VoiceMessageAdaptor       ├───────────────> SubscribeEventAdaptor
                                                |  location                             |       unsubscribe
                                                ├───────────> LocationMessageAdaptor    ├───────────────> UnSubscribeEventAdaptor
                                                |  link                                 |       component_verify_ticket
                                                ├───────────> LinkMessageAdaptor        ├───────────────> ComponentVerifyTicketAdaptor
                                                |  shortvideo                           |       unauthorized
                                                └───────────> ShortVideoMessageAdaptor  └───────────────>UnAuthorizedAdaptor

结点与父结点的关系通过 @Node(value = "raw", parent = EncryptRouter.class) 指定。

消息返回

Service 的实现方法中返回的字符串会被写回到请求流中,需要返回消息时,调用 com.chn.wx.template.PassiveMessage 中的对应方法生成报文返回即可。

注意:仅同步执行时该返回有效

主动调用

所有实例获取可以通过 @Autowired,也可以通过 FactoryUtils.getInstance()

  • com.chn.wx.api.GroupManager 分组管理
  • com.chn.wx.api.MaterialManager 素材管理
  • com.chn.wx.api.MenuManager 菜单管理
  • com.chn.wx.api.PlatFormManager 作为第三方平台运行时的相关接口
  • com.chn.wx.api.PlatFormTokenAccessor 第三方平台相关接口的 token 获取入口
  • com.chn.wx.api.ServiceMessageSender 客服消息发送
  • com.chn.wx.api.TokenAccessor 唯一的 token 获取入口, token 只能能过该类获取, 不能另做缓存
  • com.chn.wx.api.UrlTransformer 短地址服务
  • com.chn.wx.api.UserManager 用户管理

语法糖

Service 实现类中被@Param注解标记的字段,会被注入成 Context 中对应的属性值,当然也可以直接通过 Context 读取。

Recent Posts

如何安全取回 GitHub 存储的 Action Secrets

在GitHub的使用过程中,存…

3 周 之前

Docker 容器非 root 用户监听 80 端口

起因是基于 CentOS 的 …

2 年 之前

基于 Docker 定时打印文件

先说背景,喷墨打印机有个很大的…

3 年 之前

Java 运行时反射获取来自继承的泛型

背景 正常情况下 Java 的…

3 年 之前

Java 基于 ByteBuddy 重写系统当前时间

背景 一般单元测试时总会有些代…

3 年 之前

华硕 B450F-Gaming 主板 I211-AT 网卡驱动安装

事情起因是买了块华硕的 ROG…

3 年 之前