Хобрук: Ваш путь к мастерству в программировании

ACL на основе ресурсов и ACL на основе контроллера

Традиционный подход к управлению доступом к действиям контроллера - создать ресурс (строковый идентификатор) для каждого / module / controller / action, а затем проверить ACL в подключаемом модуле контроллера.

Недавно я обнаружил очень удобный Zend_Acl_Resource_Interface, который можно использовать для управления доступом к любому классу, реализующему его. Таким образом, любая Модель, Форма или другой элемент приложения может стать ресурсом ACL. Это вполне здравый подход, потому что таким образом ресурсы приложения становятся ресурсами ACL.

С слушателями Doctrine это становится очень легко, поэтому мне вообще не нужна дополнительная логика в контроллере.

Теперь я могу проверить ACL, например. всякий раз, когда создается какая-либо форма и в конечном итоге выполняется перенаправление на страницу входа.
Но как я могу скрыть элементы навигации Zend, которые используют ограниченные формы, модели и т. д.
Нужен ли мне также традиционный подход, ориентированный на контроллер? Нужен ли мне отдельный идентификатор ресурса для каждого элемента навигации? В чем же тогда преимущество использования ACL на основе ресурсов?


Ответы:


1

Вы можете назначить соответствующий идентификатор ресурса элементам страницы Zend_Navigation, установить предопределенный ACL и текущую роль пользователя, вошедшего в систему, для экземпляра Zend_Navigation, помощник по навигации проверяет ACL перед рендерингом. См. Пример здесь http://framework.zend.com/manual/en/zend.view.helpers.html#zend.view.helpers.initial.navigation.acl.

08.10.2010
  • Спасибо, но внимательно прочтите вопрос. Рассмотрим следующую ситуацию: у меня есть страница / create с двумя формами (например, поиск и создание), их идентификаторы ресурсов seach-resource и create-resource . Какой из них использовать в навигации? Мне все еще нужно создать новый ресурс для доступа к URL ... 09.10.2010
  • Новые материалы

    Создание кнопочного меню с использованием HTML, CSS и JavaScript
    Вы будете создавать кнопочное меню, которое имеет состояние наведения, а также позволяет вам выбирать кнопку при нажатии на нее. Финальный проект можно увидеть в этом Codepen . Шаг 1..

    Внедрите OAuth в свои веб-приложения для повышения безопасности
    OAuth — это широко распространенный стандарт авторизации, который позволяет приложениям получать доступ к ресурсам от имени пользователя, не раскрывая его пароль. Это позволяет пользователям..

    Классы в JavaScript
    class является образцом java Script Object. Конструкция «class» позволяет определять классы на основе прототипов с чистым, красивым синтаксисом. // define class Human class Human {..

    Как свинг-трейдеры могут использовать ИИ для больших выигрышей
    По мере того как все больше и больше профессиональных трейдеров и активных розничных трейдеров узнают о возможностях, которые предоставляет искусственный интеллект и машинное обучение для улучшения..

    Как построить любой стол
    Я разработчик программного обеспечения. Я люблю делать вещи и всегда любил. Для меня программирование всегда было способом создавать вещи, используя только компьютер и мое воображение...

    Обзор: Машинное обучение: классификация
    Только что закончил третий курс курса 4 часть специализации по машинному обучению . Как и второй курс, он был посвящен низкоуровневой работе алгоритмов машинного обучения. Что касается..

    Разработка расширений Qlik Sense с qExt
    Использование современных инструментов веб-разработки для разработки крутых расширений Вы когда-нибудь хотели кнопку для установки переменной в приложении Qlik Sense? Когда-нибудь просили..


    © 2024 hobruk.ru, Хобрук: Ваш путь к мастерству в программировании