248 lines
7.8 KiB
PHP
Raw Normal View History

2025-10-17 16:32:16 +08:00
<?php
/**
* 建行生活对接配置文件
*
* 重要说明:
* - 建行只提供生产环境,没有测试环境
* - 配置优先从.env读取,如果没有则使用默认值
* - 请在.env文件中配置敏感信息(密钥等)
*
* @author Billy
* @date 2025-01-16
*/
use think\Env;
2025-10-20 10:37:59 +08:00
// 读取 .env 文件以获取密钥配置
$envFile = __DIR__ . '/../../../.env';
$envVars = [];
if (file_exists($envFile)) {
$envVars = parse_ini_file($envFile);
}
2025-10-17 16:32:16 +08:00
return [
// API基础地址 (生产环境)
2025-10-21 15:03:39 +08:00
'api_base_url' => 'https://yunbusiness.ccb.com/tp_service/txCtrl/server',
2025-10-17 16:32:16 +08:00
// 交易代码映射
'tx_codes' => [
2025-10-18 15:47:25 +08:00
'order_push' => 'A3341TP01', // 订单推送
'order_update' => 'A3341TP02', // 订单状态更新
'order_query' => 'A3341TP03', // 订单查询
'order_refund' => 'A3341TP04', // 订单退款
2025-10-17 16:32:16 +08:00
],
2025-10-17 17:18:15 +08:00
// 服务方信息(生产环境)
'service_id' => Env::get('ccb.service_id', 'YS44000009001853'),
2025-10-17 16:32:16 +08:00
2025-10-17 17:18:15 +08:00
// 商户信息(从.env读取)
2025-10-17 16:32:16 +08:00
'merchant_id' => Env::get('ccb.merchant_id', '105003953998037'),
'pos_id' => Env::get('ccb.pos_id', '068295530'),
'branch_id' => Env::get('ccb.branch_id', '340650000'),
2025-10-20 15:29:15 +08:00
// ========== 密钥配置 (从.env读取) ==========
/**
* 服务方私钥 (自己生成的RSA私钥)
* 用途:
2025-10-21 20:48:28 +08:00
* - API请求签名MD5(明文 + 私钥)
2025-10-20 15:29:15 +08:00
* - 解密建行返回的加密数据(ccbParamSJ等)
* 格式: BASE64格式(不含PEM头尾) PEM格式(含头尾)
*/
2025-10-20 10:37:59 +08:00
'private_key' => $envVars['private_key'] ?? '',
2025-10-20 15:29:15 +08:00
/**
* 服务方公钥 (自己生成的RSA公钥,对应上面的私钥)
* 用途:
2025-10-21 20:48:28 +08:00
* - 加密API请求报文建行用相同的公钥解密
* - 支付下单的MD5签名计算(PLATFORMPUB字段)
2025-10-20 15:29:15 +08:00
* - 加密商户公钥(ENCPUB字段)
* 格式: BASE64格式(不含PEM头尾) PEM格式(含头尾)
*/
2025-10-20 10:37:59 +08:00
'public_key' => $envVars['public_key'] ?? '',
2025-10-20 15:29:15 +08:00
/**
* 建行生活支付验签公钥 (建行生活平台分配的)
* 用途:
* - 验证异步通知中的SIGN字段(NT_TYPE=YS时)
* 获取方式: 联系建行生活平台运营人员或技术支持
* 格式: PEM格式RSA公钥(2048)
*
* 📌 如果未配置此字段:
* - 异步通知验签会降级为POSID验证
* - 安全性降低,建议尽快获取并配置
*/
'ccb_payment_verify_public_key' => $envVars['ccb_payment_verify_public_key'] ?? '',
2025-10-17 16:32:16 +08:00
// HTTP请求配置
'http' => [
'timeout' => 30, // 超时时间(秒)
'retry_times' => 3, // 重试次数
'retry_delay' => [1, 2, 5], // 重试间隔(秒)
],
// 支付配置
'payment' => [
'currency_code' => '01', // 币种: 01-人民币
'tx_code' => '520100', // 支付交易码
'third_app_info' => 'comccbpay1234567890cloudmerchant',
'timeout_minutes' => 30, // 支付超时时间(分钟)
],
2025-10-21 14:33:20 +08:00
// ========== 可选支付参数配置 ==========
// 以下参数按需配置,不配置则不会添加到支付串中
/**
* 外部平台商户号 (与建行商户号二选一)
* 说明: 使用外部平台商户号时,会自动移除MERCHANTID、POSID、BRANCHID
*/
'plat_mct_id' => Env::get('ccb.plat_mct_id', ''),
/**
* 微信支付19位终端号
* 说明: 微信支付场景下使用
*/
'pos_id_19' => Env::get('ccb.pos_id_19', ''),
/**
* 支付位图 - 控制支付方式
* 格式: 6位字符串,每位对应一个支付方式(1=开启,0=关闭)
* 位置: [生活钱包][龙支付][微信][数字人民币][信用付][快贷]
* 示例: '111111' = 全部开启, '110000' = 仅生活钱包和龙支付
*/
'pay_bitmap' => Env::get('ccb.pay_bitmap', '110000'),
/**
* 账户位图 - 控制支付账户类型
* 格式: 5位字符串,每位对应一个账户类型(1=开启,0=关闭)
* 位置: [建行借记卡][建行贷记卡][他行借记卡][他行贷记卡][建行钱包]
* 示例: '11111' = 全部开启, '11000' = 仅建行卡
*/
'account_bitmap' => Env::get('ccb.account_bitmap', '11000'),
/**
* 分期付款期数
* 说明: 分期支付场景下使用
*/
'install_num' => Env::get('ccb.install_num', ''),
/**
* 积分二级活动编号
* 说明: 积分抵扣场景下使用
*/
'point_avy_id' => Env::get('ccb.point_avy_id', ''),
/**
* 固定抵扣积分值
* 说明: 固定积分抵扣场景下使用
*/
'fixed_point_val' => Env::get('ccb.fixed_point_val', ''),
/**
* 最小使用积分抵扣限制
* 说明: 积分抵扣最小值限制
*/
'min_point_limit' => Env::get('ccb.min_point_limit', ''),
/**
* 有价券活动编号
* 说明: 优惠券活动场景下使用
*/
'coupon_avy_id' => Env::get('ccb.coupon_avy_id', ''),
/**
* 限制信用卡支付标志
* 说明: 1=仅限信用卡支付
*/
'only_credit_pay_flag' => Env::get('ccb.only_credit_pay_flag', ''),
/**
* 扩展域参数
* 格式: JSON字符串(配置时无需urlencode,代码会自动处理)
* 示例: '{"key1":"value1","key2":"value2"}'
*/
'extend_params' => Env::get('ccb.extend_params', ''),
// ========== 数字人民币(DCEP)配置 ==========
/**
* 数字人民币商户类型
* 1=融合商户(使用普通商户号)
* 2=非融合商户(需单独配置数币商户号)
*/
'dcep_mct_type' => Env::get('ccb.dcep_mct_type', ''),
/**
* 数字人民币商户号 (dcep_mct_type=2时必填)
*/
'dcep_merchant_id' => Env::get('ccb.dcep_merchant_id', ''),
/**
* 数字人民币柜台号 (dcep_mct_type=2时必填)
*/
'dcep_pos_id' => Env::get('ccb.dcep_pos_id', ''),
/**
* 数字人民币分行号 (dcep_mct_type=2时必填)
*/
'dcep_branch_id' => Env::get('ccb.dcep_branch_id', ''),
/**
* 数字人民币存款账号
*/
'dcep_dep_acc_no' => Env::get('ccb.dcep_dep_acc_no', ''),
// ========== 二级商户配置(平台类服务方使用) ==========
/**
* 二级商户编号
* 说明: 平台型服务方为下级商户收款时使用
*/
'sub_mct_id' => Env::get('ccb.sub_mct_id', ''),
/**
* 二级商户名称
*/
'sub_mct_name' => Env::get('ccb.sub_mct_name', ''),
/**
* 二级商户MCC码
* 说明: 商户类别码,标识商户行业类型
*/
'sub_mct_mcc' => Env::get('ccb.sub_mct_mcc', ''),
// ========== 场景编号配置(埋点使用,不参与MAC签名) ==========
/**
* 场景编号
* 说明: 用于数据埋点分析,不参与MAC校验
*/
'scn_id' => Env::get('ccb.scn_id', ''),
/**
* 场景平台编号
* 说明: 用于数据埋点分析,不参与MAC校验
*/
'scn_pltfrm_id' => Env::get('ccb.scn_pltfrm_id', ''),
2025-10-17 16:32:16 +08:00
// 日志配置
'log' => [
'enabled' => true,
'level' => Env::get('ccb.log_level', 'info'), // debug, info, warning, error
2025-10-18 15:47:25 +08:00
'path' => __DIR__ . '/../../../runtime/log/ccblife/',
2025-10-17 16:32:16 +08:00
],
// 安全配置
'security' => [
'encrypt_enabled' => true, // 是否启用加密
'sign_enabled' => true, // 是否启用签名
'verify_sign' => true, // 是否验证响应签名
],
// 商户信息
'merchant' => [
2025-10-21 11:11:59 +08:00
'name' => Env::get('ccb.merchant_name', '丰科贸易(荷西嘉园店)'),
2025-10-17 16:32:16 +08:00
'logo_url' => Env::get('ccb.merchant_logo', ''),
'order_detail_url' => Env::get('app_url', 'http://fengketrade.test') . '/pages/order/detail?id=',
],
];