Skip to content

微信支付

请仔细阅读并理解:微信官方文档 - 微信支付

NOTE

2024 年 Q3,微信支付官方开启了「平台公钥」平替「平台证书」方案,初始化所需的参数仅需配置上 平台公钥 ID平台公钥 即完全兼容支持,CLI/API 下载 平台证书 已不是一个必要步骤,可略过。 平台公钥 ID平台公钥 均可在 微信支付商户平台 -> 账户中心 -> API 安全 查看及/或下载。

实例化

php
<?php
use EasyWeChat\Pay\Application;

$config = [
    'mch_id' => 1360649000,

    // 商户证书
    'private_key' => __DIR__ . '/certs/apiclient_key.pem',
    'certificate' => __DIR__ . '/certs/apiclient_cert.pem',

     // v3 API 秘钥
    'secret_key' => '43A03299A3C3FED3D8CE7B820Fxxxxx',

    // v2 API 秘钥
    'v2_secret_key' => '26db3e15cfedb44abfbb5fe94fxxxxx',

    // 平台证书:微信支付 APIv3 平台证书,需要使用工具下载
    // 下载工具:https://github.com/wechatpay-apiv3/CertificateDownloader
    'platform_certs' => [
        // 如果是「平台证书」模式
        //    可简写使用平台证书文件绝对路径
        // '/path/to/wechatpay/cert.pem',

        // 如果是「平台公钥」模式
        //    使用Key/Value结构, key为平台公钥ID,value为平台公钥文件绝对路径
        // "{$pubKeyId}" => '/path/to/wechatpay/pubkey.pem',
    ],

    /**
     * 接口请求相关配置,超时时间等,具体可用参数请参考:
     * https://github.com/symfony/symfony/blob/5.3/src/Symfony/Contracts/HttpClient/HttpClientInterface.php
     */
    'http' => [
        'throw'  => true, // 状态码非 200、300 时是否抛出异常,默认为开启
        'timeout' => 5.0,
        // 如果你在国外想要覆盖默认的 url 的时候才使用,根据不同的模块配置不同的 base_uri
        // 'base_uri' => 'https://api.mch.weixin.qq.com/',
    ],
];

$app = new Application($config);

API

Application 就是一个工厂类,所有的模块都是从 $app 中访问,并且几乎都提供了协议和 setter 可自定义修改。

API Client

封装了多种模式的 API 调用类,你可以选择自己喜欢的方式调用开放平台任意 API,默认自动处理了 access_token 相关的逻辑。

php
$app->getClient();

📖 更多说明请参阅:API 调用

工具

为了方便开发者生成各种调起支付所需配置,你可以使用工具类:

php
$app->getUtils();

📖 更多说明请参阅:工具

配置

php
$config = $app->getConfig();

你可以轻松使用 $config->get($key, $default) 读取配置,或使用 $config->set($key, $value) 在调用前修改配置项。

支付账户

支付账户类,提供一系列 API 获取支付的基本信息:

php
$account = $app->getMerchant();

$account->getMerchantId();
$account->getPrivateKey();
$account->getCertificate();
$account->getSecretKey();
$account->getV2SecretKey();
$account->getPlatformCert($serial);
$account->getPlatformCerts();

一些可能会用到的

签名验证

按官方说法,建议在拿到微信接口响应接收到微信支付的回调通知时,对通知的签名进行验证,以确保通知是微信支付发送的。

你可以通过以下方式获取签名验证器:

php
$app->getValidator();
推送消息的签名验证
php
$server = $app->getServer();

$server->handlePaid(function (Message $message, \Closure $next) use ($app) {
    // $message->out_trade_no 获取商户订单号
    // $message->payer['openid'] 获取支付者 openid

    try{
        $app->getValidator()->validate($app->getRequest());
       // 验证通过,业务处理
    } catch(Exception $e){
      // 验证失败
    }

    return $next($message);
});

// 默认返回 ['code' => 'SUCCESS', 'message' => '成功']
return $server->serve();
API 返回值的签名验证
php
// API 请求示例
$response = $app->getClient()->postJson("v3/pay/transactions/jsapi", [...]);

try{
    $app->getValidator()->validate($response->toPsrResponse());
   // 验证通过
} catch(Exception $e){
  // 验证失败
}

获取证书序列号

bash
openssl x509 -in /path/to/merchant/apiclient_cert.pem -noout -serial | awk -F= '{print $2}'

Released under the MIT License.