说明:
  本帖是利用支付宝沙箱测试电脑网站支付接口

  测试环境:Apache2.4.23 +php 5.6.25

  沙箱环境测试正式环境请修改网关为下方值

  

1
正式环境网关:https://openapi.alipay.com/gateway.do

注意事项:

  1.目前仅支持账户余额渠道付款。

  2.转账额度

    1)单日转出累计额度为100万元。

    2)转账给个人支付宝账户,单笔最高5万元;转账给企业支付宝账户,单笔最高10万元。

特殊逻辑注意点:

  1)如果商户重复请求转账,支付宝会幂等返回成功结果,商户必须对重复转账的业务做好幂等处理;如果不判断,

  存在潜在的风险,商户自行承担因此而产生的所有损失。

  2)如果调用alipay.fund.trans.toaccount.transfer掉单时,或返回结果code=20000时,或返回结果code=40004,

  sub_code= SYSTEM_ERROR时,请调用alipay.fund.trans.order.query发起查询,如果未查询到结果,

  请保持原请求不变再次请求alipay.fund.trans.toaccount.transfer接口。

  3)商户处理转账结果时,对于错误码的处理,只能使用sub_code作为后续处理的判断依据,

  不可使用sub_msg作为后续处理的判断依据。

参数解读:

  1.amount 转账金额,只支持2位小数,小数点前最大支持13位,金额必须大于等于0.1元。

  2.payer_show_name付款方姓名(最长支持100个英文/50个汉字)。显示在收款方的账单详情页。如果该字段不传

 则默认显示付款方的支付宝认证姓名或单位名称。

  3.payee_real_name收款方真实姓名(最长支持100个英文/50个汉字),如果本参数不为空,则会校验该账户在支付宝

 登记的实名是否与收款方真实姓名一致。

  4.remark转账备注(支持200个英文/100个汉字)。当付款方为企业账户,且转账金额达到(大于等于)50000元,

  remark不能为空。收款方可见,会展示在收款用户的收支详情中。

测试流程(声明:demo仅做参考使用):

  1.下载官方【服务端sdk】放到项目中,注意:官方sdk php环境要求php5.5以上

  2.看下方代码

    1)收款方账户类型为:ALIPAY_LOGONID

  

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
<?php
require_once 'AopSdk.php';
$aop = new AopClient ();
$aop->appId = '填写您的沙箱appid';
$aop->rsaPrivateKey = '填写您的私钥';
$aop->alipayrsaPublicKey='填写您的支付宝公钥';
$aop->apiVersion = '1.0';
$aop->signType = 'RSA2';
$aop->postCharset='utf-8';
$aop->format='json';
$date=date("YmdHis");
$arr=range(1000,9999);
shuffle($arr);
$request = new AlipayFundTransToaccountTransferRequest ();
//收款方账户类型为:ALIPAY_LOGONID:支付宝登录号,支持邮箱和手机号格式。
$request->setBizContent("{" .
    "\"out_biz_no\":\"".$date.$arr[0]."\"," .
    "\"payee_type\":\"ALIPAY_LOGONID\"," .
    "\"payee_account\":\"请填写您转账的账号\"," .
    "\"amount\":\"0.1\"," .
    "\"remark\":\"单笔转账测试\"" .
    "}");
$result = $aop->execute ($request);
var_dump($result);

2)收款方账户类型为:ALIPAY_USERID

    

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
<?php
require_once 'AopSdk.php';
$aop = new AopClient ();
$aop->appId = '填写您的appid';
$aop->rsaPrivateKey = '填写您的私钥';
$aop->alipayrsaPublicKey='填写您的支付宝公钥';
$aop->apiVersion = '1.0';
$aop->signType = 'RSA2';
$aop->postCharset='utf-8';
$aop->format='json';
$date=date("YmdHis");
$arr=range(1000,9999);
shuffle($arr);
$request = new AlipayFundTransToaccountTransferRequest ();
// 收款方账户类型为:ALIPAY_USERID:支付宝账号对应的支付宝唯一用户号。以2088开头的16位纯数字组成。
$request->setBizContent("{" .
        "\"out_biz_no\":\"".$date.$arr[0]."\"," .
        "\"payee_type\":\"ALIPAY_USERID\"," .
        "\"payee_account\":\"填写您要转账的2088\"," .
        "\"amount\":\"0.1\"," .
        "\"remark\":\"单笔转账测试\"" .
        "}");
$result = $aop->execute ($request);
var_dump($result);

3)alipay.fund.trans.order.query(查询转账订单接口)

    说明:商户可通过该接口查询转账订单的状态、支付时间等相关信息,主要应用于B2C转账订单查询的场景

    

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
<?php
/**
 * 2017-08-01
 * by 我是个导演
 * 欢迎访问支付宝论坛:https://openclub.alipay.com/index.php
 */
require_once 'AopSdk.php';
$aop = new AopClient ();
$aop->appId = '填写您的appid';
$aop->rsaPrivateKey = '填写您的私钥';
$aop->alipayrsaPublicKey='填写您的支付宝公钥';
$aop->apiVersion = '1.0';
$aop->signType = 'RSA2';
$aop->postCharset='utf-8';
$aop->format='json';
$request = new AlipayFundTransOrderQueryRequest ();
//商户转账唯一订单号: 和支付宝转账单据号不能同时为空。当和支付宝转账单据号同时提供时,将用支付宝转账单据号进行查询,忽略本参数。
$request->setBizContent("{" .
"\"out_biz_no\":\"填写商户转账唯一订单号\"," .
"\"order_id\":\"填写支付宝转账单据号\"" .
"}");
$result = $aop->execute ( $request);
var_dump($result);
05-11 10:57