tcgunel/omnipay-qnbfinansbank
最新稳定版本:v2.0.0
Composer 安装命令:
composer require tcgunel/omnipay-qnbfinansbank
包简介
Omnipay extension for QNB Finansbank
关键字:
README 文档
README
QNB Finansbank sanal pos gateway for the Omnipay PHP payment processing library
Omnipay is a framework agnostic, multi-gateway payment processing library for PHP. This package implements QNB Finansbank support for Omnipay.
Installation
composer require tcgunel/omnipay-qnbfinansbank
Available Methods
| Method | Description |
|---|---|
purchase() |
Direct (non-3D) sale or 3D Secure redirect |
completePurchase() |
Complete 3D Secure payment after bank callback |
void() |
Cancel/void a transaction |
refund() |
Refund a transaction (full or partial) |
Supported Features
| Feature | Supported |
|---|---|
| 3D Secure | Yes |
| Non-3D (direct) | Yes |
| Cancel (void) | Yes |
| Refund | Yes |
| BIN lookup | No |
| Installment query | No |
| Sale query | No |
Usage
Gateway Initialization
use Omnipay\Omnipay; $gateway = Omnipay::create('QnbFinansbank'); $gateway->setMerchantId('your_merchant_id'); $gateway->setMerchantUser('your_user_code'); $gateway->setMerchantPassword('your_user_password'); $gateway->setMerchantStorekey('your_store_key'); // Required for 3D Secure $gateway->setTestMode(true); // Use test endpoint
Non-3D Purchase (Direct Sale)
$response = $gateway->purchase([ 'amount' => '100.00', 'currency' => 'TRY', 'transactionId' => 'ORDER-12345', 'secure' => false, 'card' => [ 'number' => '4508034508034509', 'expiryMonth' => '12', 'expiryYear' => '2030', 'cvv' => '000', ], ])->send(); if ($response->isSuccessful()) { echo 'Transaction ID: ' . $response->getTransactionReference(); } else { echo 'Error: ' . $response->getMessage(); }
3D Secure Purchase
$response = $gateway->purchase([ 'amount' => '100.00', 'currency' => 'TRY', 'transactionId' => 'ORDER-12345', 'secure' => true, 'returnUrl' => 'https://yoursite.com/payment/success', 'cancelUrl' => 'https://yoursite.com/payment/fail', 'card' => [ 'number' => '4508034508034509', 'expiryMonth' => '12', 'expiryYear' => '2030', 'cvv' => '000', ], ])->send(); if ($response->isRedirect()) { $response->redirect(); // POSTs card data to the bank 3D Secure page }
Complete 3D Secure Purchase (Callback Handler)
After the bank posts back to your returnUrl:
$response = $gateway->completePurchase([])->send(); if ($response->isSuccessful()) { echo 'Payment confirmed! Transaction: ' . $response->getTransactionReference(); } else { echo 'Payment failed: ' . $response->getMessage(); }
The callback POST fields (ProcReturnCode, AuthCode, OrderId, ErrMsg) are read
directly from $_POST by the request internally.
Void (Cancel)
$response = $gateway->void([ 'orderNumber' => 'ORDER-12345', 'currency' => 'TRY', ])->send(); if ($response->isSuccessful()) { echo 'Transaction voided.'; } else { echo 'Error: ' . $response->getMessage(); }
Refund
$response = $gateway->refund([ 'orderNumber' => 'ORDER-12345', 'amount' => '50.00', 'currency' => 'TRY', ])->send(); if ($response->isSuccessful()) { echo 'Refund processed.'; } else { echo 'Error: ' . $response->getMessage(); }
Hash Algorithm (3D Secure)
SHA1Base64(MbrId + OrderId + PurchAmount + OkUrl + FailUrl + TxnType + InstallmentCount + Rnd + MerchantPass)
Note: MbrId is always 5 for QNB Finansbank.
Endpoints
| Environment | URL |
|---|---|
| Test | https://vpostest.qnbfinansbank.com/Gateway/Default.aspx |
| Production | https://vpos.qnbfinansbank.com/Gateway/Default.aspx |
Key Differences from Denizbank
- Uses
MbrId: 5field in all requests - Uses
ErrMsginstead ofErrorMessagefor error messages - Different endpoint URLs (qnbfinansbank.com vs inter-vpos.com.tr)
Running Tests
composer test
Static Analysis
composer analyse
Code Style
composer lint
License
MIT License. See LICENSE for details.
统计信息
- 总下载量: 2
- 月度下载量: 0
- 日度下载量: 0
- 收藏数: 0
- 点击次数: 4
- 依赖项目数: 0
- 推荐数: 0
其他信息
- 授权协议: MIT
- 更新时间: 2026-03-23