楼主: kevinzhang19701
|
[项目] 小题大做系列II(PM2.5微信控)炒鸡长文体虚慎入 |
本帖最后由 kevinzhang19701 于 2015-12-7 17:09 编辑 加油加油加油(重要的事情说三遍);P |
本帖最后由 kevinzhang19701 于 2015-12-8 10:51 编辑 12.3 XML长啥样 如上样例,这些用"<>"和"</>"成对括起来的就是正宗的XML代码。我们不用了解得很深入,对本项目有用的概念,就是记住微信在回复消息的时候,使用的就是XML格式的字符串。数据来往,就是接受和发送这些符合格式要求的串(字符串含有“元素”、“属性”等)。不过,有一点大家要注意:XML字符串,需要我们自己进行编码和解析。 关于XML的引申阅读链接:http://www.w3school.com.cn/xml/index.asp 12.4 XML的编码和解析 让我们自己编码,问题不大,可以先摸清楚微信文本消息的格式,然后用字符串拼接出来。 然而让我们解析XML字符串,就有一定困难了。不过,老夫这个矮子仍旧可以站在巨人的肩上,借助一个开源项目:dom4j,来完成。 |
本帖最后由 kevinzhang19701 于 2015-12-8 10:55 编辑 13. dom4j开源项目 dom4j的快速入门教程链接如下: http://dom4j.sourceforge.net/dom4j-1.6.1/guide.html 但是我担心翻不了墙的小伙伴会无法看到。 下载地址在Sourceforge,别忘记下载完成后的jar文件要放入Java的lib目录,或者直接在NetBeans里导入这个jar。 http://sourceforge.net/projects/dom4j/files/ 我们的重点在解析上,也就是我们需要从微信服务器传给项目服务器的一长串XML字符串里,提取我们想要的数据值,其他我们就不关心了。整个解析过程可以分如下三步: 13.1 从输入流读取微信服务器传过来的一长串字符串(XML格式)。 13.2 将字符串转换成dom4j可以处理的类型,赋给变量。 13.3 从这个变量中提取需要的参数值(即微信服务器传过来的数据),这一步我们仰赖dom4j自动帮我们完成。 别着急,后面代码我会有解释,先让老夫卖个关子。 |
本帖最后由 kevinzhang19701 于 2015-12-8 11:02 编辑 14. 微信消息的XML格式 14.1 接受消息 我们在微信客户端里发一个言,站在微信服务器的角度来看,就是发送了一个消息(可能是文本消息、语音消息、图像消息、音乐视频消息、地理位置消息等)。这个消息传到微信服务器后,服务器会判断传过来的微信公众号运作在编辑模式还是开发模式,一旦确认是开发模式,那么微信服务器就直接把消息打包成XML字符串转给项目服务器,全部由项目服务器接着去做后续处理。 老夫定义了"/??"为用户获取设备数据的关键词。 项目服务器必须要处理这个叫做“文本消息”的XML字符串。 请大家注意下列连接(接受消息): http://mp.weixin.qq.com/wiki/17/ ... 44d9c96eaf51f9.html 这是开发者文档中重要的一部分,我们关注的是“文本消息”和她的格式。其他格式的消息本项目暂时不使用,如您有兴趣,比如想做个语音消息,可以参考文档的其他部分。 文本消息的格式如下图: 各位看到上面的文本消息格式和解释了吧,我就不啰嗦了。对我们的项目来说,需要提取的是<MsgType>和<Content>两个值。前者我们限定在"text"(老夫只看文本消息,忽略其他的),后者我们限定在"/??"(老夫只看用户是不是发送了/??查询数据,其他忽略)。这两个地方,可以根据您的项目的要求灵活运用。 14.2 回复消息 现在我们已可以判断用户是否发送了查询关键词/??,那么接下来怎么回复给用户呢?请阅读如下链接: http://mp.weixin.qq.com/wiki/18/ ... 46dc39de20f672.html “回复文本消息”说明了我们要回复给微信服务器的也是一串XML格式的字符串,格式如下: 看上去好像和传过来的消息挺像的。这里的ToUserName和FromUserName只需要简单地将传过来的文本消息的To和From交换一下,即可实现回复给发言的那个用户了。 这里的Content参数,就要组织好回复的7个数据的XML串。整个回复文本的样子应该是下面这个样子滴: 那么,上面的7个参数数据从哪里来?对,从我们的数据库里来,而且我们只取数据库最后那一条最新鲜的值。 |
本帖最后由 kevinzhang19701 于 2015-12-8 11:12 编辑 15. 完整的wxtest.class源代码 此为本项目核心代码之三,技术涉及非常广泛,如果您有疑问,欢迎跟帖咨询。 正常情况下,正确反馈应该是下面酱紫滴: |
本帖最后由 kevinzhang19701 于 2015-12-8 11:18 编辑 16. 其他一些注意事项 请允许老夫再啰嗦几句。 本项目只使用了文本消息查询,回复消息也是文本消息。 有小盆友问是否可以接受用户发来的语音、图像、甚至地理位置信息?回答是完全可以接收。不过,由于个人申请的无认证订阅号受到其权限限制,能接受字符串并不意味着可以接受这些语音、图像和地理位置的源数据(微信团队还是很奸诈的,将这些源数据使用MediaId来标识和引用)。这也就是解释了为什么Arduino中文社区里有朋友发的帖子,是使用测试账号制作的自定义菜单来发起查询的(http://www.arduino.cn/forum.php? ... =%E5%BE%AE%E4%BF%A1)。 因为微信团队给测试账号的权限很大很大(顺便说一下上图的自定义菜单是使用JSON而不是XML实现的,需要注意),不过,测试账号就是测试账号,自己用用可以,推广成正式项目就非常可疑了。是吧,这年头骗子太多。 从另外的角度看,如果需要拥有更多的权限、更高大上的形象的话,那么还是需要以公司名义,申请一个乃至多个认证的服务号,或者最高大的企业号。 == 大家可能不太知道,鳗鱼年幼的时候对水温、水质、含氧量等环境要求很高。一旦生活环境稍有不适,会成批死去,严重影响养殖场的收益。几年前,韩国鳗鱼养殖场主们开始使用点状分布的传感器来监控鳗鱼网箱的环境数据,以取代原来每隔一段时间人工测量的繁琐工作。这些数据上传至云端,可以实时从手机上获得。当个别敏感数据的变化超过警戒范围时,手机App会发出警告,及时通知养殖场主是哪个网箱发生了问题,且是什么样的问题。 |
本帖最后由 kevinzhang19701 于 2015-12-8 13:07 编辑 17. 结束语 从上个月25号到今天,陆陆续续把这个项目扯完了。篇幅有点长,话也有点啰嗦,不过,其中着实还有不少东西说得挺含糊甚至没来得及提及的,大家要是恶心想吐就跟帖吐槽吧。 科技行业分析公司Linley Group发布了最新的调研报告。报告显示,到2020年,全球使用的物联网设备将达到19亿个。所以,如果有孩子打算上大学的话,请一定选择IT专业(特别是她们)。未来生活中将充斥着无数的传感器,它们的功耗更小、体积更小、更稳定、更灵敏,我们的生活将因为传感器和智能算法而发生重大的变化。不过数据汇合点仍将在云端,这就是为什么西方敌对势力都极其重视云端的原因。 本项目还存在安全方面的问题,比如终端设备提交给项目服务器的数据没有加密、项目服务器与微信服务器数据交换时也没有加密、获取传感器数据后写入数据库前没有做防注入验证等等,这条数据传输链是不稳定不安全的。如果是生产环境的话,这些都要再加以调整。 这个项目还可以进一步扩展成一个志愿者联盟性质的活动。这意味着有兴趣的地府同好可以人手一台,将实时数据提交到地府某个志愿者的服务器上,数据可供社会查询和进一步加工使用(加工后的数据的使用可能需要支付一定费用;P)。这有个好处,因为花纳税人钱的政府只会提供有限的几个点的某些时间点的空气质量数据,而地府同好来自于世界各地,且覆盖范围更广、数据采集更密集,因此提供的数据量、覆盖面、实时性将更好,社会效益和经济效益都有收获(老夫顺便问问,这个粉尘传感器输出数据是否可以信赖?) (以上灵感来自于:http://www.leiphone.com/news/201508/zxYBDeC5khgC26Zz.html) 谨借宝地谨献此文,预祝地府君们圣诞快乐、新年快乐。 (全文完) |
本帖最后由 kevinzhang19701 于 2015-12-12 20:20 编辑 非常感谢地府萝卜头的厚爱。 尝鲜包内有Romeo Mini BLE和两枚微马达,外加一个环保袋:D:D |
刹那ZF清英 发表于 2015-12-16 08:59 您的鱼菜共生炒鸡棒:D:D:handshake |
© 2013-2025 Comsenz Inc. Powered by Discuz! X3.4 Licensed