华企号 后端开发 支付宝分账系统开发之alipay.trade.royalty.relation.bind(分账关系绑定)接口

支付宝分账系统开发之alipay.trade.royalty.relation.bind(分账关系绑定)接口

支付宝分账系统开发之alipay.trade.royalty.relation.bind(分账关系绑定)接口,支持第三方代理调用

当商户签约分账产品后,授权ISV帮其进行分账关系的维护。本接口用于商户与分账方的关系绑定。
公共请求参数
参数
类型
是否必选
最大长度
描述
示例值
app_id String 必选 32
支付宝分配给开发者的应用ID
2014072300007148
method String 必选 128
接口名称
alipay.trade.royalty.relation.bind
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 必选
请求参数的集合,最大长度不限,除公共参数外所有请求参数都必须放在这个参数中传递,具体参照各产品快速接入文档
请求参数
参数
类型
是否必选
最大长度
描述
示例值

receiver_list

RoyaltyEntity[] 必选
分账接收方列表,单次传入最多20个
out_request_no String 必选 32
外部请求号,由商家自定义。32个字符以内,仅可包含字母、数字、下划线。需保证在商户端不重复。
2019032200000001
公共响应参数
参数
类型
是否必选
最大长度
描述
示例值
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/V5WENS3OYR8z
Redqo6D+fUTdLHdc+EFyCkiQhBxIzgngPdPdfp1PIS7BdhhzrsZ
HbRqb7o4k3Dxc+AAnFauu4V6Zdwczo=
响应参数
参数
类型
是否必选
最大长度
描述
示例值
result_code String 必选 16
SUCCESS:分账关系绑定成功;
FAIL:分账关系绑定失败。
SUCCESS
支付宝分账系统开发之请求示例

 

AlipayClient alipayClient = new DefaultAlipayClient("https://openapi.alipay.com/gateway.do","app_id","your private_key","json","GBK","alipay_public_key","RSA2");
AlipayTradeRoyaltyRelationBindRequest request = new AlipayTradeRoyaltyRelationBindRequest();
request.setBizContent("{" +
"  \"receiver_list\":[" +
"    {" +
"      \"type\":\"userId\"," +
"      \"account\":\"2088xxxxx00\"," +
"      \"name\":\"测试名称\"," +
"      \"memo\":\"分账给测试商户\"," +
"      \"login_name\":\"test@alitest.xyz\"," +
"      \"bind_login_name\":\"test@alitest.xyz\"" +
"    }" +
"  ]," +
"  \"out_request_no\":\"2019032200000001\"" +
"}");
AlipayTradeRoyaltyRelationBindResponse 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);
AlipayTradeRoyaltyRelationBindRequest request= new AlipayTradeRoyaltyRelationBindRequest() ;
request.BizContent="{" +
" \"receiver_list\":[" +
" {" +
" \"type\":\"userId\"," +
" \"account\":\"2088xxxxx00\"," +
" \"name\":\"测试名称\"," +
" \"memo\":\"分账给测试商户\"," +
" \"login_name\":\"test@alitest.xyz\"," +
" \"bind_login_name\":\"test@alitest.xyz\"" +
" }" +
" ]," +
" \"out_request_no\":\"2019032200000001\"" +
"}";
AlipayTradeRoyaltyRelationBindResponse 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 AlipayTradeRoyaltyRelationBindRequest ();
$request->setBizContent(“{” .
” \”receiver_list\”:[” .
” {” .
” \”type\”:\”userId\”,” .
” \”account\”:\”2088xxxxx00\”,” .
” \”name\”:\”测试名称\”,” .
” \”memo\”:\”分账给测试商户\”,” .
” \”login_name\”:\”test@alitest.xyz\”,” .
” \”bind_login_name\”:\”test@alitest.xyz\”” .
” }” .
” ],” .
” \”out_request_no\”:\”2019032200000001\”” .
“}”);
$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.royalty.relation.bind&app_id=30608&sign_type=RSA2&sign=ERITJKEIJKJHKKKKKKKHJEREEEEEEEEEEE&version=1.0&charset=GBK&biz_content=AlipayTradeAllocationRelationBindModel
分账系统开发请求示例PHP版本
响应示例

 

{
    "alipay_trade_royalty_relation_bind_response": {
        "code": "10000",
        "msg": "Success",
        "result_code": "SUCCESS"
    },
    "sign": "ERITJKEIJKJHKKKKKKKHJEREEEEEEEEEEE"
}
xml
<alipay_trade_royalty_relation_bind_response> 
<code>10000</code> 
<msg>Success</msg> 
<result_code>SUCCESS</result_code> 
</alipay_trade_royalty_relation_bind_response>

说明:本示例仅供参考。

异常示例
json
{
    "alipay_trade_royalty_relation_bind_response": {
        "code": "20000",
        "msg": "Service Currently Unavailable",
        "sub_code": "isp.unknow-error",
        "sub_msg": "系统繁忙"
    },
    "sign": "ERITJKEIJKJHKKKKKKKHJEREEEEEEEEEEE"
}
错误码
公共错误码

前往查看

业务错误码
状态码
错误码
错误描述
解决方案
400 INVALID_PARAMETER 参数有误参数有误 检查请求参数,修改后重新发起请求
400 RELATION_QUANTITY_LIMIT 达到分账关系集数量上限 分账关系集数量有上限,当达到上限后,无法继续添加分账方。可删除无用的分账方后,再发起分账关系绑定。
400 PRODUCT_UNSIGN 未签约分账产品 商户需在签约分账产品的情况下,才可进行分账关系集的新增操作。请先确认商户是否签约分账产品。
400 USER_NOT_EXIST 分账接收方不存在 请确认分账接收方类型或者账号无误后重试
400 SYSTEM_ERROR 系统繁忙 如果多次调用依然报此错误码,请联系支付宝客服
400 RECEIVER_LIST_EMPTY 分账收款方列表为空 请检查分账收款方列表是否为空
400 RECEIVER_LIST_OVERLOAD 分账收款方列表数量超限 请检查分账收款方列表数量是否超过了20
400 INVALID_RECEIVER_TYPE 分账收款方类型参数非法 请检查分账收款方类型参数
400 USERNAME_NOT_MATCH 分账接收方全称不匹配 请检查分账方全称是否正确
400 RECEIVER_ACCOUNT_NOT_CERTIFY 分账收款方账号未完成实名认证 请在支付宝完成实名认证,或更换一个已认证账号作为分账收款方
400 RECEIVER_ACCOUNT_NO_BALANCE 分账收款方账号无支付宝账户 分账收款方支付宝账号未开立余额账户,请确认收款方账号是否正确,更换账号后重新发起
400 RECEIVER_ACCOUNT_STATE_INVALID 分账收款方账号被冻结或已注销 分账收款方账号被冻结或已注销,请联系支付宝小二确认原因
400 OPENID_APPID_NOT_MATCH OPENID与APPID不匹配 检查当前接口调用时使用的appId与获取openId时使用的appId是否是同一个(需一致)

作者: 李铁牛程序员

李铁牛,一直致力于企业客户软件定制开发,计算机专业毕业后,一直从事于互联网产品开发到现在。微信技术交流:tieniu6636
上一篇
下一篇

发表回复

联系我们

联系我们

028-84868647

在线咨询: QQ交谈

邮箱: tech@68v8.com

工作时间:周一至周五,9:00-17:30,节假日休息

关注微信
微信扫一扫关注我们

微信扫一扫关注我们

关注微博
返回顶部