1С Битрикс Управления сайтом довольно мощная и гибкая CMS позволяющая решать множество задач веб-разработки. В ней так же предусмотрены механизмы расширения базовых возможностей системы по средством собвтенных компонентов, модулей и классов. Давайте рассмотрим последние и разберёмся как же загружать их в систему.

1С Битрикс Управления сайтом довольно мощная и гибкая CMS позволяющая решать множество задач веб-разработки. В ней так же предусмотрены механизмы расширения базовых возможностей системы по средством собвтенных компонентов, модулей и классов. Давайте рассмотрим последние и разберёмся как же загружать их в систему.


Существует 2 основных варианта подключения своего класса (сейчас я не рассматриваю модули и компоненты, в них так же можно создавать классы и подключаь методами CModule::IncludeModue(‘module_name’) или же через компоненты $APPLICATION->IncludeComponent()):

  1. Через автозагрузчик классов битрикс
  2. По средствам composer

Автозагрузка классов 1С Битрикс

Первым делом необходимо расположить класс в удобном для этого месте, где его не затрут обновления системы и с ним будет удобно работать. Обычно я размещаю классы в папке /local/php_interface/lib/#папка_с_типом_класса#/ — здесь #папка_с_типом_класса# это директория собирающая однотипные классы в одном месте, например для работы с собственными пользовательскими свойствами или информационными блоками, для простоты пока опустим эту папку и поместим прямо в корень /lib/. Назовём его someclass.php:


<?php

namespace lib;


class SomeClass
{
    public static function someMethod()
    {

    }
}

Теперь в папке /local/php_interface/ создадим файл autoload.php где вызовем метод Bitrix\Main\Loader::registerAutoLoadClasses() вот с такими настройками:

<?

Bitrix\Main\Loader::registerAutoLoadClasses(null, [
    'lib\SomeClass' => '/local/php_interface/lib/SomeClass.php'
]);

Сам файл естественно необходимо подключить в /local/php_interface/init.php в самом начале:

<?

require_once( $_SERVER['DOCUMENT_ROOT'] . '/local/php_interface/autoload.php');

Таким образом, как только нам потребуется воспользоваться нашим классом, 1С Битрикс, автоматически его подгрузит.

Загрузка классов через Composer

Так же для автозагрузки классов битрикс можно использовать популярный менеджер зависимостей composer. Он сам создаст файл autoload.php который будет отвечать за автозагрузку наших классов. Чтобы использовать composer вам необходимо в папке  /local/php_interface/ создать файл composer.json со следующим содержимым:


{
  "autoload": {
    "psr-4": {
      "lib\\": "lib/"
    }
  }
}

здесь первый «lib\\» (ключ) — это пространство имён наших классов, а «lib/» это папка (относительно директории где создан conposer.json) где будут лежать наши классы.  Затем открываем консоль, переходим в папку /local/php_interface/ и запускаем команду composer install. Если всё сделано правильно и у вас или на сервере установлен composer вы увидите следующее сообщение:

Loading composer repositories with package information
Updating dependencies (including require-dev)
Nothing to install or update
Generating autoload files


При этом composer создаст новую папку /vendor/ и файл autoload.php, который нам осталось загрузить в init.php как мы делали в первом методе:

<? 
require_once ( $_SERVER['DOCUMENT_ROOT'] . '/local/php_interface/vendor/autoload.php' );


Лично мне, второй вариант нравится больше, т.к. я часто использую в своих проектах сторонние библиотеки, которые как раз устанавливаю при помощи composer и т.к. у меня всё равно подключен /vendor/autoload.php, не вижу смысла подключать собственные классы через автозагрузчик битрикса. Но это дело вкуса.

Используйте современные инструменты и пусть ваш код работает быстро и правильно!

Полезная статья?
(Голосов: 3, Рейтинг: 3.25)
Вам также могут понравиться
Объективно о преимуществах и недостатках 1С-Битрикс

Объективно о преимуществах и недостатках 1С-Битрикс

С развитием интернета появилось много платформ, которые помогают начинающим бизнесменам создать и сделать рентабельным и успешным интернет-магазин. Но подобрать действительно эффективную площадку не так-то просто. Что необходимо знать, чтобы не прогореть, какой тип платформы выбрать. Об этом поговорим в этой статье.

Авторизация на сайте при помощи Вконтакте

Авторизация на сайте при помощи Вконтакте

Большинство социальных сетей позволяют использовать свои API для авторизации пользователей на сайте имеющих аккаунт в данной социальной сети. В статье рассмотрен способ авторизации при помощи API вконтакте.ру.

Исключения в PHP, что это и как ими пользоваться

Исключения в PHP, что это и как ими пользоваться

В этой статье вы узнаете что такое исключения в PHP и как их использовать для обработки ошибок. Начиная с PHP версии 5.0 стала доступна новая модель обработки ошибок, так называемые исключения. Она позволяет более гибко и информативно для пользователя обрабатывать не стандартные ситуации в работе вашего приложения. 


Комментарии
Защита от автоматических сообщений
CAPTCHA
Введите слово на картинке
04.10.2020 | Дмитрий

Спасибо за статью. Помогла. Не знал, что после добавления классов в psr-4 нужно делать в composer install.

Комментировать | 0  
Защита от автоматических сообщений
CAPTCHA
Введите слово на картинке
Закрыть