玩玩微信公众号Java版之二:接收、处理及返回微信消息


/**
* 处理微信服务器发来的消息
*/
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信息:

第二步,解析及处理接收到数据的内容:
/**
* 微信消息主要类
* @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;
}
}

/**
* 处理微信信息
* @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 "传入的文本消息处理完毕";
}


// 定义微信消息类型--文本
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);
}
}
};
}
});


玩玩微信公众号Java版之二:接收、处理及返回微信消息的更多相关文章
- 玩玩微信公众号Java版之七:自定义微信分享
前面已经学会了微信网页授权,现在微信网页的功能也可以开展起来啦! 首先,我们先来学习一下分享,如何在自己的页面获取分享接口及让小伙伴来分享呢? 今天的主人公: 微信 JS-SDK, 对应官方链接为:微 ...
- 玩玩微信公众号Java版之一:配置微信公众平台服务器信息
在进行微信公众平台开发前,前先做好准备工作,好了以后,我们可以开始啦! 第一.准备好服务端接口 定义一个http服务接口,主要分为如下几步: 1.创建一个servlet类,用来接收请求: ...
- 玩玩微信公众号Java版之准备
微信自2013年流行起来,现在的发展已经超过了我们的想象,那么对应的公众平台,小程序等都是让人眼前一亮的东西,这里来学习一下微信工作号的对接,实现为Java,希望大家一起学习! 这里大概描述一下所 ...
- 玩玩微信公众号Java版之四:自定义公众号菜单
序: 微信公众号基本的菜单很难满足个性化及多功能的实现,那么微信能否实现自定菜单呢,具体的功能又如何去实现么?下面就来学习一下微信自定义公众号菜单吧! 自定义菜单接口可实现多种类型按钮,如下: 1.c ...
- 玩玩微信公众号Java版之六:微信网页授权
我们经常会访问一些网站,用微信登录的时候需要用到授权,那么微信网页授权是怎么一回事呢,一起来看看吧! 参考官方文档:https://mp.weixin.qq.com/wiki?t=resource ...
- 玩玩微信公众号Java版之三:access_token及存储access_token
微信官方参考文档:https://mp.weixin.qq.com/wiki?t=resource/res_main&id=mp1421140183 基本说明: access_token是 ...
- 玩玩微信公众号Java版之五:获取关注用户信息
在关注者与公众号产生消息交互后,公众号可获得关注者的OpenID(加密后的微信号,每个用户对每个公众号的OpenID是唯一的.对于不同公众号,同一用户的openid不同).公众号可通过本接口来根据Op ...
- C#微信公众号开发系列教程(接收事件推送与消息排重)
微信服务器在5秒内收不到响应会断掉连接,并且重新发起请求,总共重试三次.这样的话,问题就来了.有这样一个场景:当用户关注微信账号时,获取当前用户信息,然后将信息写到数据库中.类似于pc端网站的注册.可 ...
- 微信公众号Java接入demo
微信公众号Java接入demo 前不久买了一台服务,本来是用来当梯子用的,后来买了一个域名搭了一个博客网站,后来不怎么在上面写博客一直闲着,最近申请了一个微信公众号就想着弄点什么玩玩.周末没事就鼓捣了 ...
随机推荐
- 一天搞定CSS:css选择器--07
选择器:是指选择标签的方法 1.选择器类型 2.id选择器 代码演示 <!DOCTYPE html> <html> <head> <meta charset= ...
- Node.js爬虫-爬取慕课网课程信息
第一次学习Node.js爬虫,所以这时一个简单的爬虫,Node.js的好处就是可以并发的执行 这个爬虫主要就是获取慕课网的课程信息,并把获得的信息存储到一个文件中,其中要用到cheerio库,它可以让 ...
- pb传输优化浅谈
在正式切入今天要谈的优化之前,先碎碎念一些自己过去这几年的经历.很久没有登录过博客园了,今天也是偶然兴起打开上来看一下,翻看了下自己的随笔,最后一篇原创文章发布时间是2015年的4月,今天是2017年 ...
- Dojo初探之2:设置dojoConfig详解,dojoConfig参数详解+Dojo中预置自定义AMD模块的四种方式(基于dojo1.11.2)
Dojo中想要加载自定义的AMD模块,需要先设置好这个模块对应的路径,模块的路径就是这个模块的唯一标识符. 一.dojoConfig参数设置详解 var dojoConfig = { baseUrl: ...
- Ajax请求,跨域小坑
今天在上班的时候,被坐在旁边项目经理叫过去问了一个Ajax请求跨域的问题,一开始没理解清楚也还有对这个没有理解的透,后面被打击的要死. 当时的需求是需要测试一个已发布的api接口,需要在本地写测试程序 ...
- div中内容无法自动换行问题
.l-text{ padding:.3em .5em; width:67%; height: auto; /*height:1.3em;*/ border:.1em #2294C3 solid; bo ...
- js传宗接代---继承
前几天重温了一下js的继承,今天分享给大家: 一,类式继承. 所谓的类式继承就是:第二个类的原型prototype被赋予了第一个类的实例,如subcals.prototype=new supercls ...
- Swift三元条件运算
三元条件运算的特殊在于它是有三个操作数的运算符,它的原型是问题?答案1:答案2.它简洁地表达根据问题成立与否作出二选一的操作.如果问题成立,返回答案1的结果; 如果不成立,返回答案2的结果. 使用三元 ...
- linux服务器load的含义
Linux的Load(系统负载),是一个让新手不太容易了解的概念.load的就是一定时间内计算机有多少个active_tasks,也就是说是计算机的任务执行队列的长度,cpu计算的队列. top/up ...
- Lambda(Linq)
在谈到lambda表达式之前,首先要说一下委托,在下一章会详细介绍委托,在这里就是简单说明一下. 委托的关键字段delegate,声明委托 public delegate void NoReturnN ...