Интеграция платёжных систем для сайтов и приложений

Наша компания занимается разработкой, поддержкой и обслуживанием сайтов любой сложности. От простых одностраничных сайтов до масштабных кластерных систем построенных на микро сервисах. Опыт разработчиков подтвержден сертификатами от вендоров.
Разработка и обслуживание любых видов сайтов:
Информационные сайты или веб-приложения
Сайты визитки, landing page, корпоративные сайты, онлайн каталоги, квиз, промо-сайты, блоги, новостные ресурсы, информационные порталы, форумы, агрегаторы
Сайты или веб-приложения электронной коммерции
Интернет-магазины, B2B-порталы, маркетплейсы, онлайн-обменники, кэшбэк-сайты, биржи, дропшиппинг-платформы, парсеры товаров
Веб-приложения для управления бизнес-процессами
CRM-системы, ERP-системы, корпоративные порталы, системы управления производством, парсеры информации
Сайты или веб-приложения электронных услуг
Доски объявлений, онлайн-школы, онлайн-кинотеатры, конструкторы сайтов, порталы предоставления электронных услуг, видеохостинги, тематические порталы

Это лишь некоторые из технических типов сайтов, с которыми мы работаем, и каждый из них может иметь свои специфические особенности и функциональность, а также быть адаптированным под конкретные потребности и цели клиента

Предлагаемые услуги
Показано 30 из 48 услугВсе 2065 услуг
Сложная
от 2 недель до 3 месяцев
Сложная
от 2 недель до 3 месяцев
Сложная
от 2 недель до 3 месяцев
Сложная
от 1 недели до 3 месяцев
Средняя
от 1 рабочего дня до 3 рабочих дней
Средняя
от 1 рабочего дня до 3 рабочих дней
Средняя
от 1 рабочего дня до 3 рабочих дней
Средняя
от 1 рабочего дня до 3 рабочих дней
Средняя
от 1 рабочего дня до 3 рабочих дней
Средняя
от 1 рабочего дня до 3 рабочих дней
Средняя
от 1 рабочего дня до 3 рабочих дней
Средняя
от 1 рабочего дня до 3 рабочих дней
Средняя
от 1 рабочего дня до 3 рабочих дней
Сложная
~2-3 рабочих дня
Средняя
от 1 рабочего дня до 3 рабочих дней
Средняя
от 1 рабочего дня до 3 рабочих дней
Средняя
от 1 рабочего дня до 3 рабочих дней
Средняя
от 1 рабочего дня до 3 рабочих дней
Средняя
от 1 рабочего дня до 3 рабочих дней
Средняя
от 1 рабочего дня до 3 рабочих дней
Часто задаваемые вопросы
Наши компетенции:
Этапы разработки
Последние работы
  • image_website-b2b-advance_0.png
    Разработка сайта компании B2B ADVANCE
    1212
  • image_web-applications_feedme_466_0.webp
    Разработка веб-приложения для компании FEEDME
    1161
  • image_websites_belfingroup_462_0.webp
    Разработка веб-сайта для компании БЕЛФИНГРУПП
    852
  • image_ecommerce_furnoro_435_0.webp
    Разработка интернет магазина для компании FURNORO
    1041
  • image_crm_enviok_479_0.webp
    Разработка веб-приложения для компании Enviok
    822
  • image_bitrix-bitrix-24-1c_fixper_448_0.png
    Разработка веб-сайта для компании ФИКСПЕР
    815

Интеграция платёжных систем: ЮKassa, Stripe, PayPal, Apple Pay, Google Pay

Магазин упал в конверсии на 12% после редизайна. Страница оформления заказа — новая, красивая. Но в Sentry посыпались ошибки: Payment method not available for this currency, 3DS2 challenge flow failed, webhook signature verification failed. Платёжная интеграция — это не «подключить SDK и забыть». Это постоянно живая часть системы с обновляющимися требованиями банков, изменениями SCA (Strong Customer Authentication) в Европе и новыми требованиями ФНС в России.

Платёжная экосистема: чем отличаются провайдеры

ЮKassa (ранее Яндекс.Касса) — основной выбор для российского рынка. Поддерживает карты, SBP (Система Быстрых Платежей), ЮMoney, наложенный платёж, рассрочку (через BNPL-партнёров). Важно: ЮKassa требует фискализации — интеграция с 54-ФЗ обязательна, чеки отправляются в ОФД. Webhooks приходят на указанный endpoint, подпись проверяется через HMAC-SHA256 с секретным ключом.

Stripe — выбор для международных проектов и SaaS. Payment Intents API, поддержка 3DS2, SCA compliance для европейских карт. Stripe Elements или Payment Element для кастомного UI без передачи данных карты на ваш сервер (PCI DSS облегчённый режим). Webhooks через Stripe CLI для локальной разработки — стандарт.

PayPal — до сих пор актуален для B2C с международной аудиторией, особенно США и Западная Европа. PayPal Checkout v2 (Orders API) — современный вариант, старый Express Checkout устарел. Особенность: PayPal IPN (Instant Payment Notification) — legacy, новый путь через Webhooks REST API.

Apple Pay / Google Pay — не отдельные процессоры, а способы инициирования платежа. Apple Pay работает через Payment Request API или через специфичный JS SDK, требует верификации домена (файл apple-developer-merchantid-domain-association в /.well-known/). Google Pay — через Google Pay API, обычно поверх Stripe или другого процессора.

Где прячутся реальные сложности

Подключить тестовый режим — час работы. Правильно обработать все сценарии — несколько недель.

Webhook надёжность. Webhook может не дойти — сервер был недоступен, таймаут, временная ошибка сети. Провайдер повторяет отправку (Stripe — до 3 дней с экспоненциальным backoff, ЮKassa — своя логика). Ваш обработчик должен быть идемпотентным: если payment.succeeded придёт дважды с одним payment_id, заказ должен обновиться только один раз. Реализуется через хранение обработанных event IDs.

3DS2 и redirect flow. При оплате картой с 3DS2 пользователь уходит на страницу банка, проходит верификацию, возвращается по return_url. За это время сессия могла истечь, корзина очиститься, URL с параметрами потеряться. Статус платежа нужно проверять не только по redirect-параметрам, но и через прямой запрос к API провайдера при возврате пользователя.

Частичные возвраты и чеки. Если клиент вернул часть товаров — нужен чек коррекции (для ФНС) и частичный refund в ЮKassa. Stripe поддерживает partial_refund нативно. В обоих случаях нужна логика синхронизации статусов между платёжной системой, базой данных и складом.

Валютные ограничения. ЮKassa работает только с рублями. Stripe работает с 135+ валютами, но для конверсии currency в разных странах нужен currency в Payment Intent. Если клиент из РФ платит в евро через Stripe — он увидит конвертацию от своего банка, а не от вас.

Как строим интеграцию

Архитектура. Никогда не храним данные карт на своём сервере — только токены от провайдера. Payment flow: создание Order в нашей БД → создание Payment Intent на стороне провайдера → редирект/виджет → webhook подтверждает → обновляем Order статус. База истины — статус в платёжной системе, не в нашей БД.

Для Laravel-проектов используем официальные SDK: stripe/stripe-php, yookassa/yookassa-sdk-php. Webhook обработчик — отдельный контроллер с VerifyCsrfToken исключением для webhook URL, проверкой подписи в первой строке, Queue job для бизнес-логики (чтобы не держать соединение).

Для Next.js / React — Stripe Elements интегрируются через @stripe/stripe-js и @stripe/react-stripe-js. PaymentElement обрабатывает все методы оплаты автоматически, включая Apple/Google Pay, без кастомного кода для каждого.

Тестирование. Stripe CLI (stripe listen --forward-to localhost:8000/webhook) для локальных webhooks. Тест-карты для всех сценариев: успешная оплата, отклонение, 3DS required, insufficient funds. Cypress/Playwright тест для полного checkout flow — обязательно в CI.

Процесс и сроки

Аудит требований → выбор провайдеров → дизайн payment flow → backend интеграция → frontend checkout → тестирование всех сценариев (success, failure, 3DS, refunds, webhooks) → деплой → мониторинг первых транзакций.

Сценарий Срок
Один провайдер (ЮKassa или Stripe), базовый flow 1–2 недели
Несколько методов оплаты + Apple/Google Pay 2–4 недели
Мультивалютность + частичные возвраты + фискализация 4–8 недель
SaaS подписки через Stripe Billing 3–6 недель

Стоимость рассчитывается индивидуально.