微信回调过程(Python)

def weixin(request):
    if request.method == 'GET':           
                response=HttpResponse()
                try:
                    signature = request.GET['signature']  
                    timestamp = request.GET['timestamp'] 
                    nonce = request.GET['nonce']
                    echostr = request.GET['echostr']
                except: 
                    pass  
                response.write(echostr) 
                return response
    elif request.method == 'POST': 
        xml = request.raw_post_data
        doc = minidom.parseString(xml)
        root = doc.documentElement
        node = root.getElementsByTagName('MsgType')[0]
        rc = ""
        for n in node.childNodes:
          if n.nodeType in ( n.TEXT_NODE, n.CDATA_SECTION_NODE):
            rc = rc + n.data
        MsgType = rc
        node = root.getElementsByTagName('ToUserName')[0]
        rc = ""
        for n in node.childNodes:
          if n.nodeType in ( n.TEXT_NODE, n.CDATA_SECTION_NODE):
            rc = rc + n.data
        ToUserName = rc
        node = root.getElementsByTagName('FromUserName')[0]
        rc = ""
        for n in node.childNodes:
          if n.nodeType in ( n.TEXT_NODE, n.CDATA_SECTION_NODE):
            rc = rc + n.data
        FromUserName = rc
        node = root.getElementsByTagName('CreateTime')[0]
        rc = ""
        for n in node.childNodes:
          if n.nodeType in ( n.TEXT_NODE, n.CDATA_SECTION_NODE):
            rc = rc + n.data
        CreateTime = rc
        dbgFile.write(ToUserName+' '+FromUserName+' '+CreateTime+'\n')
        if MsgType == 'event':
    
             node = root.getElementsByTagName('Event')[0]
             rc = ""
             for n in node.childNodes:
                 if n.nodeType in ( n.TEXT_NODE, n.CDATA_SECTION_NODE):
                     rc = rc + n.data
             Event = str(rc)
             if Event == 'subscribe':
                #用户关注公众号触发事件
             elif Event == 'LOCATION':  #location service
                node = root.getElementsByTagName('Latitude')[0]
                rc = ""
                for n in node.childNodes:
                    if n.nodeType in ( n.TEXT_NODE, n.CDATA_SECTION_NODE):
                        rc = rc + n.data
                Latitude = rc
                node = root.getElementsByTagName('Longitude')[0]
                rc = ""
                for n in node.childNodes:
                    if n.nodeType in ( n.TEXT_NODE, n.CDATA_SECTION_NODE):
                        rc = rc + n.data
                Longitude = rc
                node = root.getElementsByTagName('Precision')[0]
                rc = ""
                for n in node.childNodes:
                    if n.nodeType in ( n.TEXT_NODE, n.CDATA_SECTION_NODE):
                        rc = rc + n.data
                Precision = rc
             elif Event == 'CLICK':
                 #微信菜单click事件
                 node = root.getElementsByTagName('EventKey')[0]
                 rc = ""
                 for n in node.childNodes:
                     if n.nodeType in ( n.TEXT_NODE, n.CDATA_SECTION_NODE):
                         rc = rc + n.data
                 EventKey = rc
                 if EventKey == 'V_INDUSTRYNEWS': 
                     #依据菜单设置的值进行判断           
        elif MsgType == 'text':
            #用户发送文本信息
        elif MsgType == 'voice':
            #用户发送语音信息
        elif MsgType == 'image':
            #用户发送图片信息
        elif MsgType == 'voice':
            #用户发送语音信息

这段时间一直在搞微信,就将微信回调以及动作处理的东西整理了一下,分享出来。


上述代码包括了微信回调以及部分动作的操作判断。重构一下会更简洁些,为了能整体的查看微信的回调模式,就用了笨办法直接全写在了一起。代码里包括了用户关注、判断用户发送信息类别,菜单click事件判断。可根据判断结果对用户进行回复操作。

转载于:https://my.oschina.net/u/585729/blog/607200

您好!要实现微信支付回调的功能,可以使用Python来处理。以下是一个简单的示例代码: ```python import hashlib from flask import Flask, request app = Flask(__name__) @app.route('/wxpay/callback', methods=['POST']) def wxpay_callback(): # 获取请求数据 data = request.data.decode('utf-8') # 将请求数据转换为字典格式 xml_data = xmltodict.parse(data)['xml'] # 验证签名 sign = xml_data.pop('sign') raw_data = '&'.join([f"{key}={xml_data[key]}" for key in sorted(xml_data)]) raw_data += '&key=YOUR_API_KEY' # 替换成您的API密钥 calc_sign = hashlib.md5(raw_data.encode('utf-8')).hexdigest().upper() if calc_sign == sign: # 签名验证通过,处理支付成功逻辑 # 这里可以根据业务需求进行相应的操作,比如更新订单状态等 return '<xml><return_code><![CDATA[SUCCESS]]></return_code><return_msg><![CDATA[OK]]></return_msg></xml>' else: # 签名验证失败 return '<xml><return_code><![CDATA[FAIL]]></return_code><return_msg><![CDATA[Invalid sign]]></return_msg></xml>' if __name__ == '__main__': app.run() ``` 这是一个使用Flask框架编写的示例代码,通过定义一个`/wxpay/callback`的路由来接收微信支付回调通知。在`wxpay_callback`函数中,首先获取请求数据,并将其转换为字典格式。然后,从字典中取出签名,并利用API密钥计算出签名,与请求中的签名进行比对,以验证签名的有效性。如果签名验证通过,可以在相应的条件下进行支付成功的处理逻辑。 请注意,示例代码中的`YOUR_API_KEY`需要替换为您在微信支付商户平台上设置的API密钥。同时,您还需要安装`xmltodict`和`Flask`这两个库,可以使用以下命令来安装它们: ```shell pip install xmltodict Flask ``` 以上是一个简单的微信支付回调处理的示例代码,您可以根据自己的实际需求进行修改和优化。希望能对您有所帮助!如果您还有其他问题,请随时提问。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值