承接 andrewnovikof/omnipay-sberbank 相关项目开发

从需求分析到上线部署,全程专人跟进,保证项目质量与交付效率

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

andrewnovikof/omnipay-sberbank

最新稳定版本:3.4.0

Composer 安装命令:

composer require andrewnovikof/omnipay-sberbank

包简介

Omnipay driver for Sberbank

README 文档

README

Build Status Latest Stable Version Total Downloads License

Introduction

This library implements the work with Sberbank acquiring api via theleague Omnipay processing library for PHP. It has a clear and consistent API, is fully unit tested.

The package release 3.2.2 version supports PHP 7.1 and higher and omnipay/common v3.0.3 The package release 3.3.0 version supports PHP 8.0 and higher and omnipay/common v3.2

Download

Composer

// This assumes that you have composer installed globally composer require andrewnovikof/omnipay-sberbank 

Solving problems with minimal stability

Add to your composer.json

{ "minimum-stability":"dev", "prefer-stable": true } 

Simple Example

use Omnipay\Omnipay; // Setup payment gateway $gateway = Omnipay::create('Sberbank'); // Set params for authorize request $gateway->authorize( [ 'orderNumber' => $localOrderNumber, // local order number 'amount' => $order_amount, // The amount of payment (you can use decimal with 2 precisions for copecs or string equal to decimal) 'returnUrl' => $callback_url // succesfull callback url ] ); // Enable test mode $gateway->setTestMode(true); // You can set parameters via setters, for example: $gateway->setUserName('merchant_login') ->setPassword('merchant_password') ->setOrderNumber($localOrderNumber) ->setLanguage('en'); // Send request $response = $gateway->send(); // Process response if ($response->isSuccessful()) { // Payment was successful print_r($response); // Get gateway orderId $gatewayOrderId = $response->getOrderId(); // Get manualy get redirect url to offsite payment gateway $offsiteGateway = $response->getRedirectUrl(); } else { // Payment failed echo $response->getMessage(); } // Work with redirect if ($response->isRedirect()) { // Redirect to offsite payment gateway $response->redirect(); } 

Payment Methods

Order registration without pre-authorization

Order registration with pre-authorization

Order completion after pre-authorization

Orders status

Extended order status

Void order

Refund for an order payment

Verify the involvement of the map in 3DS

Statistics on payments for the period

Add a card to the list of SSL-cards

Order registration without pre-authorization

More about this request you'll see in Sberbank official documentation -> item 1 or in our source code

use Omnipay\Omnipay; $gateway = Omnipay::create('Sberbank'); $response = $gateway->authorize( [ 'orderNumber' => $localOrderNumber, // local order number 'amount' => $order_amount, // The amount of payment (you can use decimal with 2 precisions for copecs or string equal to decimal) 'returnUrl' => $callback_url, // succesfull callback url 'description' => 'Order Description' ] )->setUserName('merchant_login') ->setPassword('merchant_password') ->send(); // Process response if ($response->isSuccessful()) { // Payment was successful print_r($response); // Get gateway orderId $gatewayOrderId = $response->getOrderId(); // Get manualy get redirect url to offsite payment gateway $offsiteGateway = $response->getRedirectUrl(); } else { // Payment failed echo $response->getMessage(); } // Work with redirect if ($response->isRedirect()) { // Redirect to offsite payment gateway $response->redirect(); } 

Order registration with pre-authorization

More about this request you'll see in Sberbank official documentation -> item 1 or in our source code

use Omnipay\Omnipay; $gateway = Omnipay::create('Sberbank'); $response = $gateway->authorize( [ 'orderNumber' => $localOrderNumber, // local order number 'amount' => $order_amount, // The amount of payment (you can use decimal with 2 precisions for copecs or string equal to decimal) 'returnUrl' => $callback_url, // succesfull callback url 'description' => 'Order Description' ] )->setTwoStage(true) ->setUserName('merchant_login') ->setPassword('merchant_password') ->send(); // Process response if ($response->isSuccessful()) { // Payment was successful print_r($response); // Get gateway orderId $gatewayOrderId = $response->getOrderId(); // Get manualy get redirect url to offsite payment gateway $offsiteGateway = $response->getRedirectUrl(); } else { // Payment failed echo $response->getMessage(); } // Work with redirect if ($response->isRedirect()) { // Redirect to offsite payment gateway $response->redirect(); } 

Order completion after pre-authorization

More about this request you'll see in Sberbank official documentation -> item 2 or in our source code

use Omnipay\Omnipay; $gateway = Omnipay::create('Sberbank'); $response = $gateway->capture( [ 'orderId' => $localOrderNumber, // gateway order number 'amount' => $order_amount, // The amount of payment (you can use decimal with 2 precisions for copecs or string equal to decimal) ] )->setUserName('merchant_login') ->setPassword('merchant_password') ->send(); // Process response if ($response->isSuccessful()) { // Get response code $code = $response->getCode(); } else { // Payment failed echo $response->getMessage(); }

Orders status

More about this request you'll see in Sberbank official documentation -> item 5 or in our source code

This method work for completeAuthorize() and completePurchase() requests of Omnipay.

use Omnipay\Omnipay; $gateway = Omnipay::create('Sberbank'); $response = $gateway->orderStatus( // It will be similar to calling methods `completeAuthorize()` and `completePurchase()` [ 'orderId' => $localOrderNumber, // gateway order number 'language' => 'en' ] )->setUserName('merchant_login') ->setPassword('merchant_password') ->send(); // Process response if ($response->isSuccessful()) { // Get response code $code = $response->getCode(); // Get paid amount  $paid_amount = $response->getAmount(); // Get other data $order_status = $response->getOrderStatus(); $order_number = $response->getOrderNumber(); $order_pan = $response->getPan(); $order_expiration = $response->getExpiration(); $order_cardholder_name = $response->getCardHolderName(); $order_currency = $response->getCurrency(); $order_approval_code = $response->getApprovalCode(); $order_ip = $response->getIp(); $order_client_id = $response->getClientId(); $order_binding_id = $response->getBindingId(); } else { // Payment failed echo $response->getMessage(); }

Extended order status

More about this request you'll see in Sberbank official documentation -> item 6 or in our source code

use Omnipay\Omnipay; $gateway = Omnipay::create('Sberbank'); $response = $gateway->extendedOrderStatus( [ 'orderId' => $localOrderNumber, // gateway order number 'language' => 'en' ] )->setOrderNumber($localORderNumber) // You can set local orderNumber Instead of an orderId of gateway system ->setUserName('merchant_login') ->setPassword('merchant_password') ->send(); // Process response if ($response->isSuccessful()) { // Get response code $code = $response->getCode(); // Get paid amount  $paid_amount = $response->getAmount(); // Get other data $order_status = $response->getOrderStatus(); $order_number = $response->getOrderNumber(); $order_pan = $response->getPan(); $order_expiration = $response->getExpiration(); $order_cardholder_name = $response->getCardHolderName(); $order_currency = $response->getCurrency(); $order_approval_code = $response->getApprovalCode(); $order_ip = $response->getIp(); $order_client_id = $response->getClientId(); $order_binding_id = $response->getBindingId(); $order_merchant_order_params = $response->getMerchantOrderParams(); $order_eci = $response->getEci(); $order_cavv = $response->getCavv(); $order_xid = $response->getXid(); $order_auth_date_time = $response->getAuthDateTime(); $order_auth_ref_num = $response->getAuthRefNum(); $order_terminal_id = $response->getTerminalId(); $order_approved_amount = $response->getApprovedAmount(); $order_deposited_amount = $response->getDepositedAmount(); $order_refunded_amount = $response->getRefundedAmount(); $order_payment_state = $response->getPaymentState(); $order_bank_name = $response->getBankName(); $order_bank_country_code = $response->getBankCountryCode(); $order_band_country_name = $response->getBankCountryName(); } else { // Payment failed echo $response->getMessage(); }

Void order

More about this request you'll see in Sberbank official documentation -> item 3 or in our source code

To request cancellation of payment for an order, use the request reverse.do. The cancellation function is available for a limited time after payment, the exact terms should be specified in the Bank.

The cancellation operation can only be performed once. If it ends with an error, then the repeated cancellation operation will fail.

This function is available to stores in consultation with the Bank. To perform the cancellation operation, the user must have the appropriate rights.

use Omnipay\Omnipay; $gateway = Omnipay::create('Sberbank'); $response = $gateway->void( [ 'orderId' => $localOrderNumber, // gateway order number 'language' => 'en' ] )->setUserName('merchant_login') ->setPassword('merchant_password') ->send(); // Process response if ($response->isSuccessful()) { // Get response code $code = $response->getCode(); } else { // Payment failed echo $response->getMessage(); }

Refund for an order payment

More about this request you'll see in Sberbank official documentation -> item 4 or in our source code

For this request, the funds will be returned to the payer on the specified order. The request will end with an error if the funds for this order were not written off. The system allows you to return funds more than once, but in total no more than the original amount of write-off.

To perform a return operation, you must have the appropriate rights in the system.

use Omnipay\Omnipay; $gateway = Omnipay::create('Sberbank'); $response = $gateway->refund( [ 'orderId' => $localOrderNumber, // gateway order number 'language' => 'en', 'amount' => $oder_amount // // The amount of payment (you can use decimal with 2 precisions for copecs or string equal to decimal) ] )->setUserName('merchant_login') ->setPassword('merchant_password') ->send(); // Process response if ($response->isSuccessful()) { // Get response code $code = $response->getCode(); } else { // Payment failed echo $response->getMessage(); }

Verify the involvement of the map in 3DS

More about this request you'll see in Sberbank official documentation -> item 7 or in our source code

use Omnipay\Omnipay; $gateway = Omnipay::create('Sberbank'); $response = $gateway->verifyEnrollment( [ 'pan' => $cardPan ] )->setUserName('merchant_login') ->setPassword('merchant_password') ->send(); // Process response if ($response->isSuccessful()) { // Get response code $code = $response->getCode(); $emitter_country_name = $response->getEmitterName(); $emitter_country_code = $response->getEmitterCountryCode(); $enrolled = $response->getEnrolled(); } else { // Payment failed echo $response->getMessage(); }

Statistics on payments for the period

More about this request you'll see in Sberbank official documentation -> item 8 or in our source code

use Omnipay\Omnipay; $gateway = Omnipay::create('Sberbank'); $response = $gateway->getLastOrdersForMerchants( [ 'size' => $size, 'from' => $from, 'to' => $to, 'transactionStates' => $transactionStates, 'merchants' => $merchants ] )->setUserName('merchant_login') ->setPassword('merchant_password') ->send(); // Process response if ($response->isSuccessful()) { // Get response code $code = $response->getCode(); $total_count = $response->getTotalCount(); $page = $response->getPage(); $page_size = $response->getPageSize(); // Available getters $response->getOrderErrorCode($orderIndex); $response->getOrderNumber($orderIndex); $response->getOrderStatus($orderIndex); $response->getActionCode($orderIndex); $response->getActionCodeDescription($orderIndex); $response->getAmount($orderIndex); $response->getCurrency($orderIndex); $response->getDate($orderIndex); $response->getOrderDescription($orderIndex); $response->getIp($orderIndex); $response->getMerchantOrderParamName($orderIndex, $paramIndex); $response->getMerchantOrderParamValue($orderIndex, $paramIndex); $response->getAttributesName($orderIndex, $attributeIndex); $response->getAttributesValue($orderIndex, $attributeIndex); $response->getExpiration($orderIndex); $response->getCardholderName($orderIndex); $response->getApprovalCode($orderIndex); $response->getPan($orderIndex); $response->getClientId($orderIndex); $response->getBindingId($orderIndex); $response->getAuthDateTime($orderIndex); $response->getTerminalId($orderIndex); $response->getAuthRefNum($orderIndex); $response->getPaymentState($orderIndex); $response->getApprovedAmount($orderIndex); $response->getDepositedAmount($orderIndex); $response->getRefundedAmount($orderIndex); $response->getBankName($orderIndex); $response->getBankCountryName($orderIndex); $response->getBankCountryCode($orderIndex); } else { // Payment failed echo $response->getMessage(); }

Add a card to the list of SSL-cards

More about this request you'll see in Sberbank official documentation -> item 9 or in our source code

use Omnipay\Omnipay; $gateway = Omnipay::create('Sberbank'); $response = $gateway->verifyEnrollment( [ 'mdorder' => $mdorder ] )->setUserName('merchant_login') ->setPassword('merchant_password') ->send(); // Process response if ($response->isSuccessful()) { // Get response code $code = $response->getCode(); } else { // Payment failed echo $response->getMessage(); }

统计信息

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

GitHub 信息

  • Stars: 32
  • Watchers: 2
  • Forks: 16
  • 开发语言: PHP

其他信息

  • 授权协议: MIT
  • 更新时间: 2026-01-04

承接程序开发

PHP开发

VUE

Vue开发

前端开发

小程序开发

公众号开发

系统定制

数据库设计

云部署

网站建设

安全加固