OGNL - OGNL

OGNL
Разработчики)Технология OGNL
Стабильный выпуск
3.0.8 / 24 сентября 2013 г. (2013-09-24)
Написано вЯва
Операционная системаКроссплатформенность
ПлатформаВиртуальная машина Java
ТипЯзык выражений (EL)
ЛицензияЛицензия BSD
Интернет сайтhttp://commons.apache.org/ognl/

Язык объектно-графической навигации (OGNL) с открытым исходным кодом Язык выражений (EL) за Ява, который, хотя и использует более простые выражения, чем полный набор выражений, поддерживаемых языком Java, позволяет получать и устанавливать свойства (через определенные методы setProperty и getProperty, найденные в JavaBeans ), и выполнение методов классов Java. Это также позволяет упростить манипуляции с массивами.

Он предназначен для использования в Java EE приложения с taglibs как язык выражения.

OGNL был создан Люком Бланшардом и Дрю Дэвидсоном из Технология OGNL.[1] Развитие OGNL продолжили OpenSymphony, который закрылся в 2011 году.[2] OGNL сейчас разрабатывается как часть Apache Commons.

Технология OGNL

OGNL возник как способ сопоставления ассоциаций между интерфейсными компонентами и внутренними объектами с использованием имен свойств. По мере того, как эти ассоциации собирали больше возможностей, Дрю Дэвидсон создал язык кодирования ключевых значений (KVCL). Люк Бланшард затем переопределил KVCL, используя ANTLR и начал использовать имя OGNL. Технология была снова реализована с использованием компилятора Java Compiler Compiler (JavaCC ).

OGNL использует Java отражение и самоанализ обратиться к Граф объектов исполняемого приложения. Это позволяет программе изменять поведение в зависимости от состояния графа объекта вместо того, чтобы полагаться на настройки времени компиляции. Он также позволяет вносить изменения в граф объекта.

Проекты с использованием OGNL

Проблемы безопасности OGNL

Благодаря своей способности создавать или изменять исполняемый код, OGNL способен вносить критические недостатки безопасности в любую платформу, которая его использует.[нужна цитата ] Несколько Apache Struts 2 версии были уязвимы для недостатков безопасности OGNL.[3] По состоянию на октябрь 2017 г. рекомендуемая версия Struts 2 - 2.5.13.[4] Пользователям настоятельно рекомендуется выполнить обновление до последней версии, поскольку в более старых версиях были задокументированы уязвимости безопасности - например, Struts 2 версий 2.3.5–2.3.31 и 2.5–2.5.10 позволяет удаленным злоумышленникам выполнить произвольный код.[5]

Смотрите также

внешняя ссылка

Рекомендации

  1. ^ "ognl.org", OGNL Technology, Inc, заархивировано из оригинал 25 октября 2008 г., получено 5 ноября 2013
  2. ^ «OpenSymphony, RIP (2000 - 2011)». Открытая симфония. Архивировано из оригинал 5 сентября 2013 г.. Получено 1 июня 2011.
  3. ^ «Apache Struts: список уязвимостей безопасности». cvedetails.com. Получено Второе октября, 2017.
  4. ^ «Выпуски Apache Struts». struts.apache.org. Получено Второе октября, 2017.
  5. ^ Гудин, Дэн (9 марта 2017 г.). «Критическая уязвимость при« массированной »атаке ставит под угрозу высокоэффективные сайты [Обновлено]». Ars Technica. Получено Второе октября, 2017.