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

一. 支付

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调起支付,输入密码之后,提示:暂时无法获取订单信息,请稍后重试。

	// 构造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支付的异步通知的数据,同一意思的字段两个的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,标识一次退款请求,参数要求是,如果不填写该参数,表示是交易全额退款,如果同一笔交易多次退款需要保证唯一,如需部分退款,则此参数必传。
  我的问题是忘记填写该参数了,然后又是部分退款,相当于全额退款,那么退款金额与订单金额不一致了,然后同一笔交易多次退款需要保证唯一的问题,一笔交易分多次退款,每次的退款号要唯一

  • 4
    点赞
  • 12
    收藏
    觉得还不错? 一键收藏
  • 5
    评论
评论 5
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值