一款轻量级的微信消息处理框架
-
封装了微信消息接收与发送,可以使用注解驱动开发,方便的进行业务开发而不需要再关注消息接收和消息发送的细节。
-
内部封装了消息处理器抽象类,该类提供处理消息前的消息过滤、默认行为日志等功能,用户可继承该类实现自己的业务。
-
只需加入注解就可将处理各个类型的消息处理器分开了,更支持将不同事件类型的消息处理器分开,避免了在处理业务逻辑的代码中使用大段的if elseif elseif 来判断消息得类型的方式。每个接口职责清晰明了,实现更解耦;
- 使用Java语言,集成了springMVC 和maven,没有使用什么高大上得技术,代码中的注释也很详细,相信读者朋友能很容易看得懂。
-
在classpath根路径下创建wechat.properties属性文件,配置appId、appsecret、token、encodingAESKey(名字必须跟这个一样), 示例如下图:
-
编写消息处理器类,继承AbstractMessageHandler抽象类,实现doHandleMessage方法,在该类上加上@MessageProcessor的注解,并指明要处理的消息类型,属性messageType指明要处理得消息类型,eventType指明要处理得事件类型。当消息类型是普通消息时,eventType属性可不用指定(即使指定也无效) 示例代码如下:
- 基本消息类型的处理(文本消息处理器)
@Component @MessageProcessor(messageType = MessageType.TEXT_MESSAGE) public class TextMessageHandlerExample extends AbstractMessageHandler { private static final Logger LOGGER = LoggerFactory.getLogger(TextMessageHandlerExample.class); public BaseResponseMessage doHandleMessage(BaseRequestMessage requestMessage) { //在这里实现你自己的业务逻辑 return MessageUtils.buildTextResponseMessage(requestMessage, "hello,world"); } }
- 关注事件类型的消息处理
@Component @MessageProcessor(messageType = MessageType.EVENT,eventType = EventType.EVENT_SUBSCRIBE) public class SubscribeEventMessageHandlerExample extends AbstractMessageHandler { private static final Logger LOGGER = LoggerFactory.getLogger(SubscribeEventMessageHandlerExample.class); @Autowired private WechatUserService wechatUserService; @Override public BaseResponseMessage doHandleMessage(BaseRequestMessage baseRequestMessage) { //在这里实现你自己的业务逻辑 SubOrUnSubEventRequestMessage subOrUnSubEventRequestMessage = (SubOrUnSubEventRequestMessage) baseRequestMessage; } }
-
just run your application !! have fun...
各种消息类型的接收与回复的示例代码链接如下,供读者朋友们参考
-
基本消息类型
-
事件消息类型
- 对基本消息类型(文本、图片、音频、视频、位置、短视频、链接消息)和事件消息(关注、取消关注、上传地理位置、扫描二维码)的接收和响应的封装。
- 对access_token的封装,请参考AccessTokenService。
- 整个用户接口API的封装,请参考WechatUserService
- 下一步准备做自定义菜单、redis实现accesstoken存储
邮箱:[email protected] ,欢迎提bug和建议。