[由于远程方关闭传输流,身份验证失败]一次处理支付接口bug记录
因公司系统升级,出现突然有些银行卡不能支付的情况,最开始排查发现是第三方平台接口返回有问题:
返回如下:
从11月7日下午开始一直联系第三方,第三方开始排查,一直说是数据格式有问题。
修改格式以后问题同样出现,又重新调试跟踪下代码,发现如下问题:
看错误描述应该是判断是访问发生问题,又想到了为什么升级以前是好好得,升级以后才出现这个问题?
重新找来官方的demo文档,重新下单测试,发现又是正常的 ?why?把所有的数据复制到系统来,发现还是不能访问。。。。
于是把系统中的请求数据直接写死:
直接访问下单页面 ,OK终于能访问了,到这以为问题已经解决,估计是数据格式问题,然后就又从下单界面测试了一次,发现又不行了 ,
我擦,为什么直接访问接口页面能够访问,通过下单界面调用接口访问而不行了呢?仍然报错误:由于远程方关闭传输流,身份验证失败。
打开百度,出现很多类似的情况,找到各种处理方法,但是都不能解决,太奇怪了啊。于是想起了用Fiddler试试看,果然在这里出现了问题。
当访问失败时请求数据为:
当访问成功时,请求数据为:
两次采用的ssl加密版本方式居然不一样,难道是随机的吗?太奇葩了吧,修改访问时,强制采用Tsl/1.0版本的加密方式:
ServicePointManager.SecurityProtocol = SecurityProtocolType.Tls;
问题终于得到解决,然后现在已经是11月8日的下午了。
话说:对接的两个第三方平台,支付都出问题,
一个是java和.net ,对json反序列化不同,导致验证失败,他们主要使用java。
一个是没有设置正确的ssl访问加密方式,由于第三方平台没有.NET开发了,他们自己也测试不到。
还有一个支付平台,只有php和java的接口,没有.NET的接口,暂时还未对接。
怎么感觉使用.NET的突然好像变少了呢?