vinhkosd/omnipay-vnpay

支持集成VNPay支付网关的库。

1.0.2 2020-07-09 10:18 UTC

This package is not auto-updated.

Last update: 2024-09-25 17:38:35 UTC


README

Omnipay: VNPay


Latest version Build status Quantity score StyleCI Total download License

信息

支持集成VNPay支付网关的库,基于Omnipay League平台开发。

了解Omnipay网关的概念和使用方法,请访问这里进行查阅。

安装

通过Composer安装Omnipay VNPay。

composer require vinhkosd/omnipay-vnpay

使用方法

集成到当前流行的各种框架中

或者如果您想在不使用框架的情况下使用,请继续阅读。

初始化网关

use Omnipay\Omnipay;

$gateway = Omnipay::create('VNPay');
$gateway->initialize([
    'vnp_TmnCode' => 'Do VNPay cấp',
    'vnp_HashSecret' => 'Do VNPay cấp',
]);

上面的网关用于向VNPay发送请求或接收VNPay发送的请求。

创建支付请求

$response = $gateway->purchase([
    'vnp_TxnRef' => time(),
    'vnp_OrderType' => 100000,
    'vnp_OrderInfo' => time(),
    'vnp_IpAddr' => '127.0.0.1',
    'vnp_Amount' => 1000000,
    'vnp_ReturnUrl' => 'https://github.com/phpviet',
])->send();

if ($response->isRedirect()) {
    $redirectUrl = $response->getRedirectUrl();
    
    // TODO: chuyển khách sang trang VNPay để thanh toán
}

有关创建请求和VNPay返回的参数的详细信息,请参阅这里

检查当客户被VNPay重定向回时返回的 vnp_ReturnUrl 信息

$response = $gateway->completePurchase()->send();

if ($response->isSuccessful()) {
    // TODO: xử lý kết quả và hiển thị.
    print $response->vnp_Amount;
    print $response->vnp_TxnRef;
    
    var_dump($response->getData()); // toàn bộ data do VNPay gửi sang.
    
} else {

    print $response->getMessage();
}

有关VNPay返回的参数的详细信息,请参阅这里

检查VNPay发送的 IPN 信息

$response = $gateway->notification()->send();

if ($response->isSuccessful()) {
    // TODO: xử lý kết quả.
    print $response->vnp_Amount;
    print $response->vnp_TxnRef;
    
    var_dump($response->getData()); // toàn bộ data do VNPay gửi sang.
    
} else {

    print $response->getMessage();
}

有关VNPay发送的参数的详细信息,请参阅这里

检查交易状态

$response = $gateway->queryTransaction([
    'vnp_TransDate' => 20190705151126,
    'vnp_TxnRef' => 1562314234,
    'vnp_OrderInfo' => time(),
    'vnp_IpAddr' => '127.0.0.1',
    'vnp_TransactionNo' => 496558,
])->send();

if ($response->isSuccessful()) {
    // TODO: xử lý kết quả và hiển thị.
    print $response->getTransactionId();
    print $response->getTransactionReference();
    
    var_dump($response->getData()); // toàn bộ data do VNPay gửi về.
    
} else {

    print $response->getMessage();
}

有关创建请求和VNPay返回的参数的详细信息,请参阅这里

退款请求

$response = $gateway->refund([
    'vnp_Amount' => 10000,
    'vnp_TransactionType' => '03',
    'vnp_TransDate' => 20190705151126,
    'vnp_TxnRef' => 32321,
    'vnp_OrderInfo' => time(),
    'vnp_IpAddr' => '127.0.0.1',
    'vnp_TransactionNo' => 496558,
])->send();

if ($response->isSuccessful()) {
    // TODO: xử lý kết quả và hiển thị.
    print $response->getTransactionId();
    print $response->getTransactionReference();
    
    var_dump($response->getData()); // toàn bộ data do VNPay gửi về.
    
} else {

    print $response->getMessage();
}

有关创建请求和VNPay返回的参数的详细信息,请参阅这里

针对开发者

如果您觉得我们的库还有不足或错误,并想共同开发,我们非常欢迎!请创建 issue 以提出下一个版本的想法,或者创建 PR 以补充不足或错误。对于与安全相关的问题,请通过 vuongxuongminh@gmail.com 发送电子邮件,而不是创建 issue。感谢!