微信企业支付--遇到不明确结果的err_code:SYSTEMERROR,NOT_FOUND

前提

项目开发中实现微信提现的功能。使用到了两个接口

企业付款接口:https://api.mch.weixin.qq.com/mmpaymkttransfers/promotion/transfers【https://pay.weixin.qq.com/wiki/doc/api/tools/mch_pay.php?chapter=14_2】

查询企业付款接口:https://api.mch.weixin.qq.com/mmpaymkttransfers/gettransferinfo 【https://pay.weixin.qq.com/wiki/doc/api/tools/mch_pay.php?chapter=14_3】

为什么有不能马上知道付款结果的情况--遇到err_code=SYSTEMERROR

根据支付文档https://pay.weixin.qq.com/wiki/doc/api/tools/mch_pay.php?chapter=14_2,可知,主要看3个字段

return_code :通信标识,非交易标识,此字段是通信标识,非交易标识,交易是否成功需要查看result_code来判断

result_code:  交易标识

err_code :错误编码

只有在return_code 和 result_code 同时为SUCCESS时 才可判断 交易成功

那么return_code ==SUCCESS result_code =FAIL的时候呢?根据文档可知result_code 才是交易标识,这时应该判定位交易失败才对,

然而,在实际应用中发现,真相并不是这样的。

在一次付款日志中出现,return_code ==SUCCESS result_code =FAIL 有err_code时 【err_code=SYSTEMERROR:系统繁忙,请稍后再试】

我们判定了为交易失败,但是微信方面却在几天后,成功支付了这笔钱,这就就导致了损失。

所以,付款API 除了有即时成功 即时失败的情况外 还有一些意外的情况 :不能马上判断是成功了还是失败了

对于那些不能马上知道结果的交易订单应该怎么处理?

对于那些不能即时成功的交易记录,我们使用第二个微信接口:查询企业付款接口:https://api.mch.weixin.qq.com/mmpaymkttransfers/gettransferinfo

定期去查询这些记录的微信处理结果,如果返回即时成功/失败时 才在我们这边处理金额数据。这样就尽量避免了出现上面会造成损失的情况。

查询企业付款接口遇到的err_code=NOT_FOUND问题

但是这个查询企业付款接口 ,在实际应用中,我们又遇到了一个新的问题:

  • 付款接口返回即时成功时,下一秒马上使用查询接口去查询该订单号的交易结果时,返回的却是err_code=NOT_FOUND而不是成功。再隔一个时间去查询时 就返回交易结果为成功了。

这种情况,因为付款成功到调用查询接口的时间间隔太短 (只有1秒)导致的,这1秒期间微信那边的订单可能还没有入库,导致查询结果为订单号不存在,再隔一段时间去查就为成功了。

这是因为付款成功后,刚好就到了定时任务启动的时间段,马上就去执行查询订单结果的脚本的结果,这是使用定时任务无法避免的会出现的情况。

  所以,有err_code=NOT_FOUND并不代表 真的交易失败,err_code为NOT_FOUND时可能只是数据没有入库的原因。

总结上文工作中遇到的情况,可以归纳如下结果

  • 付款接口
  1. return_code=result_code=SUCCESS   -->可以 判定为即时交易成功
  2. return_code=FAIL           -->可以判定为即时交易失败 
  3. err_code=SYSTEMERROR       -->不可判定交易结果,需要定时去调用查询付款接口取确定,直到明确结果
  4. 其他 明确失败的err_code则 可以判定为即时失败(err_code=NOAUTH/AMOUNT_LIMIT等)
  5. 其他不可判定交易结果,需要定时去调用查询付款接口取再去确定,直到明确结果
  • 查询付款接口
  1. return_code=result_code=SUCCESS时:

  status=SUCCESS   交易成功

  status = FAILED    交易失败

  status=PROCESSING 交易处理中

  2.return_code=SUCCESS,result_code=FAIL时:

  err_code=NOT_FOUND 不可判定交易结果,需要定时去调用查询付款接口取再去确定,直到明确结果

  其他 明确失败的err_code 则可以判定为即时失败(err_code=NOAUTH/AMOUNT_LIMIT等)

  3.其他不可判定交易结果,需要定时去调用查询付款接口取再去确定,直到明确结果

 

时间: 2024-08-18 03:18:52

微信企业支付--遇到不明确结果的err_code:SYSTEMERROR,NOT_FOUND的相关文章

thinkphp 微信支付 thinkphp 微信企业付款

前面已经跑通了微信支付的流程,接下来吧微信支付和微信企业付款接入到thinkphp中,版本是3.2 把微信支付类.企业付款类整合到一起放到第三方类库,这里我把微信支付帮助类和企业付款类放到同一个文件了: 把Payment整个文件夹放到\ThinkPHP\Library\Vendor文件夹下面,打开WxPay.pub.config.php,配置四个参数即可,然后把微信提供的证书放到caccert文件夹:这样就完成了支付和 企业付款的所有代码配置! 待续...

微信支付 企业转账 小程序发红包 提现 发红包 企业支付等遇到的问题

最近公司在开发一个项目,小程序抢红包,抢到的红包用户要提现.商家需要通过微信的企业转账功能打款到微信的钱包里. 开发的时候发现有几个坑,在这里和大家分享下.首先就是微信支付的开通条件. 第一个,就是个体工商户注册的微信支付,是没有企业转账到微信钱包的功能的.必需是企业资质申请的才有. 然后发现个体工商户里有一个转账到个人银行卡的,这个是要收千分之一的手续费,也是微信最近推出来的功能,但是,既然在微信官方开发文档里找不到相关的api接口文档.额,还在内测期间么.... 请注意开通的前两个条件,如果

微信企业红包开发(php)

微信的开发真的有点麻烦,不是难,就是烦,细节多,东西多,关联多 这里记录下 微信企业红包开发的整个过程(弄完的话  微信支付 也差不多了,代码是 php的) 申请:这里只说简单的过程 先申请公众服务号 在服务号中申请'微信支付'(登录公众号平台首页左面有这个菜单),觉得微信在推广移动支付,所以还是很好申请的,关于申请中填写的网站最好做一个购买的演示链接,这样可能更容易下来. 证书 微信支付申请下来了,那么你有了一个 微信的 商户号和登录密码 (会发邮件给你) 还是从申请微信支付哪里 点到  微信

微信JSApi支付~集成到MVC环境后的最后一个坑(网上没有这种解决方案)

大叔第一人 之前写了关于微信的坑<微信JSApi支付~坑和如何填坑>,今天将微信的jsapi支付封装到了MVC环境里,当然也出现了一些新的坑,如支付参数应该是Json对象而不是Json字符串,这样也会应付引起“get_brand_wcpay_request:fail_invalid appid”这个大家都知道的异常,呵呵,解决方案网上说是“授权目录“,事实上,还有一种原因,那就是你的WeixinJSBridge.invoke方法里的参数应该是Json对象而不是字符串,这才是最重要的. 代码我们

Zabbix微信企业订阅号报警设置

Zabbix微信企业订阅号报警设置 官方提供了较全的api,使用个人订阅号测试时,发现很多接口没有权限,无法获取订阅者openid,导致无法发送消息,然后要来了公司的企业订阅号来进行报警. 微信公众号登录:https://mp.weixin.qq.com/ 微信api参考:http://mp.weixin.qq.com/wiki/16/992df48524118c3e89945856694b30cc.html 微信api在线调试:http://mp.weixin.qq.com/debug/ 微信

微信企业付款到银行卡

第一次做微信企业付款到银行卡,特地记录下来,因为这个功能自己用了2-3天,这中间的坑主要是再rsa加密那块.自己记录下来,供朋友参考.自己用的php开发 第一,首先你需要开通企业的微信认证公众号平台,然后开通支付功能.这些我就不说了.自己开通. 第二,看文档, 第三步,发送请求接口,发送后,腾讯会给你响应.特别要说明一点的是,腾讯这个功能真不便宜,我测试时一元钱,手续费扣了我一元.最少金额是一元. 在发送接口时有个公钥我们首先要获得,同时里面有个签名算法,公钥主要用于到时银行账号和收款人姓名加密

小黑式烂代码之微信APP支付 + 退款(JAVA实现)

首先,你得先有微信开发平台账号密码还需要开通应用,然后还有微信服务商平台商户版账号(这些我都是给产品经理拿的) 其次我认为你先去看一看微信开发平台的文档!  https://pay.weixin.qq.com/wiki/doc/api/index.html 这里有很多种支付,我就采用APP支付来说了(会了APP支付其实H5支付都差不多的!) 进来后是这样的,随便看看'APP支付那几篇文章'讲的流程!,看完后知道大概了就可以看看'API列表了' 我们后台开发需要关注的就是这三个API了! 1 /*

.Net后台实现微信APP支付

上一节分享了微信小程序支付的后台,这一节来分享一下微信APP支付的后台.微信APP支付和微信小程序差别不大,微信APP支付后台不需要微信登录凭证.后台下单时交易类型(trade_type)不再是"JSAPI",而是"APP".商户后台传递给支付端的下单参数也有所不同.由于微信小程序支付和APP支付使用的APPID不同,索性直接写了两套支付,不再在代码里区分究竟该使用小程序支付的配置参数还是APP支付的参数. 官方是这样介绍的 具体实现: 新建AppPayConfig

第三方聚合支付vs微信支付宝支付,有何区别?

自移动支付逐步取缔了现金支付后,现在我们在商户的收银台上会看到各种二维码牌,一般比较经常看到的主要是微信L牌.支付宝二维码L牌,有部分商户会直接打印二维码帖子在桌面上.现在很多人估计会听到有些朋友是做微信和支付宝的移动支付,那么他们所说的做微信和支付宝的移动支付究竟是什么?聚合支付品牌有哪些?微信作为聚合支付品牌国内支付龙头企业,根据微信在2018年发布的<2018微信年度数据报告>显示,2018年,微信每个月有10.82亿用户保持活跃,每天有450亿次信息发送出去,每天有4.1亿音视频呼叫成