最近做微信支付遇到的几个问题,记录一下
1.成功支付后回调
支付成后回调,由于是用wcf写的restful风格的api,原本官方demo返回的是一个xml数据,读取方法是通过
HttpContext.Current.Request.InputStream来读取的,监听到回调方法获取到InputStream的Length为0,
但是从WebServiceHostFactory监听到的这个对象是有值的,于是就考虑是不是要修改webconfig配置,来
修改behavior,结果无功而返,后来从网上找到,wcf读取post报文是用OperationContext.Current.RequestContext.RequestMessage,成功读到对应的值
2.退款问题
一开始退款功能开发参看支付订单的接口,直接用postman测试接口,发现接口怎么都调不通,一度想去咨询微信客服,后来在开发文档中发现,是需要双向证书验证的,如图
按照步骤去下载证书文件,并且按照指示双击安装,下载了官方的demo正常跑起来,
然后把同样的方法写入自己的接口,结果还是连不通微信接口的,基础连接关闭,百思不得其解,
同样的代码官方的winform程序能跑起来,我的接口跑不起来??代码如下
于是就考虑是不是又和wcf的配置有关,按照网上找的资料修改了webconfig,把aspNetCompatibilityEnabled="true",结果还是不行,后面想到会不会和iis有关,上网一找,
基础连接已关闭 连接被意外关闭 其实是没访问到证书,会不会和IIS有关系能,后来得证果然证书是需要添加IIS_User角色,配置完成后,终于,正常调用了
解决方法是
1.开始-运行 输入mmc
2.文件-添加/删除管理单元 在可用的管理单元中选择 证书 添加到右侧 弹框选择计算机帐户
3.展开个人-证书 选择你导入的证书或从这里右键导入
4.右击证书-所有任务-管理私钥
5.添加IIS_IUser 勾选读取就行
3.退款回调
这里也是一个小坑,退款回调里面有一个req_info的加密值,根据官方的介绍,需要base64解码后根据商户号相关的秘钥再AES解密,如图
后按照步骤base64解码再AES解密,发现一只保存,提示存在非base64字符,于是监听发现,原来req_info本来就是base64,直接用MD5的key进行AES解密,得到相关的信息
4.回调告知微信
2个回调通知,一个是退款回调,需在微信后台设置url,一个是支付回调,在申请订单的时候带上,另外就是回调后如何告知微信端我已经收到回调,官方的解释是返回一传xml数据如下:
但是实际上回复succes或者fail即可,中间遇到的问题是我回复了结果后,微信还是会多次回调结果给我,用SNAP抓包软件查看一切正常,(微信IP->我的IP,我的IP返回结果给微信IP)后面把回调后我这边的逻辑代码注销掉,回复结果就正常结束支付.再观察SNAP,发现我的逻辑中间有一次调用第三方的接口,多了一个HttpWebRequest请求第三方充值的功能,(微信ip->我的IP,我的IP->第三方接口ip,第三方接口回复结果到我的ip,我的ip最后把处理结果反馈给微信ip)我把这一句注销掉后也是正常,后面就考虑是否超时或者HTTPCONTEXT被改变了,结果我把这段逻辑代码用asyn/await去做协程处理(之前有一个老哥告诉了我kotlin有协程这样的一个概念,刚好运用上了),于是加上了异步处理,把支付回调反馈给微信端的结果马上response回去,这下就正常了,asyn的task也照样能跑,但是最后还是搞不懂为什么同步下去的不会正常回馈给微信端……
最后
终于,完成了所有支付到退款的流程,感觉微信的策略还是很严谨靠谱的,但是坑太多,个人感觉还是阿里的API写得比较稳一点,以上还是把支付流程封住成一个类,并且记录一下,以免以后再遇到同样的坑,接下来继续研究sip,开源的C++项目……