Интеграция логистических сервисов Boxberry в мобильное приложение

TRUETECH занимается разработкой, поддержкой и обслуживанием мобильных приложений iOS, Android, PWA. Имеем большой опыт и экспертизу для публикации мобильных приложений в популярные маркеты Google Play, App Store, Amazon, AppGallery и другие.

Разработка и поддержка любых видов мобильных приложений:

Информационные и развлекательные мобильные приложения
Новостные приложения, игры, справочники, онлайн-каталоги, погодные, фитнес и здоровье, туристические, образовательные, социальные сети и мессенджеры, квиз, блоги и подкасты, форумы, агрегаторы
Мобильные приложения электронной коммерции
Интернет-магазины, B2B-приложения, маркетплейсы, онлайн-обменники, кэшбэк-сервисы, биржи, дропшиппинг-платформы, программы лояльности, доставка еды и товаров, платежные системы
Мобильные приложения для управления бизнес-процессами
CRM-системы, ERP-системы, управление проектами, инструменты для команды продаж, учет финансов, управление производством, логистика и доставка, управление персоналом, системы мониторинга данных
Мобильные приложения электронных услуг
Доски объявлений, онлайн-школы, онлайн-кинотеатры, платформы предоставления электронных услуг, платформы кешбека, видеохостинги, тематические порталы, платформы онлайн-бронирования и записи, платформы онлайн-торговли

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

Услуги, которые мы предлагаем
Показано 1 из 1Все 1735 услуг
Интеграция логистических сервисов Boxberry в мобильное приложение
Средний
~3-5 дней
Часто задаваемые вопросы

Наши компетенции:

Этапы разработки

Последние работы

  • image_mobile-applications_feedme_467_0.webp
    Разработка мобильного приложения для компании FEEDME
    792
  • image_mobile-applications_xoomer_471_0.webp
    Разработка мобильного приложения для компании XOOMER
    671
  • image_mobile-applications_rhl_428_0.webp
    Разработка мобильного приложения для компании RHL
    1097
  • image_mobile-applications_zippy_411_0.webp
    Разработка мобильного приложения для компании ZIPPY
    969
  • image_mobile-applications_affhome_429_0.webp
    Разработка мобильного приложения для компании Affhome
    914
  • image_mobile-applications_flavors_409_0.webp
    Разработка мобильного приложения для компании FLAVORS
    495

Интеграция логистических сервисов Boxberry в мобильное приложение

Boxberry — логистический оператор с сетью более 18 000 пунктов выдачи в России. Их API старше и менее RESTful, чем у СДЭК v2, но для ключевых задач — расчёт тарифов, список ПВЗ, создание и отслеживание заказов — всё необходимое есть.

Особенности API Boxberry

Boxberry API работает на одном эндпоинте с параметром method в query string: https://api.boxberry.ru/json.php?token={TOKEN}&method={METHOD}&.... Это не типичный REST-подход, поэтому Retrofit-интерфейс выглядит иначе — один базовый URL, параметры в @Query.

Аутентификация — токен в параметре запроса, не в заголовке. Токен выдаётся в личном кабинете и не имеет срока действия по умолчанию. Хранить в Keychain / Android Keystore, не в константах кода.

Тестового окружения в публичной документации нет — разработка на боевом токене с минимальными реальными запросами. Учитывать это при разработке: не делать лишних запросов, кэшировать агрессивно.

Основные методы

Список ПВЗ:

GET /json.php?token=...&method=ListPoints&CityCode=10&prepaid=1

CityCode — внутренний код города Boxberry (не КЛАДР, не ФИАС). Таблицу кодов получаем через method=ListCities. Ответ — JSON-массив точек с полями Code, Name, Address, GPS (формат "55.7558,37.6173"), WorkShedule, Phone.

Обратить внимание: поле GPS — строка с запятой внутри, не отдельные lat/lon. Парсим:

let coords = point.gps.split(separator: ",")
let lat = Double(coords[0]) ?? 0
let lon = Double(coords[1]) ?? 0

Расчёт тарифа:

GET /json.php?token=...&method=DeliveryCosts&zip=...&weight=500&ordersum=2000

zip — почтовый индекс получателя. Возвращает price и delivery_period (дни).

Создание заказа:

POST /json.php?token=...&method=ParselCreate

Body — JSON с полями отправителя, получателя, списком товаров. Ответ содержит track — трек-номер для отслеживания.

Отслеживание:

GET /json.php?token=...&method=ListStatuses&ImId={track}

Возвращает массив статусов с Date, Name, Comment.

Реализация на Android

interface BoxberryApi {
    @GET("json.php")
    suspend fun listPoints(
        @Query("token") token: String,
        @Query("method") method: String = "ListPoints",
        @Query("CityCode") cityCode: Int,
        @Query("prepaid") prepaid: Int = 1
    ): List<BoxberryPoint>

    @GET("json.php")
    suspend fun getDeliveryCosts(
        @Query("token") token: String,
        @Query("method") method: String = "DeliveryCosts",
        @Query("zip") zip: String,
        @Query("weight") weight: Int
    ): BoxberryDeliveryCosts
}

Токен не передавать в каждом вызове — OkHttp Interceptor добавляет его автоматически. Список ПВЗ кэшировать в Room на 24 часа.

Карта ПВЗ с фильтрацией

После загрузки точек отображаем на Google Maps. Фильтры: тип ПВЗ (с примеркой / без), работа в выходные, наличие карточной оплаты — всё есть в полях ответа. Реализуем BottomSheet с фильтрами и MutableStateFlow<FilterState> для реактивной перефильтрации списка без повторного API-запроса.

Кластеризация при зуме < 12 — ClusterManager на Android, GMUMarkerClusterer на iOS. При тапе на кластер — анимированный zoom к его границам.

Flutter

Общий HTTP-клиент с Dio, BoxberryRepository с кэшем на Hive. Карта — google_maps_flutter или flutter_map. Список ПВЗ для выбора — ListView.builder с поиском по названию/адресу и фильтрами в FilterChip.

Срок интеграции: три-четыре дня — клиент, список ПВЗ с картой, расчёт стоимости, создание и отслеживание заказа.