webazain/laravel-payment

一个连接到所有伊朗支付网关的Laravel包

v1.0.1 2022-05-31 05:33 UTC

This package is auto-updated.

Last update: 2024-09-29 05:50:09 UTC


README

连接所有伊朗IPG和银行的包。

本包与Laravel版本(4、5、6)兼容。

仅支持以下支付网关

  1. MELLAT
  2. SADAD (MELLI)
  3. SAMAN
  4. PARSIAN
  5. PASARGAD
  6. ZARINPAL
  7. PAYPAL
  8. ASAN PARDAKHT
  9. PAI.R (使用'payir'调用)
  10. Irankish ( - 使用'irankish'调用)

安装:

按照以下步骤进行安装:

步骤 1)

composer require webazin/laravel-payment

步骤 2)

تغییرات زیر را در فایل  config/app.php اعمال نمایید:

注意:对于Laravel 6以后的版本,此步骤不需要执行

'providers' => [
  ...
  Webazin\LaravelPayment\GatewayServiceProvider::class, // <-- add this line at the end of provider array
],


'aliases' => [
  ...
  'Gateway' => Webazin\LaravelPayment\Gateway::class, // <-- add this line at the end of aliases array
]

步骤 3) - 转移必要文件

对于Laravel 5

php artisan vendor:publish --provider=Webazin\LaravelPayment\GatewayServiceProviderLaravel5
对于Laravel 6以后的版本
php artisan vendor:publish 

// then choose : GatewayServiceProviderLaravel6

步骤 4) - 创建表

php artisan migrate

步骤 5)

安装操作完成。现在打开app/目录下的gateway.php文件,并输入您所需银行网关的设置。

现在,您可以从以下方法中选择一种来连接到银行API。

  1. Gateway::make(new Mellat())
  2. Gateway::make('mellat')
  3. Gateway::mellat()
  4. app('gateway')->make(new Mellat());
  5. app('gateway')->mellat();

例如:连接到银行MELLAT(请求令牌并将用户传输到银行网关)注意:price方法的值以里亚尔输入,相当于100泰铢。

创建一个GET类型的路由,路径为/bank/request,并在其中放置以下代码。

try {

   $gateway = \Gateway::make('mellat');

   $gateway->setCallback(url('/bank/response')); // You can also change the callback
   $gateway->price(1000)
           // setShipmentPrice(10) // optional - just for paypal
           // setProductName("My Product") // optional - just for paypal
           ->ready();

   $refId =  $gateway->refId(); // شماره ارجاع بانک
   $transID = $gateway->transactionId(); // شماره تراکنش

   // در اینجا
   //  شماره تراکنش  بانک را با توجه به نوع ساختار دیتابیس تان 
   //  در جداول مورد نیاز و بسته به نیاز سیستم تان
   // ذخیره کنید .

   return $gateway->redirect();

} catch (\Exception $e) {

   echo $e->getMessage();
}

然后创建一个POST类型的路由,路径为/bank/response,并在其中放置以下代码。

try { 

   $gateway = \Gateway::verify();
   $trackingCode = $gateway->trackingCode();
   $refId = $gateway->refId();
   $cardNumber = $gateway->cardNumber();

   // تراکنش با موفقیت سمت بانک تایید گردید
   // در این مرحله عملیات خرید کاربر را تکمیل میکنیم

} catch (\Webazin\LaravelPayment\Exceptions\RetryException $e) {

    // تراکنش قبلا سمت بانک تاییده شده است و
    // کاربر احتمالا صفحه را مجددا رفرش کرده است
    // لذا تنها فاکتور خرید قبل را مجدد به کاربر نمایش میدهیم

    echo $e->getMessage() . "<br>";

} catch (\Exception $e) {

    // نمایش خطای بانک
    echo $e->getMessage();
}

如果您愿意参与开发

  1. 开发包文档。
  2. 报告错误。
  3. 为该包编写其他银行模块。

如果有任何错误问题,请通知我们。