Настройка XML-импорта и экспорта 1С-Битрикс

Наша компания занимается разработкой, поддержкой и обслуживанием решений на Битрикс и Битрикс24 любой сложности. От простых одностраничных сайтов до сложных интернет магазинов, CRM систем с интеграцией 1С и телефонии. Опыт разработчиков подтвержден сертификатами от вендора.
Предлагаемые услуги
Показано 1 из 1 услугВсе 1626 услуг
Настройка XML-импорта и экспорта 1С-Битрикс
Простая
~1 рабочий день
Часто задаваемые вопросы
Наши компетенции:
Этапы разработки
Последние работы
  • image_website-b2b-advance_0.png
    Разработка сайта компании B2B ADVANCE
    1177
  • image_bitrix-bitrix-24-1c_fixper_448_0.png
    Разработка веб-сайта для компании ФИКСПЕР
    811
  • image_bitrix-bitrix-24-1c_development_of_an_online_appointment_booking_widget_for_a_medical_center_594_0.webp
    Разработка на базе Битрикс, Битрикс24, 1С для компании Development of an Online Appointment Booking Widget for a Medical Center
    564
  • image_bitrix-bitrix-24-1c_mirsanbel_458_0.webp
    Разработка на базе 1С Предприятие для компании МИРСАНБЕЛ
    747
  • image_crm_dolbimby_434_0.webp
    Разработка сайта на CRM Битрикс24 для компании DOLBIMBY
    655
  • image_crm_technotorgcomplex_453_0.webp
    Разработка на базе Битрикс24 для компании ТЕХНОТОРГКОМПЛЕКС
    976

Настройка XML-импорта и экспорта 1С-Битрикс

Стандартный модуль «Торговый каталог» (catalog) поддерживает обмен с 1С через протокол CommerceML 2.x — XML-файлы с номенклатурой, ценами и остатками. На практике этот механизм ломается в трёх типовых сценариях: кодировка файла не UTF-8, нестандартная структура узлов <Классификатор> от 1С и превышение лимита времени выполнения при файлах больше 50 МБ.

Как работает штатный обмен

Битрикс ожидает файлы строго в формате CommerceML 2.08. Обмен идёт через /bitrix/admin/1c_exchange.php — скрипт-приёмник, который читает сессию обмена из $_SESSION['BX_CML2_IMPORT'] и последовательно обрабатывает чанки через CCatalogImport.

Таблицы, которые затрагивает импорт:

  • b_iblock_element — элементы каталога
  • b_catalog_price — цены по типам
  • b_catalog_store_product — остатки по складам
  • b_iblock_element_property — свойства элементов

Типичные проблемы и их решение

Проблема 1: таймаут при больших файлах

1С выгружает один XML на 200 000 позиций — файл весит 180 МБ. set_time_limit(0) не спасает, если PHP-FPM настроен с request_terminate_timeout. Решение — включить пошаговый режим: в настройках модуля «1С-Битрикс: Управление сайтом → Настройки → Настройки продукта → 1С» выставить «Размер файла для пошаговой обработки» (параметр CATALOG_IMPORT_STEP_SIZE). Битрикс сам разрежет файл на части по SAX-парсеру.

Проблема 2: дубли товаров

Импорт идентифицирует товар по XML-атрибуту Ид из тега <Товар>. Если в 1С сменили GUID номенклатуры, Битрикс создаёт новый элемент. Проверьте поле XML_ID в b_iblock_element — там хранится этот идентификатор. Чиним через прямое обновление или пересвязку через CIBlockElement::Update().

Проблема 3: цены не обновляются

Частая причина — тип цены в 1С называется «Основная», а в Битриксе создан тип «Розничная». Маппинг задаётся в /bitrix/admin/cat_price_type.php. Убедитесь, что XML-тег <ТипЦены><Наименование> совпадает с полем NAME в таблице b_catalog_price_type.

Настройка экспорта из Битрикса в 1С

Для обратного потока (заказы → 1С) работает тот же endpoint с параметром type=sale. Битрикс формирует orders.xml со структурой <Документ>, включающей позиции заказа. Критично проверить, что в настройках обмена включён флаг «Выгружать реализации» и указан нужный статус заказов для выгрузки.

Параметры тонкой настройки через CBitrixComponent bitrix:catalog.import.1c:

IBLOCK_ID — инфоблок каталога
PRICE_TYPE — тип цены по умолчанию
STORE_ID — склад по умолчанию
USE_CML2_DESCRIPTION — брать описание из XML

Таймлайн работ

Этап Срок
Диагностика текущей схемы обмена 2–4 часа
Настройка маппинга типов цен и складов 3–6 часов
Настройка пошагового импорта 2–4 часа
Тестовый прогон + отладка 4–8 часов

Полная настройка под нестандартную структуру 1С занимает 1–2 рабочих дня. Если нужна кастомная обработка событий OnSuccessCatalogImport или OnBeforeCatalogImport — добавляйте ещё день на разработку обработчика.