2025-02-16 22:40:30 +08:00
|
|
|
<?php
|
|
|
|
|
|
|
|
namespace App\Utils\API;
|
|
|
|
|
|
|
|
use GuzzleHttp\Client;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* 第三方api转账
|
|
|
|
*/
|
|
|
|
class Payment
|
|
|
|
{
|
2025-02-18 12:36:42 +08:00
|
|
|
public static function generate_encrypt_value($data, $secret_key) {
|
2025-02-18 11:08:46 +08:00
|
|
|
// 1. 过滤掉 EncryptValue 和值为 null 的参数
|
|
|
|
$filtered_data = array_filter($data, function($v, $k) {
|
|
|
|
return $k !== "EncryptValue" && $v !== null;
|
|
|
|
}, ARRAY_FILTER_USE_BOTH);
|
|
|
|
|
|
|
|
// 2. 按照 A~Z 顺序排序 key
|
|
|
|
ksort($filtered_data);
|
|
|
|
|
|
|
|
// 3. 拼接 key=value 形式的字符串,并加上 HashKey=密钥
|
|
|
|
$param_str = http_build_query($filtered_data) . "&HashKey=$secret_key";
|
|
|
|
|
|
|
|
// 4. 转换为小写
|
|
|
|
$param_str = strtolower($param_str);
|
|
|
|
|
|
|
|
// 5. 计算 sha256 哈希
|
|
|
|
$hash_value = hash('sha256', $param_str);
|
|
|
|
|
|
|
|
// 6. 转换为大写返回
|
|
|
|
return strtoupper($hash_value);
|
|
|
|
}
|
2025-02-16 22:40:30 +08:00
|
|
|
/**
|
|
|
|
* 转账
|
|
|
|
*/
|
|
|
|
public static function pushMoney($money,$payeeAccountName,$payeeAccountNumber,$payeeBankName)
|
|
|
|
{
|
2025-02-18 11:08:46 +08:00
|
|
|
$secret_key = "sZ2wAfh1lMkxBVrlY4uZY8Fj92E4scFf";
|
|
|
|
$url = "https://mdf.hr5688.com/api/createPaymentOrder";
|
|
|
|
$headers = [
|
|
|
|
"accept" => "application/json",
|
|
|
|
"content-type" => "application/json"
|
|
|
|
];
|
2025-02-16 22:40:30 +08:00
|
|
|
// 请求数据
|
2025-02-18 11:08:46 +08:00
|
|
|
$payload = [
|
2025-02-16 22:40:30 +08:00
|
|
|
"Amount" => $money,
|
|
|
|
"CurrencyId" => 11,
|
|
|
|
"IsTest" => false,
|
|
|
|
"PayeeAccountName" => $payeeAccountName,
|
|
|
|
"PayeeAccountNumber" => $payeeAccountNumber,
|
|
|
|
"PayeeBankName" => $payeeBankName,
|
|
|
|
"PayeeIFSCCode" => "abc123",
|
|
|
|
"PaymentChannelId" => 34,
|
2025-02-18 11:15:14 +08:00
|
|
|
"ShopInformUrl" => "http://127.0.0.1/api/withdraw/getMoney",
|
2025-02-16 22:40:30 +08:00
|
|
|
"ShopOrderId" => "10",
|
|
|
|
"ShopRemark" => "", // 留空时可不给此参数
|
|
|
|
"ShopUserLongId" => "776ae472-d4fc-435c-9639-be5763138d95"
|
|
|
|
];
|
2025-02-18 11:08:46 +08:00
|
|
|
$secret_key = "sZ2wAfh1lMkxBVrlY4uZY8Fj92E4scFf";
|
2025-02-18 12:36:42 +08:00
|
|
|
$encrypt_value = self::generate_encrypt_value($payload, $secret_key);
|
2025-02-18 11:08:46 +08:00
|
|
|
$payload["EncryptValue"] = $encrypt_value;
|
|
|
|
|
|
|
|
$json_payload = json_encode($payload);
|
|
|
|
|
|
|
|
$ch = curl_init();
|
|
|
|
curl_setopt($ch, CURLOPT_URL, $url);
|
|
|
|
curl_setopt($ch, CURLOPT_POST, true);
|
|
|
|
curl_setopt($ch, CURLOPT_POSTFIELDS, $json_payload);
|
|
|
|
curl_setopt($ch, CURLOPT_HTTPHEADER, $headers);
|
|
|
|
curl_setopt($ch, CURLOPT_RETURNTRANSFER, true);
|
2025-02-16 22:40:30 +08:00
|
|
|
|
2025-02-18 11:08:46 +08:00
|
|
|
$response = curl_exec($ch);
|
|
|
|
$http_code = curl_getinfo($ch, CURLINFO_HTTP_CODE);
|
2025-02-16 22:40:30 +08:00
|
|
|
|
2025-02-18 11:08:46 +08:00
|
|
|
if ($http_code == 200) {
|
|
|
|
echo $response;
|
|
|
|
} else {
|
|
|
|
echo "Error: HTTP Code $http_code\n";
|
|
|
|
echo $response;
|
|
|
|
}
|
|
|
|
curl_close($ch);
|
|
|
|
return $response;
|
2025-02-16 22:40:30 +08:00
|
|
|
}
|
|
|
|
}
|