Разработка кастомных административных страниц 1С-Битрикс

Наша компания занимается разработкой, поддержкой и обслуживанием решений на Битрикс и Битрикс24 любой сложности. От простых одностраничных сайтов до сложных интернет магазинов, CRM систем с интеграцией 1С и телефонии. Опыт разработчиков подтвержден сертификатами от вендора.
Предлагаемые услуги
Показано 1 из 1 услугВсе 1626 услуг
Разработка кастомных административных страниц 1С-Битрикс
Средняя
~1-2 недели
Часто задаваемые вопросы

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

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

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

  • image_website-b2b-advance_0.png
    Разработка сайта компании B2B ADVANCE
    1262
  • image_bitrix-bitrix-24-1c_fixper_448_0.png
    Разработка веб-сайта для компании ФИКСПЕР
    851
  • 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
    585
  • image_bitrix-bitrix-24-1c_mirsanbel_458_0.webp
    Разработка на базе 1С Предприятие для компании МИРСАНБЕЛ
    751
  • image_crm_dolbimby_434_0.webp
    Разработка сайта на CRM Битрикс24 для компании DOLBIMBY
    657
  • image_crm_technotorgcomplex_453_0.webp
    Разработка на базе Битрикс24 для компании ТЕХНОТОРГКОМПЛЕКС
    989

Разработка кастомных административных страниц 1С-Битрикс

Стандартный административный раздел покрывает типовые задачи — управление каталогом, заказами, пользователями. Но как только появляется специфика бизнеса — ручная синхронизация остатков из внешней системы, массовое обновление цен по формуле, управление настройками интеграций — нужны собственные административные страницы. Разрабатывать их в /bitrix/admin/ напрямую нельзя (обновления сотрут изменения), правильный путь — /local/.

Где размещать кастомные административные страницы

Файлы кастомных страниц размещаются в /local/admin/. Битрикс автоматически включает этот путь в поиск административных страниц. Страница становится доступна по адресу /bitrix/admin/my_page.php если файл лежит в /local/admin/my_page.php.

Альтернатива — создать страницу как компонент в /local/components/ и подключить её через обёртку. Это предпочтительный подход для сложных интерфейсов.

Структура минимальной административной страницы

<?php
// /local/admin/my_custom_page.php

require_once($_SERVER['DOCUMENT_ROOT'] . '/bitrix/modules/main/include/prolog_admin_before.php');

// Проверка прав
$APPLICATION->SetTitle('Моя страница');
if (!$USER->IsAdmin() && !$USER->CanDoOperation('edit_php')) {
    $APPLICATION->AuthForm('Нет доступа');
}

require_once($_SERVER['DOCUMENT_ROOT'] . '/bitrix/modules/main/include/prolog_admin_after.php');

// Контент страницы
?>
<div class="adm-content-wrap">
    <!-- HTML интерфейса -->
</div>
<?php
require_once($_SERVER['DOCUMENT_ROOT'] . '/bitrix/modules/main/include/epilog_admin.php');

Три обязательных инклюда формируют правильную обёртку: шапку, навигацию, подвал административного раздела. Без них страница откроется без оформления.

Использование административных хелперов Битрикс

Битрикс предоставляет набор классов для построения стандартных административных UI-элементов. Использование этих классов даёт нативный внешний вид и избавляет от вёрстки.

CAdminList — таблица с сортировкой, пагинацией и фильтром:

use Bitrix\Main\UI\Filter\Options as FilterOptions;

$oList = new CAdminList('my_list_id');

// Добавить колонки
$lAdmin->AddHeaders([
    ['id' => 'ID', 'content' => 'ID', 'sort' => 'ID'],
    ['id' => 'NAME', 'content' => 'Название', 'sort' => 'NAME'],
    ['id' => 'DATE', 'content' => 'Дата'],
]);

// Заполнить строками
while ($row = $rsData->Fetch()) {
    $oRow = &$oList->AddRow('ID_' . $row['ID'], $row);
    $oRow->AddActions([
        ['TEXT' => 'Изменить', 'ONCLICK' => "jsUtils.Redirect([], 'my_edit.php?ID=" . $row['ID'] . "')"],
        ['TEXT' => 'Удалить', 'ACTION' => $oList->ActionDoGroup($row['ID'], 'delete')],
    ]);
}

$oList->DisplayList();

CAdminForm — форма редактирования с вкладками:

$oTabControl = new CAdminTabControl('tabControl', [
    ['DIV' => 'tab1', 'TAB' => 'Основное', 'ICON' => 'main_user_edit'],
    ['DIV' => 'tab2', 'TAB' => 'Дополнительно'],
]);

$oTabControl->Begin();
$oTabControl->BeginNextTab();
// поля первой вкладки
$oTabControl->BeginNextTab();
// поля второй вкладки
$oTabControl->Buttons(['btnSave' => true, 'btnApply' => true, 'btnCancel' => true]);
$oTabControl->End();

Добавление страницы в меню административного раздела

Страница должна быть доступна из меню, а не только по прямому URL. Регистрация через обработчик события в /local/php_interface/init.php:

AddEventHandler('main', 'OnBuildGlobalMenu', function(&$globalMenu, &$moduleMenu) {
    $moduleMenu[] = [
        'parent_menu' => 'global_menu_services', // раздел меню
        'sort'        => 500,
        'text'        => 'Синхронизация',
        'title'       => 'Управление синхронизацией с внешней системой',
        'url'         => 'my_custom_page.php',
        'icon'        => 'main_menu_tasks',      // CSS-класс иконки
        'page_icon'   => 'main_page_icon',
        'more_url'    => ['my_custom_page.php', 'my_custom_edit.php'],
    ];
});

Параметр more_url нужен, чтобы пункт меню оставался активным при переходе на связанные страницы (например, форму редактирования).

Работа с данными: D7 vs старое API

Для кастомных страниц рекомендуется использовать D7 ORM (\Bitrix\Main\ORM). Если данные хранятся в собственных таблицах — создаётся класс сущности:

namespace Local\MyModule;

use Bitrix\Main\ORM\Data\DataManager;
use Bitrix\Main\ORM\Fields;

class MyEntityTable extends DataManager
{
    public static function getTableName(): string
    {
        return 'my_custom_table';
    }

    public static function getMap(): array
    {
        return [
            new Fields\IntegerField('ID', ['primary' => true, 'autocomplete' => true]),
            new Fields\StringField('NAME', ['required' => true]),
            new Fields\DatetimeField('CREATED_AT'),
        ];
    }
}

После этого MyEntityTable::getList(), ::add(), ::update(), ::delete() работают через стандартный Битрикс ORM.

Обработка форм и AJAX

Административные страницы Битрикс традиционно используют POST-формы с токеном CSRF (bitrix_sessid_post()). Для AJAX-запросов:

// Проверка сессионного токена
if (!check_bitrix_sessid()) {
    die(json_encode(['error' => 'Invalid session']));
}

// В JS (при использовании BX.ajax)
BX.ajax.runAction('local:my.action', {
    data: { param: value },
    sessid: BX.bitrix_sessid()
});

Для современных AJAX-интерфейсов можно использовать \Bitrix\Main\Engine\Controller с роутингом через /.action.php — это D7-подход, рекомендованный для новых разработок.

Права доступа к кастомным страницам

Кастомная страница должна проверять права самостоятельно. Варианты:

  • Проверка $USER->IsAdmin() — только для страниц, доступных исключительно администраторам
  • Проверка $USER->CanDoOperation('название_операции') — для гранулярного контроля
  • Проверка права на модуль: CModule::IncludeModule('main') && $USER->GetRights('mymodule') >= 'W'

Если страница должна быть доступна определённой группе — лучше создать собственный модуль с регистрацией прав через RegisterModuleDependences.

Типовые задачи, для которых создаются кастомные страницы

  • Панель управления синхронизацией с 1С или внешними API (ручной запуск, лог последних операций)
  • Массовое редактирование товаров по нестандартным критериям
  • Дашборд с аналитикой на основе данных из нескольких модулей
  • Управление настройками интеграций (ключи API, вебхуки, маппинг полей)
  • Инструменты миграции контента между окружениями

Сроки выполнения

Простая кастомная страница с формой и CRUD-таблицей — 1–2 дня. Многостраничный раздел с фильтрами, AJAX, правами доступа и собственной таблицей в БД — 3–5 дней. Полноценный кастомный модуль с интеграцией в меню, правами и событиями — 1–2 недели.