前面已经配置了微信服务器,那么先开始最简单的接收微信消息吧~
 
可以用我们的微信号来直接进行测试,下面先看测试效果图:
 

这是最基本的文本消息的接收、处理及返回,来看看是怎么实现的吧!
 
首先可以参考微信消息相关的接口文档:https://mp.weixin.qq.com/wiki?t=resource/res_main&id=mp1421140453
 
具体实现如下:
第一步,接收微信发送的文本消息入口:

 /**
* 处理微信服务器发来的消息
*/
public void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException
{
// TODO 消息的接收、处理、响应
System.out.println("接口调用了一次"); String ret = IOUtils.toString(request.getInputStream(), "utf-8").toString();
System.out.println(ret); WeChatMsgBL tWeChatMsgBL = new WeChatMsgBL();
String result = tWeChatMsgBL.dealWechatMsg(ret); response.setCharacterEncoding("UTF-8"); // 返回文本消息,将处理结果返回
PrintWriter out = response.getWriter(); System.out.println(result); out.print(result); out.close(); }

可以先输出接收到的xml信息:

 

第二步,解析及处理接收到数据的内容:

从微信提供的接口文档上,我们可以发现,不论是文本消息还是语音、图片等消息,在xml报文中,有部分节点信息的一致的,因此可以创建一个父类在处理(变量名要与xml中节点名一致,大小写也一样,这样后面返回消息结果时很方便):
 /**
* 微信消息主要类
* @author user
*/
public class WechatMsg
{
// 开发者微信号
private String ToUserName = ""; // 发送方帐号(一个OpenID)
private String FromUserName = ""; // 消息创建时间 (整型)
private String CreateTime = ""; // 消息类型
private String MsgType = ""; // 消息id,64位整型
private String MsgId = ""; public String getToUserName()
{
return ToUserName;
} public void setToUserName(String toUserName)
{
ToUserName = toUserName;
} public String getFromUserName()
{
return FromUserName;
} public void setFromUserName(String fromUserName)
{
FromUserName = fromUserName;
} public String getCreateTime()
{
return CreateTime;
} public void setCreateTime(String createTime)
{
CreateTime = createTime;
} public String getMsgType()
{
return MsgType;
} public void setMsgType(String msgType)
{
MsgType = msgType;
} public String getMsgId()
{
return MsgId;
} public void setMsgId(String msgId)
{
MsgId = msgId;
} }

然后对应的基本信息子类为(只用多一个变量):
 /**
* 普通消息类
* @author Damon
*/
public class WechatTextMsg extends WechatMsg
{ // 文本内容
private String Content = ""; public String getContent()
{
return Content;
} public void setContent(String content)
{
this.Content = content;
}
}
下面来看具体的处理,涉及新增jar包:dom4j-1.6.1.jar  
     /**
* 处理微信信息
* @param reqInfo xml信息数据
* @return 处理结果
*/
public String dealWechatMsg(String reqInfo)
{ String ret = reqInfo; String result = ""; WechatTextMsg tReturnMsg = new WechatTextMsg(); try
{
Document returndoc = DocumentHelper.parseText(ret); Element rootElement = returndoc.getRootElement(); String tMsgType = rootElement.elementText("MsgType"); // 根据MsgType 返回具体的消息类 if (SysCon.TEXT_MSG_TYPE.equals(tMsgType))
{
result = dealTextMsg(rootElement);
} // 封装返回信息
tReturnMsg.setCreateTime(new Date().getTime() + "");
tReturnMsg.setToUserName(rootElement.elementText("FromUserName"));
tReturnMsg.setFromUserName(rootElement.elementText("ToUserName"));
tReturnMsg.setContent(result);
tReturnMsg.setMsgType(SysCon.TEXT_MSG_TYPE);
// 将返回结果封装成文本消息
result = WeChatUtil.textToXML(tReturnMsg);
}
catch (DocumentException e)
{
// TODO Auto-generated catch block
e.printStackTrace();
} return result;
} /**
* 处理文本消息
* @param msg
* @return
*/
private String dealTextMsg(Element rootElement)
{ WechatTextMsg tWechatTextMsg = new WechatTextMsg();
// 依次赋值
tWechatTextMsg.setCreateTime(rootElement.elementText("CreateTime"));
tWechatTextMsg.setFromUserName(rootElement.elementText("FromUserName"));
tWechatTextMsg.setToUserName(rootElement.elementText("ToUserName"));
tWechatTextMsg.setMsgType(rootElement.elementText("MsgType"));
tWechatTextMsg.setMsgId(rootElement.elementText("MsgId"));
tWechatTextMsg.setContent(rootElement.elementText("Content")); System.out.println("传入的消息是:" + tWechatTextMsg.getContent()); // 后续可处理保存到数据库及数据分析等,现在直接返回结果 // 将数据转存至数据库
// Connection conn = DBConnPool.getConnection(); return "传入的文本消息处理完毕";
}

其中对于参数类型判断,可以在SysCon类中添加基本参数

     // 定义微信消息类型--文本
public static final String TEXT_MSG_TYPE = "text";
第三步,处理消息的返回
消息处理完成后,返回文本(可返回不同类型,仅以文本为例)处理结果
这里用到了工具类中 的方法如下:
     /**
* 将对象转为XML输出
* @param textMsg
* @return
*/
public static String textToXML(WechatTextMsg textMsg)
{
xstream.alias("xml", textMsg.getClass());
return xstream.toXML(textMsg); } /**
* 扩展xstream使其支持CDATA
*/
private static XStream xstream = new XStream(new XppDriver()
{
public HierarchicalStreamWriter createWriter(Writer out)
{
return new PrettyPrintWriter(out)
{
// 对所有xml节点的转换都增加CDATA标记
boolean cdata = true; @SuppressWarnings("unchecked")
public void startNode(String name, Class clazz)
{
super.startNode(name, clazz);
} protected void writeText(QuickWriter writer, String text)
{
if (cdata)
{
writer.write("<![CDATA[");
writer.write(text);
writer.write("]]>");
}
else
{
writer.write(text);
}
}
};
}
});

涉及到新增jar包:xstream-1.3.1.jar
可以在最后返回前输出处理的结果:

微信上可接收到消息:传入的文本消息处理完毕。
 
 到这,本节内容就结束了,可以自己去扩展语音消息的接收和处理哦~

玩玩微信公众号Java版之二:接收、处理及返回微信消息的更多相关文章

  1. 玩玩微信公众号Java版之七:自定义微信分享

    前面已经学会了微信网页授权,现在微信网页的功能也可以开展起来啦! 首先,我们先来学习一下分享,如何在自己的页面获取分享接口及让小伙伴来分享呢? 今天的主人公: 微信 JS-SDK, 对应官方链接为:微 ...

  2. 玩玩微信公众号Java版之一:配置微信公众平台服务器信息

    在进行微信公众平台开发前,前先做好准备工作,好了以后,我们可以开始啦!   第一.准备好服务端接口   定义一个http服务接口,主要分为如下几步:   1.创建一个servlet类,用来接收请求: ...

  3. 玩玩微信公众号Java版之准备

    微信自2013年流行起来,现在的发展已经超过了我们的想象,那么对应的公众平台,小程序等都是让人眼前一亮的东西,这里来学习一下微信工作号的对接,实现为Java,希望大家一起学习!   这里大概描述一下所 ...

  4. 玩玩微信公众号Java版之四:自定义公众号菜单

    序: 微信公众号基本的菜单很难满足个性化及多功能的实现,那么微信能否实现自定菜单呢,具体的功能又如何去实现么?下面就来学习一下微信自定义公众号菜单吧! 自定义菜单接口可实现多种类型按钮,如下: 1.c ...

  5. 玩玩微信公众号Java版之六:微信网页授权

    我们经常会访问一些网站,用微信登录的时候需要用到授权,那么微信网页授权是怎么一回事呢,一起来看看吧!   参考官方文档:https://mp.weixin.qq.com/wiki?t=resource ...

  6. 玩玩微信公众号Java版之三:access_token及存储access_token

    微信官方参考文档:https://mp.weixin.qq.com/wiki?t=resource/res_main&id=mp1421140183   基本说明: access_token是 ...

  7. 玩玩微信公众号Java版之五:获取关注用户信息

    在关注者与公众号产生消息交互后,公众号可获得关注者的OpenID(加密后的微信号,每个用户对每个公众号的OpenID是唯一的.对于不同公众号,同一用户的openid不同).公众号可通过本接口来根据Op ...

  8. C#微信公众号开发系列教程(接收事件推送与消息排重)

    微信服务器在5秒内收不到响应会断掉连接,并且重新发起请求,总共重试三次.这样的话,问题就来了.有这样一个场景:当用户关注微信账号时,获取当前用户信息,然后将信息写到数据库中.类似于pc端网站的注册.可 ...

  9. 微信公众号Java接入demo

    微信公众号Java接入demo 前不久买了一台服务,本来是用来当梯子用的,后来买了一个域名搭了一个博客网站,后来不怎么在上面写博客一直闲着,最近申请了一个微信公众号就想着弄点什么玩玩.周末没事就鼓捣了 ...

随机推荐

  1. 提升单元测试体验的利器--Mockito使用总结

    为神马要使用Mockito? 在编写单元测试的时候,为了尽可能的保证隔离性,我们时常需要对某些不容易构造或者不容易获取或者对外部环境有依赖的对象,用一个虚拟的对象来创建以便于测试.假设你正在开发的的代 ...

  2. unity3D:游戏分解之角色移动和相机跟随

          游戏中,我们经常会有这样的操作,点击场景中某个位置,角色自动移动到那个位置,同时角色一直是朝向那个位置移动的,而且相机也会一直跟着角色移动.有些游戏,鼠标滑动屏幕,相机就会围绕角色旋转. ...

  3. IntelliJ IDEA 2017.1.4 x64配置说明

    只是为了研究下idea这款编译器怎么使用.开门见山,说下如何配置这款编译器,不配置也能用,但是强迫症表示不服.下面直入正题: 下载与安装就不说了,除了更改安装目录外,没啥注意的地方,建议下载idea去 ...

  4. 【锋利的jQuery】中全局事件ajaxStart、ajaxStop不执行

    最近一直都在研究[锋利的jQuery],确实是一本好书,受益匪浅.但由于技术发展及版本更新等原因,里面还是有些坑需要踩的. 比如:第六章七节中提到的全局事件ajaxStart.ajaxStop照着案例 ...

  5. form表单在前台转json对象

    会发生序列化乱码问题,待解决. //根据表单id将其内空间,名称,值转为json var fireTraceEquipment =queryParamByFormId('form1'); functi ...

  6. 不用媒体查询做web响应式设计-遁地龙卷风

    (0)写在前面 讲述知乎上看到的一篇文章中的一个案例,让我脑洞大开,佩服至极,特意第二天找到原文赞赏了 5元,原文地址https://zhuanlan.zhihu.com/p/27258076,案例用 ...

  7. 如何提取Redis中的大KEY

    工作中,经常有些Redis实例使用不恰当,或者对业务预估不准确,或者key没有及时进行处理等等原因,导致某些KEY相当大. 那么大Key会带来哪些问题呢? 如果是集群模式下,无法做到负载均衡,导致请求 ...

  8. scrapy中的下载器中间件

    scrapy中的下载器中间件 下载中间件 下载器中间件是介于Scrapy的request/response处理的钩子框架. 是用于全局修改Scrapy request和response的一个轻量.底层 ...

  9. jersery+jetty嵌入式restful的框架开发

    随着微服务的流程,越来越多的后台服务采用了restful api风格的开放API,jersery+jetty嵌入式变成了一个很好的选择, 我自己写了一个简单的框架,https://github.com ...

  10. 关于Handler的理解,子线程不能更新UI的纠正和回调的思考

    开发Android这么久了,总会听到有人说:主线程不能访问网络,子线程不能更新UI.Android的主线程的确不能长时间阻塞,但是子线程为什么不能更新UI呢?今天把这些东西整理,顺便在子线程更新UI. ...