前几天对接微信支付, 支付流程都没什么问题了但是回调这一块感觉就是一个天坑。
在本地测试回调的时候用官方文档给的XML格式来测试,然后就开始报错Unsupported Media Type
原因是 Django 无法解析Body为XML的格式,去官方文档找了一下有没有XML解析器,然后在rest-framework官方文档找到了这个包。
pip install djangorestframework-xml
下载这个包把它在类视图里面添加
添加完了之后就可以愉快的解析XML格式的请求了,但是会有一个问题,就是这个类视图只能解析Body为XML格式的。如果还要解析其他格式的要在列表中再添加对应的解析器。
本来以为添加了这个包就可以愉快的上线赚钱了,但是万万没想到。付款流程走完了之后微信回调还是一直报错Unsupported Media Type
检查了一下XML解析器也支持了,然后自己从本地发送了一个XML格式的请求,也都是可以请求的,看了一下日志,发现给微信回调返回的HTTP状态码是HTTP/415。百度了一下这个状态码说的是Content-Type格式不正确,想了一下自己也是支持了XML格式的。于是我觉得是微信回调那边的问题,就写了一个中间件每次Django收到请求之后把request的请求头打印出来。
果然就是微信回调那边的问题,官方提供的XML解析器需要请求头为 Content-Type: application/xml 才会触发。但是微信回调的Content-Type是 text/xml 因为跟XML解析器Content-Type 的条件不一样所以无法触发。也匹配不上其他的解析器所以就会一直报错,最后在网上找了一下Django 有没有支持text/xml 的解析器找了一圈也没找到。于是就百度了一下application/xml 和 text/xml 的区别,发现区别也不大就想自己写一个解析器,接着进去看了下官方的XML解析器。
发现完全可以把这个
media_type = 'application/xml'
改成 media_type = 'text/xml'
想到就做先把源码复制下来,去自己的工具类文件夹里建立一个新的文件夹,把源码粘贴过去改一下类名。然后在类试图指定刚创建的解析器类,
parser_classes = [TextXMLParser]
改完之后在本地测试全部通过,放服务器上也全部都通过,问题完美解决。