前言

因为好多银行的支付SDK实例都是java的比较多,所以银行的支付用PHP比较难做,尤其是工商银行的支付更加是步步是坑。头一次对接工商银行,弄了好久,终于成功。这篇博客只是我做工行的聚合支付时,遇到的一些问题以及解决方法。

商户接入聚合支付前准备工作

1、熟悉支付的操作流程,详细阅读相关的文档。

2、准备相关的参数,工行聚合支付主要有两个接口,一个是支付接口,另一个是异步商户通知接口。支付接口除了文档上的要传的必要参数,主要的参数有银行提供的appid和商户id mer_id。自行下载java SDK生成app私钥和app公钥以及加密参数的AES密钥AES_KEY,文档中自行下载网关公钥。

3、工行的接口地址:https://open.icbc.com.cn/icbc/apip/api_list.html

找到收单服务中的聚合支付。

4、确保银行提供的参数正确,以及开通了相关接口。

应用场景

公众号或者生活号上选择商品支付完成(微信支付或者支付宝支付)后,款额流入银行开通好的工行卡。完成收单。

国内聚合支付javaapi 聚合支付 api_聚合支付

国内聚合支付javaapi 聚合支付 api_聚合支付_02

开发流程

调用sdk中的类,传递参数生成form,银行sdk内部实现调用银行接口判断参数是否正确,正确的话跳转微信支付页,弹出支付密码框。

开发实例

include_once ('icbc.UiIcbcClient');
date_default_timezone_set(\IcbcConstants::$DATE_TIMEZONE);
$msg_id = 'aa' . rand(10000000, 999999999);
$content = array(
    "interface_version" => "1.0.0.1",
    "mer_id" => config::get('sdkparam.icbc')['mer_id'],
    "tp_app_id" => 'gh_594087ba8d2b',
    "tp_open_id" => session('openId'),
    "out_trade_no" => $out_trade_no,
    "tran_type" => "OfflinePay",
    "order_date" => date("YmdHis", $_SERVER['REQUEST_TIME']),
    "end_time" => date("YmdHis", $_SERVER['REQUEST_TIME'] + 300),  // order_date之后5分钟
    "goods_body" => $goods_body,
    "goods_detail" => "{'good_name':$goods_name,'good_id':$good_id,'good_num':'1'}",
    "order_amount" => bcmul($recharge_amount, 100), //总金额(单位分)
    "spbill_create_ip" => $_SERVER['REMOTE_ADDR'],
    "install_times" => "1",
    "return_url" => "http://jdhc.linkunst.com/index/pay/successful", // 支付回显
    "notify_url" => "http://jdhc.linkunst.com/index/pay/notify", // 支付结果通知
    "notify_type" => "HS",
    "result_type" => "0",
    "type_meter" => $recharge_type,
);
$json_content = json_encode($content);
$request = array(
    "serviceUrl" => 'https://gw.open.icbc.com.cn/ui/aggregate/payment/request/V2',
    "method" => 'POST',
    "isNeedEncrypt" => true,
    "extraParams" => null,
    "biz_content" => $json_content,
);

$client = new \UiIcbcClient(Config::get('sdkparam.icbc')['app_id'],
    Config::get('sdkparam.icbc')['private_key'],
    \IcbcConstants::$SIGN_TYPE_RSA2,
    'UTF-8',
    'json',
    '',
    Config::get('sdkparam.icbc')['encrypt_key'],
    'AES',
    '',
    '');
$resp = $client->buildPostForm($request, $msg_id, '');
echo $resp;

避坑指南

1、sdk中DefaultIcbcClient.php参数补全,根据提示自行补全。(缺少CA密码$this->password)

2、常量配置类中时区改成Asia/Shanghai,不然后续支付的时候会提示参数错误。

国内聚合支付javaapi 聚合支付 api_bc_03

3、UI界面调用UI接口,即https://gw.open.icbc.com.cn/ui/aggregate/payment/request/V2,如果调用https://gw.open.icbc.com.cn/api/aggregate/payment/request/V2会报http 307

4、确保配置的参数完全正确,详细阅读接口文档。