Интеграция платежной системы Cloudpayments с вашим проектом
Сегодня немыслим ни один бизнес без возможности приема платежей онлайн, будь то интернет-магазин или сервис по предоставлению персональных услуг, ввиду чего как нельзя актуальным становится услуга интернет-эквайринга(возможность приема платежей картами Visa, MasterCard, Maestro, Visa Electron или Мир), которую предоставляет такой сервис как Cloudpayments. Данный сервис примечателен в первую очередь гибкостью настроек, позволяющих произвести интеграцию с вашим проектом с максимальной эффективностью — реализовав более обширный функционал, нежели в случае работы с другим сервисом интернет-эквайринга, а также стабильностью работы и исчерпывающей документацией. Далее я проведу краткий обзор его возможностей.
Варианты интеграции
Сервис предоставляет несколько вариантов интеграции(так называемых продуктов) с вашим проектом, с помощью прямого взаимодействия с API, путем размещения виджета или использования мобильных пакетов SDK(для взаимодействия с Apple Pay, Google Pay), также есть плагины для быстрой интеграции с несколькими десятками популярных CMS.
API и доступные методы
Данные передаются в формате Json, методом POST на сервер Cloudpayments.
Пример запроса на оплату по криптограмме:
{ "Amount":10, "Currency":"RUB", "InvoiceId":"1234567", "IpAddress": "123.123.123.123", "Description":"Оплата товаров в example.com", "AccountId":"user_x", "Name":"CARDHOLDER NAME", // CardCryptogramPacket Обязательный параметр "CardCryptogramPacket":"01492500008719030128SMfLeYdKp5dSQVIiO5l6ZCJiPdel4uDjdFTTz1UnXY+3QaZcNOW8lmXg0H670MclS4lI+qLkujKF4pR5Ri+T/E04Ufq3t5ntMUVLuZ998DLm+OVHV7FxIGR7snckpg47A73v7/y88Q5dxxvVZtDVi0qCcJAiZrgKLyLCqypnMfhjsgCEPF6d4OMzkgNQiynZvKysI2q+xc9cL0+CMmQTUPytnxX52k9qLNZ55cnE8kuLvqSK+TOG7Fz03moGcVvbb9XTg1oTDL4pl9rgkG3XvvTJOwol3JDxL1i6x+VpaRxpLJg0Zd9/9xRJOBMGmwAxo8/xyvGuAj85sxLJL6fA==" "Payer": { "FirstName":"Тест", "LastName":"Тестов", "MiddleName":"Тестович", "Birth":"1955-02-24", "Address":"тестовый проезд дом тест", "Street":"Lenina", "City":"MO", "Country":"RU", "Phone":"123", "Postcode":"345" } } |
Пример ответа (некорректный запрос):
{ "Success": false, "Message": "Invalid Amount value" } |
- Аутентификация запросов;
- Идемпотентность API;
- Тестовый метод;
- Оплата по криптограмме;
- Обработка 3-D Secure;
- Оплата по токену (рекарринг);
- Подтверждение оплаты;
- Отмена оплаты;
- Возврат денег;
- Выплата по криптограмме;
- Выплата по токену;
- Просмотр транзакции;
- Проверка статуса платежа;
- Выгрузка списка транзакций;
- Выгрузка токенов;
- Создание подписки на рекуррентные платежи;
- Запрос информации о подписке;
- Поиск подписок;
- Изменение подписки на рекуррентные платежи;
- Отмена подписки на рекуррентные платежи;
- Создание счета для отправки по почте;
- Отмена созданного счета;
- Просмотр настроек уведомлений;
- Изменение настроек уведомлений;
- Запуск сессии для оплаты через Apple Pay.
Платежный виджет
Виджет — представляет собой форму, для ввода данных пластиковой карты с целью проведения дальнейшей оплаты. Для размещения формы на сайте достаточно вставить в страницу, HTML и JavaScript код, в несколько строк. Настройка виджета производится путем изменения параметров доступных в его коде.
Пример кода вставки виджета:
Строка кода ниже, вставляется в страницу сайта в секцию HEAD.
<script src="https://widget.cloudpayments.ru/bundles/cloudpayments"></script> |
Для вывод платежной формы на странице в сплывающем окне, необходимо вызвать функцию метода pay, передав в него параметр auth(двустадийная оплата) или charge(одностадийная оплата):
this.pay = function () { var widget = new cp.CloudPayments(); widget.pay('auth', // или 'charge' { //options publicId: 'test_api_00000000000000000000001', //id из личного кабинета description: 'Оплата товаров в example.com', //назначение amount: 100, //сумма currency: 'RUB', //валюта accountId: 'user@example.com', //идентификатор плательщика (необязательно) invoiceId: '1234567', //номер заказа (необязательно) skin: "mini", //дизайн виджета (необязательно) data: { myProp: 'myProp value' } }, { onSuccess: function (options) { // success //действие при успешной оплате }, onFail: function (reason, options) { // fail //действие при неуспешной оплате }, onComplete: function (paymentResult, options) { //Вызывается как только виджет получает от api.cloudpayments ответ с результатом транзакции. //например вызов вашей аналитики Facebook Pixel } } ) }; $('#checkout').click(pay); // И прописать вызов функции на событие, например, нажатие кнопки «Оплатить»: |
Схемы проведения платежа
Сервис поддерживает две схемы проведения платежа, одностадийная и двухстадийная, каждая из которых может использоваться в зависимости от логики работы вашего проекта.
Одностадийная оплата
Для оплаты достаточно сформировать и отправить одну команду на сервер Cloudpayments, по результатам работы которой будет произведена
авторизация платежа и последующее списание средств со счета плательщика.
Двухстадийная оплата
В этом случае на авторизацию платежа и списание средств формируется и отправляется две отдельные команды, что позволяет заморозить денежные средства на карте плательщика, а спустя определенное время списать необходимую сумму. Данная схема удобна при бронировании отелей, парковок и т.д., когда необходима блокировка депозита. Дополнительно можно реализовать автоматическое списание средств через определенный временной промежуток, что тоже может быть удобно в ряде случаев.
Типы платежей
Очень удобно реализованы типы платежей с возможность разового или регулярного списания, в случае покупки клиентом подписки на сервис, например.
Разовый платеж
Все просто, пользователь вводит данные своей карты и производить разовый платеж, к особенностям можно отнести поддержку оплаты по криптограмме и токену сгенерированному на основе неё, при чем все эти методы доступны по API. Что позволяет интегрировать Cloudpayments с любым проектом, будь то сайт или мобильное приложение с поддержкой Google Pay и Apple Pay.
Рекуррентные платежи
Списание средств по подписке, очень удобная функция при продаже например услуг вашего сервиса по подписке. Пользователю не нужно постоянно производить оплату вручную, достаточно единожды ввести данные своей карты. По заверениям Cloudpayments, у них этот тип платежа реализован особенно удачно, в отличии от других сервисов интернет-эквайринга(где бывает произвольное удаление подписки, или напротив сложности с отменой и т.д.), но давать оценку можно будет только после тестирования на длительной дистанции(я к сожалению такой тест пока не проводил).
Уведомления
Самым заметным отличием сервиса Cloudpayments является возможность широкой настройки Callback(или Webhook) уведомлений на адрес вашего проекта о различных событиях происходящих в момент оплаты. Это позволяет реализовать очень гибкий функционал взаимодействия вашего проекта с сервисом приема платежей, а также с вашим клиентом(пользователем производящим оплату). Стоит отметить, что более обширных возможностей я не встречал ни у одного интернет-эквайринга(но уверен аналоги все же есть). Есть возможность настройки способа передачи данных GET или POST, а также задать кодировку.
Поддерживаются уведомления следующих типов:
Check уведомление — Запрос на проверку платежа
Pay уведомление — Уведомление о принятом платеже
Fail уведомление — Уведомление о об отклоненном платеже
Confirm уведомление — Уведомление о проверке платежа
Refund уведомление — Уведомление о возврате платежа
Receipt уведомление — Уведомление об онлайн чеке
Kkt уведомление — Уведомление об статусе кассы
Recurrent уведомление — Уведомление об изменении статуса подписки
Cancel уведомление — Уведомление об отмене платежа
На стороне вашего проекта, при получении уведомлений, рекомендуется проверять статус, сумму, дату и ID клиента.
Скрипт обработки Pay уведомления(пример):
$AccountId = (string) $_POST['AccountId']; $Amount = (float) $_POST['Amount']; $Status = (string) $_POST['Status']; $DateTime = (string) $_POST['DateTime']; if($AccountId && $Amount && $Status == 'Completed') { // Проверка AccountId, суммы и статуса // Выполняем необходимые действия на стороне проекта } //В ответ на запрос система ожидает получить ответ в JSON-формате с обязательным параметром code: $response = ['code' => 0]; echo json_encode($response); |
Уведомления настраиваются в личном кабинете сервиса, в дополнении ко всему там также есть раздел «Системный журнал», позволяющий просматривать логи всех HTTP запросов уведомлений, что также крайне удобно при отладке проекта.
Тарифы
Сервис хорош во всем, но не стоит забывать о тарифах и комиссиях взымаемых им при проведении платежей. Судя из описания условий сотрудничества можно предположить, что сервис предоставляет гибкие тарифы в зависимости от масштаба вашего проекта. Отталкиваться же стоит примерно от таких данных: Верификация и доступ к сервису 1500руб., абонентская плата в месяц 900руб., комиссия за перевод 3.9%(но не менее 3.9руб.), комиссия при отмене платеже 0.5руб.(кстати ранее я не встречал комиссию за отмену платежа у какого либо другого сервиса). На самом сайте Cloudpayments данных о тарифах я не нашел, есть только форма запроса для их получения.
Заключение
Если вы рассматриваете варианты сервисов предоставляющих услугу интернет-экварийнга, то я рекомендую рассмотреть возможность сотрудничества с Cloudpayments, а то что касается технической части данного вопроса, то я всегда буду рад помочь вам с интеграцией сервиса с вашим проектом!
Пишите, буду рад помочь!
Похожие записи
Оставить комментарий
Full Stack
Senior, Architect
предложить оффер
- jQuery: как получить значение атрибута?
- PHP работа с изображением, класс SimpleImage
- Интеграция с API ОСАГО сайта sravni.ru
- Комментарии на PHP, Ajax, mySQL
- PHP: Категории бесконечного уровня вложенности.
- Nginx редирект на другой сервис с сохранением URL спросил (а) Сергей
- Исполнитель пропал, почему такое случается и понять с кем работать? спросил (а) Артем
- Можно ли WordPress считать универсальным движком? спросил (а) Андрей
- Что такое самописный скрипт или CMS? спросил (а) Антон
- Как при поиске в linux используя grep, добавить исключения? спросил (а) Алексей
- Обзор Insurance CMS — платформы для сайтов по страхованию к записи
- Консольный скрипт(JavaScript) для автоматических заказов на OZON к записи
- Консольный скрипт(JavaScript) для автоматических заказов на OZON к записи
- Как создать Telegram-бота с авторизацией через сайт к записи
- PHP скрипт: каталог закладок на сайты к записи
- Валидация на PHP к записи
- Сколько зарабатывают в бизнесе на совместных покупках к записи
Archive
- +2025 (3)
- Январь 2025 (3)
- +2024 (35)
- Декабрь 2024 (7)
- Ноябрь 2024 (13)
- Октябрь 2024 (8)
- Сентябрь 2024 (1)
- Август 2024 (5)
- Май 2024 (1)
- +2023 (27)
- Ноябрь 2023 (1)
- Октябрь 2023 (13)
- Сентябрь 2023 (10)
- Апрель 2023 (1)
- Март 2023 (1)
- Февраль 2023 (1)
- +2022 (21)
- Декабрь 2022 (11)
- Ноябрь 2022 (1)
- Май 2022 (2)
- Апрель 2022 (2)
- Март 2022 (3)
- Февраль 2022 (1)
- Январь 2022 (1)
- +2021 (17)
- Декабрь 2021 (5)
- Ноябрь 2021 (2)
- Июль 2021 (1)
- Июнь 2021 (2)
- Май 2021 (5)
- Апрель 2021 (1)
- Март 2021 (1)
- +2020 (20)
- Декабрь 2020 (6)
- Сентябрь 2020 (2)
- Август 2020 (1)
- Июль 2020 (2)
- Май 2020 (2)
- Апрель 2020 (2)
- Март 2020 (2)
- Февраль 2020 (1)
- Январь 2020 (2)
- +2019 (18)
- Декабрь 2019 (3)
- Ноябрь 2019 (2)
- Октябрь 2019 (2)
- Сентябрь 2019 (1)
- Август 2019 (2)
- Июль 2019 (1)
- Июнь 2019 (1)
- Апрель 2019 (2)
- Март 2019 (1)
- Февраль 2019 (3)
- +2018 (44)
- Декабрь 2018 (4)
- Ноябрь 2018 (7)
- Октябрь 2018 (8)
- Сентябрь 2018 (1)
- Август 2018 (4)
- Июль 2018 (5)
- Май 2018 (3)
- Апрель 2018 (7)
- Март 2018 (1)
- Февраль 2018 (2)
- Январь 2018 (2)
- +2017 (19)
- Декабрь 2017 (2)
- Ноябрь 2017 (1)
- Октябрь 2017 (1)
- Сентябрь 2017 (2)
- Июль 2017 (1)
- Июнь 2017 (1)
- Май 2017 (2)
- Апрель 2017 (3)
- Март 2017 (2)
- Февраль 2017 (1)
- Январь 2017 (3)
- +2016 (36)
- Декабрь 2016 (3)
- Ноябрь 2016 (3)
- Октябрь 2016 (2)
- Сентябрь 2016 (3)
- Август 2016 (7)
- Июнь 2016 (3)
- Май 2016 (3)
- Апрель 2016 (3)
- Февраль 2016 (1)
- Январь 2016 (8)
- +2015 (36)
- Ноябрь 2015 (5)
- Октябрь 2015 (4)
- Сентябрь 2015 (1)
- Август 2015 (8)
- Июнь 2015 (1)
- Май 2015 (4)
- Апрель 2015 (8)
- Март 2015 (3)
- Февраль 2015 (2)
- +2014 (26)
- Ноябрь 2014 (2)
- Октябрь 2014 (5)
- Сентябрь 2014 (6)
- Июль 2014 (1)
- Июнь 2014 (2)
- Май 2014 (3)
- Апрель 2014 (6)
- Февраль 2014 (1)
- +2013 (27)
- Декабрь 2013 (2)
- Ноябрь 2013 (1)
- Октябрь 2013 (1)
- Август 2013 (1)
- Июль 2013 (3)
- Июнь 2013 (10)
- Май 2013 (1)
- Апрель 2013 (2)
- Февраль 2013 (3)
- Январь 2013 (3)
- +2012 (41)
- Декабрь 2012 (2)
- Ноябрь 2012 (3)
- Октябрь 2012 (7)
- Сентябрь 2012 (2)
- Август 2012 (1)
- Июль 2012 (3)
- Июнь 2012 (2)
- Май 2012 (6)
- Апрель 2012 (2)
- Март 2012 (7)
- Февраль 2012 (5)
- Январь 2012 (1)
- +2011 (57)
- Декабрь 2011 (6)
- Ноябрь 2011 (2)
- Октябрь 2011 (3)
- Сентябрь 2011 (5)
- Август 2011 (4)
- Июль 2011 (3)
- Июнь 2011 (3)
- Май 2011 (3)
- Апрель 2011 (4)
- Март 2011 (10)
- Февраль 2011 (5)
- Январь 2011 (9)
- +2010 (43)
- Декабрь 2010 (7)
- Ноябрь 2010 (21)
- Октябрь 2010 (14)
- Сентябрь 2010 (1)
Свежие записи
- Плагин WordPress для настройки robots.txt 13.01.2025
- Скрипт проверки товара на оригинал (для WordPress и прочих) 08.01.2025
- Флаги Apache при переадресации RewriteRule 02.01.2025
- Интеграция сайта(ресторана) с API сервиса Quick Resto 23.12.2024
- Шифрование в PHP и расшифровка в JavaScript по ключу 15.12.2024