支付宝分账系统开发之交易分账查询接口alipay.trade.order.settle.query
支付宝分账系统开发之公共请求参数
参数
|
类型
|
是否必选
|
最大长度
|
描述
|
示例值
|
---|---|---|---|---|---|
app_id | String | 必选 | 32 |
支付宝分配给开发者的应用ID
|
2014072300007148 |
method | String | 必选 | 128 |
接口名称
|
alipay.trade.order.settle.query |
format | String | 可选 | 40 |
仅支持JSON
|
JSON |
charset | String | 必选 | 10 |
请求使用的编码格式,如utf-8,gbk,gb2312等
|
utf-8 |
sign_type | String | 必选 | 10 |
商户生成签名字符串所使用的签名算法类型,目前支持RSA2和RSA,推荐使用RSA2
|
RSA2 |
sign | String | 必选 | 344 |
商户请求参数的签名串,详见签名
|
详见示例 |
timestamp | String | 必选 | 19 |
发送请求的时间,格式”yyyy-MM-dd HH:mm:ss”
|
2014-07-24 03:07:50 |
version | String | 必选 | 3 |
调用的接口版本,固定为:1.0
|
1.0 |
app_auth_token | String | 可选 | 40 |
详见应用授权概述
|
|
biz_content | String | 必选 |
请求参数的集合,最大长度不限,除公共参数外所有请求参数都必须放在这个参数中传递,具体参照各产品快速接入文档
|
支付宝分账系统开发之请求参数
参数
|
类型
|
是否必选
|
最大长度
|
描述
|
示例值
|
---|---|---|---|---|---|
settle_no | String | 特殊可选 | 64 |
支付宝分账请求单号,传入该字段,无需再传外部请求号和支付宝交易号
|
20210706002530020036530021395831
|
out_request_no | String | 特殊可选 | 64 |
外部请求号,需要和支付宝交易号一起传入
|
20210727001
|
trade_no | String | 特殊可选 | 64 |
支付宝交易号,传入该字段,需要和外部请求号一起传入
|
2021112611001004680 073956707
|
支付宝分账系统开发之公共响应参数
参数
|
类型
|
是否必选
|
最大长度
|
描述
|
示例值
|
---|---|---|---|---|---|
code | String | 必选 | – |
网关返回码,详见文档
|
40004 |
msg | String | 必选 | – |
网关返回码描述,详见文档
|
Business Failed |
sub_code | String | 可选 | – |
业务返回码,参见具体的API接口文档
|
ACQ.TRADE_HAS_SUCCESS |
sub_msg | String | 可选 | – |
业务返回码描述,参见具体的API接口文档
|
交易已被支付 |
sign | String | 必选 | – |
签名,详见文档
|
DZXh8eeTuAHoYE3w1J+POiPhfDxOYBfUNn1lkeT/ V7P4zJdyojWEa6IZs6Hz0yDW5Cp/viufUb5I0/V5WEN S3OYR8zRedqo6D+fUTdLHdc+EFyCkiQhBxIzgngPdP dfp1PIS7BdhhzrsZHbRqb7o4k3Dxc+AAnFauu4V6Zdwczo= |
支付宝分账系统开发之响应参数
参数
|
类型
|
是否必选
|
最大长度
|
描述
|
示例值
|
---|---|---|---|---|---|
out_request_no | String | 必选 | 64 |
商户分账请求单号
|
20210727001
|
operation_dt | Date | 必选 | 32 |
分账受理时间
|
2021-07-30 12:00:00
|
royalty_detail_list |
RoyaltyDetail[] | 必选 |
分账明细
|
支付宝分账系统开发之请求示例
请求示例
JAVA代码
AlipayClient alipayClient = new DefaultAlipayClient(“https://openapi.alipay.com/gateway.do”,”app_id”,”your private_key”,”json”,”GBK”,”alipay_public_key”,”RSA2″);
AlipayTradeOrderSettleQueryRequest request = new AlipayTradeOrderSettleQueryRequest();
request.setBizContent(“{” +
” \”settle_no\”:\”20210706002530020036530021395831\”,” +
” \”out_request_no\”:\”20210727001\”,” +
” \”trade_no\”:\”2021112611001004680 073956707\”” +
“}”);
AlipayTradeOrderSettleQueryResponse response = alipayClient.execute(request);
if(response.isSuccess()){
System.out.println(“调用成功”);
} else {
System.out.println(“调用失败”);
}
C#代码
IAopClient client = new DefaultAopClient(“https://openapi.alipay.com/gateway.do”, “app_id”, “merchant_private_key”, “json”, “1.0”, “RSA2”, “alipay_public_key”, “GBK”, false);
AlipayTradeOrderSettleQueryRequest request= new AlipayTradeOrderSettleQueryRequest() ;
request.BizContent=”{” +
” \”settle_no\”:\”20210706002530020036530021395831\”,” +
” \”out_request_no\”:\”20210727001\”,” +
” \”trade_no\”:\”2021112611001004680 073956707\”” +
“}”;
AlipayTradeOrderSettleQueryResponse response=client.Execute(request);
Console.WriteLine(response.Body);
PHP代码
$aop = new AopClient ();
$aop->gatewayUrl = ‘https://openapi.alipay.com/gateway.do’;
$aop->appId = ‘your app_id’;
$aop->rsaPrivateKey = ‘请填写开发者私钥去头去尾去回车,一行字符串’;
$aop->alipayrsaPublicKey=’请填写支付宝公钥,一行字符串’;
$aop->apiVersion = ‘1.0’;
$aop->signType = ‘RSA2′;
$aop->postCharset=’GBK’;
$aop->format=’json’;
$request = new AlipayTradeOrderSettleQueryRequest ();
$request->setBizContent(“{” .
” \”settle_no\”:\”20210706002530020036530021395831\”,” .
” \”out_request_no\”:\”20210727001\”,” .
” \”trade_no\”:\”2021112611001004680 073956707\”” .
“}”);
$result = $aop->execute ( $request);
$responseNode = str_replace(“.”, “_”, $request->getApiMethodName()) . “_response”;
$resultCode = $result->$responseNode->code;
if(!empty($resultCode)&&$resultCode == 10000){
echo “成功”;
} else {
echo “失败”;
}
HTTP模式代码
https://openapi.alipay.com/gateway.do?timestamp=2013-01-01 08:08:08&method=alipay.trade.order.settle.query&app_id=30601&sign_type=RSA2&sign=ERITJKEIJKJHKKKKKKKHJEREEEEEEEEEEE&version=1.0&charset=GBK&biz_content=AlipayTradeOrderSettleQueryModel
支付宝分账系统开发之响应示例
XML代码
{
“alipay_trade_order_settle_query_response”: {
“out_request_no”: “20210727001”,
“operation_dt”: “2021-07-30 12:00:00”,
“royalty_detail_list”: [
{
“operation_type”: “transfer”,
“execute_dt”: “2021-07-30 12:00:00”,
“trans_out”: “2088111111111111”,
“trans_out_type”: “userId”,
“trans_in”: “2088111111112222”,
“trans_in_type”: “userId”,
“amount”: 10,
“state”: “FAIL”,
“error_code”: “TXN_RESULT_ACCOUNT_BALANCE_NOT_ENOUGH”,
“error_desc”: “分账余额不足”
}
]
}
}
<alipay_trade_order_settle_query_response>
<code>10000</code>
<msg>Success</msg>
<out_request_no>20210727001</out_request_no>
<operation_dt>2021-07-30 12:00:00</operation_dt>
<royalty_detail_list list=”true”>
<royalty_detail>
<operation_type>transfer</operation_type>
<execute_dt>2021-07-30 12:00:00</execute_dt>
<trans_out>2088111111111111</trans_out>
<trans_out_type>userId</trans_out_type>
<trans_in>2088111111112222</trans_in>
<trans_in_type>userId</trans_in_type>
<amount>10.00</amount>
<state>FAIL</state>
<error_code>TXN_RESULT_ACCOUNT_BALANCE_NOT_ENOUGH</error_code>
<error_desc>分账余额不足</error_desc>
</royalty_detail>
</royalty_detail_list>
</alipay_trade_order_settle_query_response>
说明:本示例仅供参考。
异常示例
{
“alipay_trade_order_settle_query_response”: {
“code”: “20000”,
“msg”: “Service Currently Unavailable”,
“sub_code”: “isp.unknow-error”,
“sub_msg”: “系统繁忙”
},
“sign”: “ERITJKEIJKJHKKKKKKKHJEREEEEEEEEEEE”
}
错误码
公共错误码
前往查看
业务错误码
错误码
|
错误描述
|
解决方案
|
---|---|---|
INVALID_PARAMETER | 参数有误,分账查询请求参数格式非法 | 检查请求参数,修改后重新发起请求 |
SYSTEM_ERROR | 系统繁忙 | 如果多次调用依然报此错误码,请联系支付宝客服 |
MERCHANT_TRADE_NOT_MATCH | 交易与商户不匹配 | 交易不属于该商户,请确定交易号与商户关系修改后重新发起 |
OPENID_APPID_NOT_MATCH | OPENID值和APPID不匹配 | 检查自己OpenId和APPID是否一致,检查一致仍报错,则需要联系支付宝技术支持 |