支付宝 app支付异常摘记 -- ALI40247

原文链接:https://blog.csdn.net/luojinbai/article/details/52753660

参考链接:https://blog.csdn.net/luojinbai/article/details/52753660

一. 支付

1. 系统繁忙,请稍后重试。(ALI40247): 签名错误。

我的问题来源(两个问题): 
① 签名串sign=签名串,这个签名串是不带双引号的,我不小心两头有双引号; 
② 签名流程是: 
  △ 1. 请求参数按照key=value&key=value方式拼接的未签名原始字符串; 
  △ 2. 再对原始字符串进行签名,参考 签名规则; 
  △ 3. 最后对请求字符串的所有一级value(biz_content作为一个value)进行encode,编码格式按请求串中的charset为准,没传charset按UTF-8处理,获得最终的请求字符串;
  签名之后给value进行URL编码之前,是不需要进行任何编码的,我不小心在这之前给签名穿进行了URL编码,最后相当于签名串URL编码了两次;

  注意:biz_content中的json串不需要进行排序;

2. app调起支付,输入密码之后,提示:暂时无法获取订单信息,请稍后重试。

查找资料应该是签名过了,需要换换更高版本的SDK。 
http://www.cocoachina.com/bbs/read.php?tid-1692932.html 
支付宝升级过sdk,换上最新的sdk,sdk调用也需要更改下,以android为例:
    // 构造PayTask 对象
    PayTask alipay = new PayTask(PayDemoActivity.this);
    // 调用支付接口,获取支付结果
    String result = alipay.pay(payInfo, true);
更新为

    PayTask alipay = new PayTask(PayDemoActivity.this);
    Map<String, String> result = alipay.payV2(orderInfo, true);

  到这里,我的问题还是没有解决,依旧是 暂时无法获取订单信息,请稍后重试,后来检查配置的时候,发现原来是配置错了,两个支付宝商户号,A签约的是移动支付的,B签约的是app支付的,一直报错是配了移动支付的A配置,到这里猜测下错误信息的意思,错误信息中的订单信息可能是商户与支付宝的签约订单,而非商户自己的订单,而A配置是没有签约app支付的,是没有权限使用支付2.0的接口;

3. app调起支付,输入密码之后,提示:系统太忙了,请稍后重来(T8912)。

问题:支付宝订单超时关闭了,超过了支付宝发起支付时候的超时时间。

二. app支付成功之后异步回调验签

1. 签名错误:

  我验签失败是因为把支付宝的公钥弄错了,应该下图指的位置的公钥(开放平台密钥)。 
(图片所在网页地址,https://openhome.alipay.com/platform/keyManage.htm) 

顺便说明下:移动支付和app支付异步回调的验签规则一模一样,两者通用,但是,两者的公钥是不同的,签约app支付的商户也可以用移动支付付款,但是移动支付验签的密钥是从下图指定的地方获取(合作伙伴密钥)。 

顺便说明下:移动支付和app支付异步回调的验签规则一模一样,两者通用,但是,两者的公钥是不同的,签约app支付的商户也可以用移动支付付款,但是移动支付验签的密钥是从下图指定的地方获取(合作伙伴密钥)。 

到这里,我已经懵圈了。

  还有移动支付和app支付的异步通知的数据,同一意思的字段两个的key不一样,比如:订单金额,移动支付里面是‘total_fee’表示,app支付是‘total_amount’表示,其他的字段也有不一样的,这里不一一举例。


三. 退款

  退款的签名算法与支付的是一样的。

1. 撤销或退款金额与订单金额不一致
{
    "code":"40004",
    "msg":"Business Failed",
    "sub_code":"ACQ.REFUND_AMT_NOT_EQUAL_TOTAL",
    "sub_msg":"撤销或退款金额与订单金额不一致",
    "out_trade_no":"2016101413332343230",
    "refund_fee":"0.00",
    "send_back_fee":"0.00"
}

退款的请求参数中,有个参数:out_request_no,标识一次退款请求,参数要求是,如果不填写该参数,表示是交易全额退款,如果同一笔交易多次退款需要保证唯一,如需部分退款,则此参数必传。 
  我的问题是忘记填写该参数了,然后又是部分退款,相当于全额退款,那么退款金额与订单金额不一致了,然后同一笔交易多次退款需要保证唯一的问题,一笔交易分多次退款,每次的退款号要唯一。

————————————————
版权声明:本文为CSDN博主「贱一白」的原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接及本声明。
原文链接:https://blog.csdn.net/luojinbai/article/details/52753660

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章