zoukankan      html  css  js  c++  java
  • 微信快速开发框架(一)-- 对微信公众平台开发的消息处理

    这几天有点空,做了个Android App后,想着对接一下公司的微信平台,以便让客户更方便查询,在研究微信平台中,要注意以下几点:
    1、微信验证消息真实性是用Get方式到你提交的url
    2、用户发送的消息、事件等都是通过Post方式提交过来
    3、微信服务器端发送过来的,是xml格式,通过HttpRequest.InputStream获取
    4、在处理用户消息的时候,如果你要返回信息的话,您只要输出xml格式的字符串就可以了。

    如何读取微信客户端信息:

    var stream = Request.InputStream;
    var reader = XmlReader.Create(stream);
    var doc = XDocument.Load(reader);

    我把消息流转换成XDocument,方便操作,返回的时候我也用了比较偷懒的办法:

    >var resultDoc = new XDocument();
    var root = new XElement("xml", new XElement(), new XElement());
    resultDoc.add(root);
    Response.Write(resultDoc.ToString());

    获取用户发送的消息:

    >doc.Element("xml").Element("Content");

    通过分析用户发送的内容,我们可以做很多事情,大家也可以参考下博客园大咖:"方倍工作室"

    在开发中,发觉几个问题:
    1、在“验证消息真实性”验证中,无需返回什么特殊的比对结果,只要返回“echostr”就代表验证通过
    2、对收到的消息、事件等,都没有明确的Action,仅单单靠Post方式发送到指定的Url
    3、创建的时间参数,在文档中只写明了整形,没有提到这个整形与时间的对应,难道是TICK?

    也不是说以上方式存在什么问题,但在处理收到的消息的时候,没有让我进行任何判断的地方,这是很头大的事情。还有微信对自己服务器很有信心,没把dns劫持考虑进来,每次消息的反馈不需要我进行任何验证返回,这点淘宝平台还是不错的。还有微信的文档,着实难懂,一眼看来,觉得是自己写给自己看的文档,汗!

    公司微信公众平台账号:sh_bus
    测试数据:发送消息:4660+13701111111

  • 相关阅读:
    k8s-基础入门
    Compose编排Spring Cloud微服务2
    Compose 编排 SpringCloud微服务
    Docker Compose 编排微服务
    首篇博客
    Vue--计算属性和侦听器
    Vue--事件处理--事件修饰符
    css 盒子模型理解
    移动前端开发之viewport的深入理解
    js中几种实用的跨域方法原理详解
  • 原文地址:https://www.cnblogs.com/inday/p/weixin-dev-msg-Question.html
Copyright © 2011-2022 走看看