Django开发微信公众平台

 2023-09-05 阅读 353 评论 0

摘要:处理微信发来的信息,实际上就是处理xml的过程。先写xml工具类 # -*- coding:utf-8 -*- from xml.dom import minidom from Web.model.WeiXin import *def get_attrvalue(node, attrname):return node.getAttribute(attrname) if node else ''def get_nodevalu

处理微信发来的信息,实际上就是处理xml的过程。先写xml工具类

# -*- coding:utf-8 -*-
from xml.dom import minidom
from Web.model.WeiXin import *def get_attrvalue(node, attrname):return node.getAttribute(attrname) if node else ''def get_nodevalue(node, index = 0):return node.childNodes[index].nodeValue if node else ''def get_xmlnode(node,name):return node.getElementsByTagName(name) if node else []def xml_to_string(xml):doc = minidom.parse(xml)return doc.toxml('UTF-8')def get_xml_data(xml):doc = minidom.parseString(xml)root = doc.documentElementToUserName = get_nodevalue(get_xmlnode(root,'ToUserName')[0]).encode('utf-8','ignore')FromUserName = get_nodevalue(get_xmlnode(root,'FromUserName')[0]).encode('utf-8','ignore')CreateTime = get_nodevalue(get_xmlnode(root,'CreateTime')[0]).encode('utf-8','ignore')MsgType = get_nodevalue(get_xmlnode(root,'MsgType')[0]).encode('utf-8','ignore')Content = get_nodevalue(get_xmlnode(root,'Content')[0]).encode('utf-8','ignore')MsgId = get_nodevalue(get_xmlnode(root,'MsgId')[0]).encode('utf-8','ignore')return WeiXin(ToUserName=ToUserName,FromUserName=FromUserName,CreateTime=CreateTime,MsgType=MsgType,Content=Content,MsgId=MsgId)if __name__ =='__main__':xml = '<xml><ToUserName><![CDATA[gh_d740805e3dda]]></ToUserName><FromUserName><![CDATA[otvK9uEl5TdgfKaDtBhSb6CM49Xs]]></FromUserName><CreateTime>1426579233</CreateTime><MsgType><![CDATA[text]]></MsgType><Content><![CDATA[哈哈]]></Content><MsgId>6127111151090981083</MsgId></xml>'print get_xml_data(xml)


封装一个微信xml实体类:

__author__ = 'zan'
class WeiXin():def __init__(self,ToUserName,FromUserName,CreateTime,MsgType,Content,MsgId):self.ToUserName= ToUserNameself.FromUserName= FromUserNameself.CreateTime= CreateTimeself.MsgType= MsgTypeself.Content= Contentself.MsgId= MsgIddef __repr__(self):return 'ToUserName=%s,\n FromUserName=%s,\nCreateTime=%s,\n,MsgType=%s,\nContent=%s,\nMsgId=%s\n' %(self.ToUserName,self.FromUserName,self.CreateTime,self.MsgType,self.Content,self.MsgId)

最后解析xml,并返回xml

def weixin(requset):print 'requset.body=========%s'%requset.bodyif not requset.body.strip():return HttpResponse('error')weixinObj = get_xml_data(requset.body)print '解析之前 %s'%weixinObjtoUserName = weixinObj.FromUserName;fromUserName = weixinObj.ToUserName;weixinObj.FromUserName = fromUserName;weixinObj.ToUserName = toUserName;print '解析之后 %s'%weixinObjresult = '<xml><ToUserName><![CDATA[%s]]></ToUserName><FromUserName><![CDATA[%s]]></FromUserName><CreateTime>%s</CreateTime><MsgType><![CDATA[%s]]></MsgType><Content><![CDATA[%s]]></Content><MsgId>%s</MsgId></xml>'%(weixinObj.ToUserName,weixinObj.FromUserName,weixinObj.CreateTime,weixinObj.MsgType,weixinObj.Content,weixinObj.MsgId)return HttpResponse(result)



转载于:https://www.cnblogs.com/gavanwanggw/p/7235965.html

版权声明:本站所有资料均为网友推荐收集整理而来,仅供学习和研究交流使用。

原文链接:https://hbdhgg.com/1/540.html

发表评论:

本站为非赢利网站,部分文章来源或改编自互联网及其他公众平台,主要目的在于分享信息,版权归原作者所有,内容仅供读者参考,如有侵权请联系我们删除!

Copyright © 2022 匯編語言學習筆記 Inc. 保留所有权利。

底部版权信息