CVE-2026-39387

HIGH CVSS 3.1: 7,2
Обновлено 17 апреля 2026
PHP
Параметр Значение
CVSS 7,2 (HIGH)
Уязвимые версии до 2.1.3
Устранено в версии 2.1.3
Тип уязвимости CWE-98
Поставщик PHP
Публичный эксплойт Нет

BoidCMS — это CMS с плоскими файлами на основе PHP с открытым исходным кодом для создания простых веб-сайтов и блогов, использующая JSON в качестве базы данных. Версии до 2.1.3 уязвимы к критической атаке включения локального файла (LFI) через параметр tpl, которая может привести к удаленному выполнению кода (RCE). Приложению не удается очистить параметр tpl (шаблон) во время создания и обновления страницы.

Этот параметр передается непосредственно в оператор require_once() без проверки пути. Аутентифицированный администратор может воспользоваться этим, внедрив последовательности обхода пути (../) в значение tpl, чтобы выйти из предполагаемого каталога темы и включить произвольные файлы — в частности, файлы из каталога media/ сервера. В сочетании с функцией загрузки файлов это превращается в полную цепочку RCE: злоумышленник может сначала загрузить файл со встроенным PHP-кодом (например, замаскированным под данные изображения), затем использовать уязвимость обхода пути, чтобы включить этот файл через require_once(), выполняя встроенный код с привилегиями веб-сервера.

Эта проблема исправлена ​​в версии 2.1.3.

Показать оригинальное описание (EN)

BoidCMS is an open-source, PHP-based flat-file CMS for building simple websites and blogs, using JSON as its database. Versions prior to 2.1.3 are vulnerable to a critical Local File Inclusion (LFI) attack via the tpl parameter, which can lead to Remote Code Execution (RCE).The application fails to sanitize the tpl (template) parameter during page creation and updates. This parameter is passed directly to a require_once() statement without path validation. An authenticated administrator can exploit this by injecting path traversal sequences (../) into the tpl value to escape the intended theme directory and include arbitrary files — specifically, files from the server's media/ directory. When combined with the file upload functionality, this becomes a full RCE chain: an attacker can first upload a file with embedded PHP code (e.g., disguised as image data), then use the path traversal vulnerability to include that file via require_once(), executing the embedded code with web server privileges. This issue has been fixed in version 2.1.3.

Характеристики атаки

Способ атаки
По сети
Атака возможна удалённо
Сложность
Низкая
Легко эксплуатировать
Нужны права
Высокие
Нужны права администратора
Участие пользователя
Не требуется
Не нужно действие пользователя

Последствия

Конфиденциальность
Высокое
Полная утечка данных
Целостность
Высокое
Полная модификация данных
Доступность
Высокое
Полный отказ в обслуживании

Строка CVSS v3.1

Тип уязвимости (CWE)