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

This package is not auto-updated.

Last update: 2024-04-16 05:12:10 UTC


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