phpcorelab/payment-gateways 问题修复 & 功能扩展

解决BUG、新增功能、兼容多环境部署,快速响应你的开发需求

邮箱:yvsm@zunyunkeji.com | QQ:316430983 | 微信:yvsm316

phpcorelab/payment-gateways

最新稳定版本:1.0.1

Composer 安装命令:

composer require phpcorelab/payment-gateways

包简介

Provider-agnostic PHP payment gateway library. Unified API for Razorpay, PhonePe, PayU, Paytm and Juspay.

README 文档

README

Latest Version PHP Version License

Provider-agnostic PHP payment gateway library. Unified API for Razorpay, PhonePe, PayU, Paytm and Juspay. Switch providers with a single config change — no code changes required.

Installation

composer require phpcorelab/payment-gateways

Requires PHP 8.1+.

Supported Providers

Provider Create Order Verify Payment Refund Webhook
Razorpay
PhonePe
PayU
Paytm 🚧 🚧 🚧 🚧
Juspay

How It Works

Frontend                    Backend                     Provider
   |                           |                            |
   |--- POST /payment/order --> |                            |
   |                           |--- createOrder() --------> |
   |                           |<-- OrderResult ----------- |
   |<-- { sdk_payload } -------|                            |
   |                           |                            |
   |--- [user pays via SDK] -------------------------------->|
   |<-- [provider sends back payment data] ----------------|
   |                           |                            |
   |--- POST /payment/confirm->|                            |
   |                           |--- verifyPayment() ------> |
   |                           |<-- PaymentResult --------- |
   |<-- { status: SUCCESS } ---|                            |

Quick Start

use PHPCoreLab\PaymentGateways\PaymentGateway;
use PHPCoreLab\PaymentGateways\Core\GatewayConfig;
use PHPCoreLab\PaymentGateways\DTOs\OrderPayload;
use PHPCoreLab\PaymentGateways\DTOs\PaymentStatus;

$gateway = new PaymentGateway(
    GatewayConfig::fromArray([
        'active_provider' => 'razorpay',  // change this to switch provider
        'environment'     => 'sandbox',   // 'sandbox' | 'live'
        'providers'       => [
            'razorpay' => [
                'sandbox_key_id'     => $_ENV['RAZORPAY_SANDBOX_KEY_ID'],
                'sandbox_key_secret' => $_ENV['RAZORPAY_SANDBOX_KEY_SECRET'],
                'live_key_id'        => $_ENV['RAZORPAY_LIVE_KEY_ID'],
                'live_key_secret'    => $_ENV['RAZORPAY_LIVE_KEY_SECRET'],
            ],
            // ... other providers
        ],
    ])
);

// Step 1 — Create order, get payload for frontend
$order = $gateway->createOrder(new OrderPayload(
    orderId:       'ORD-001',
    amountPaisa:   49900,       // INR 499.00 — always in paise
    customerName:  'Rahul Sharma',
    customerEmail: 'rahul@example.com',
    customerPhone: '9876543210',
    returnUrl:     'https://yourapp.com/payment/return',
    description:   'Order #ORD-001',
));

// Send to frontend:
// $order->sdkPayload  → for JS SDK providers (Razorpay)
// $order->paymentUrl  → for redirect-based providers (PhonePe, PayU)

// Step 2 — After frontend payment, verify it
$result = $gateway->verifyPayment('ORD-001', $request->all());

if ($result->status === PaymentStatus::Success) {
    // fulfil the order
}

// Refund
$refund = $gateway->refund($result->providerPaymentId, 49900);

// Handle webhook
$event = $gateway->handleWebhook(
    file_get_contents('php://input'),
    getallheaders()
);

Frontend Integration by Provider

Razorpay (JS SDK modal)

const options = JSON.parse(sdkPayload);
options.handler = function(response) {
    // POST response to /payment/confirm/:orderId
    fetch(`/payment/confirm/${orderId}`, {
        method: 'POST',
        body: JSON.stringify(response)
    });
};
const rzp = new Razorpay(options);
rzp.open();

PhonePe / PayU (redirect)

// Simply redirect the user to payment_url
window.location.href = paymentUrl;
// Provider redirects back to your return_url after payment

Juspay (SDK or redirect)

// Use client_auth_token from sdk_payload with Juspay Hypercheckout SDK
// or redirect to payment_url

Laravel Integration

AppServiceProvider

use PHPCoreLab\PaymentGateways\PaymentGateway;
use PHPCoreLab\PaymentGateways\Core\GatewayConfig;

$this->app->singleton(PaymentGateway::class, fn() =>
    new PaymentGateway(GatewayConfig::fromArray(config('payment-gateways')))
);

Routes

Route::middleware('auth:sanctum')->group(function () {
    Route::post('/payment/order',               [PaymentController::class, 'createOrder']);
    Route::post('/payment/confirm/{orderId}',   [PaymentController::class, 'confirmPayment']);
    Route::post('/payment/refund/{paymentId}',  [PaymentController::class, 'refund']);
});
Route::post('/payment/webhook',                 [PaymentController::class, 'webhook']);

DTOs Reference

Class Key Properties
OrderPayload orderId, amountPaisa, customerName, customerEmail, returnUrl
OrderResult orderId, providerOrderId, paymentUrl, sdkPayload
PaymentResult orderId, providerPaymentId, status, amountPaisa, providerRef
RefundResult refundId, success, message
PaymentEvent orderId, providerPaymentId, status, amountPaisa, providerRef

PaymentStatus enum: Pending · Success · Failed · Expired · Refunded · Cancelled

Exceptions

Exception When thrown
ProviderException HTTP / API call to provider fails
WebhookVerificationException Signature or checksum mismatch
ProviderNotFoundException Provider name not registered

All extend PaymentGatewayException extends RuntimeException.

Running Tests

composer install
composer test

License

MIT — PHPCoreLab

统计信息

  • 总下载量: 2
  • 月度下载量: 0
  • 日度下载量: 0
  • 收藏数: 0
  • 点击次数: 6
  • 依赖项目数: 0
  • 推荐数: 0

GitHub 信息

  • Stars: 0
  • Watchers: 0
  • Forks: 0
  • 开发语言: PHP

其他信息

  • 授权协议: MIT
  • 更新时间: 2026-03-16

承接程序开发

PHP开发

VUE

Vue开发

前端开发

小程序开发

公众号开发

系统定制

数据库设计

云部署

网站建设

安全加固