imaginaria / jevix
Library for html filtering, forked for imaginaria project and AJUR-Media projects from Visman
2.3.0
2022-05-29 22:00 UTC
Requires
- php: >=7.4.0
- ext-mbstring: *
README
Система автоматического типографирования и фильтрации текста с HTML/XHTML разметкой, разработанная в ТМ™ для собственных проектов с открытым исходным кодом. Изначально появился как php-версия перлового Jevix-а, сейчас проекты сильно разошлись.
Где используется
- Проекты Тематических Медиа (Хабрахабр и др.), по крайней мере использовалось до 2020 года.
- Сообщество безвоздместного дарения Дару~дар
- Один из ведущих русскоязычных интернет-ресурсов, посвящённых nix системам и миру Open Source NIXP.RU
- Свободные движки для блого-социальных сетей и тематических сообществ LiveStreet, BigStreet и Explay CMS
- Система управления сайтами Сogear на CodeIgniter
- Многофункциональная система управления сайтами Alto CMS
- Плагин для Codeigniter. Работает в связке с GeSHi для подсветки синтаксиса
- Плагин для MODx CMS: домашняя страница, на GitHub
- Компонент для удобного использования Jevix в Yii
- ... и много где еще.
Возможности
- Фильтрация введённого пользователем текста с HTML разметкой на основе заданных правил о разрешённых тегах и атрибутах
- Исправление ошибок HTML и формирование валидного HTML или XHTML кода
- Предотвращение XSS-атак
- Применение правил набора текстов (типографика) для русского языка
Преимущества
- Jevix работает на '''конечном автомате''', а не на регулярных выражениях. Соответственно обратная идеология: вместо запрещающих правил разрешающие (всё что не разрешено — запрещено)
- XSS-фильтация, валидация, обработка HTML и типографирование в одном флаконе, в одном файле
Недостатки
- Jevix разделяет строки '''<br>'''-ами. Делать '''<p>абзацы</p>''' он не умеет, и, в существующей архитектурной концепции вряд ли научится
- Автор больше не развивает проект, перешёл на Python и постепенно забывает синтаксис PHP. Однако PULL-реквесты приветствуются
Пример использования
<?php require('jevix.class.php'); $jevix = new AJUR\Jevix\Jevix(); //Конфигурация // Устанавливаем разрешённые теги. (Все не разрешенные теги считаются запрещенными.) $jevix->cfgAllowTags(array('a', 'img', 'strong', 'ul', 'li', 'h1', 'h2')); // Устанавливаем разрешённые параметры тегов. $jevix->cfgAllowTagParams('a', array('title', 'href')); // Устанавливаем параметры тегов являющиеся обязяательными. Без них вырезает тег оставляя содержимое. $jevix->cfgSetTagParamsRequired('a', 'href'); // Устанавливаем теги которые может содержать тег контейнер $jevix->cfgSetTagChilds('ul', 'li', true, false); // Устанавливаем атрибуты тегов, которые будут добавлятся автоматически $jevix->cfgSetTagParamDefault('a', 'rel', 'nofollow'); //Парсинг $res = $jevix->parse('...тут...мог...бы...быть...ваш...текст...'); ?>
Системные требования
- PHP 7.3.0+
- Модуль mbstring