前言
因为好多银行的支付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、确保银行提供的参数正确,以及开通了相关接口。
应用场景
公众号或者生活号上选择商品支付完成(微信支付或者支付宝支付)后,款额流入银行开通好的工行卡。完成收单。
开发流程
调用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,不然后续支付的时候会提示参数错误。
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、确保配置的参数完全正确,详细阅读接口文档。
5、弹出支付框后,在公众号内部支付,点击支付没有反应,而在微信聊天框中访问支付地址却可以支付。需要在微信公众号开通微信支付。