Назначение пользователю возможности читать статью в Laravel - разрешения на основе статьи

Как лучше всего дать нескольким пользователям возможность читать статью с помощью laravel?

Я использую массив в базе данных, содержащий все разрешения (на основе user_id), например:

id | user_id_permission
1  | {1,37,44}
2  | {34}

Затем я проверяю, находится ли текущий идентификатор пользователя в массиве в ArticleController.php в функции показать (ID статьи $). Если это не так, он перенаправляется на панель управления.

Мне было интересно, есть ли другой способ спроектировать это, используя ворота Laravel или какой-либо тип аутентификации.

Спасибо!

Стоит ли изучать PHP в 2026-2027 годах?
Стоит ли изучать PHP в 2026-2027 годах?
Привет всем, сегодня я хочу высказать свои соображения по поводу вопроса, который я уже много раз получал в своем сообществе: "Стоит ли изучать PHP в...
Symfony Station Communiqué - 7 июля 2023 г
Symfony Station Communiqué - 7 июля 2023 г
Это коммюнике первоначально появилось на Symfony Station .
Оживление вашего приложения Laravel: Понимание режима обслуживания
Оживление вашего приложения Laravel: Понимание режима обслуживания
Здравствуйте, разработчики! В сегодняшней статье мы рассмотрим важный аспект управления приложениями, который часто упускается из виду в суете...
Установка и настройка Nginx и PHP на Ubuntu-сервере
Установка и настройка Nginx и PHP на Ubuntu-сервере
В этот раз я сделаю руководство по установке и настройке nginx и php на Ubuntu OS.
Коллекции в Laravel более простым способом
Коллекции в Laravel более простым способом
Привет, читатели, сегодня мы узнаем о коллекциях. В Laravel коллекции - это способ манипулировать массивами и играть с массивами данных. Благодаря...
Как установить PHP на Mac
Как установить PHP на Mac
PHP - это популярный язык программирования, который используется для разработки веб-приложений. Если вы используете Mac и хотите разрабатывать...
0
0
31
1
Перейти к ответу Данный вопрос помечен как решенный

Ответы 1

Ответ принят как подходящий

Это против нормализации БД. Я бы не стал использовать такое поле в вашей таблице, но использовал бы таблицу отношений, которая связывает N статей с N пользователями.

article_user_access

 id_article | id_user 
------------+--------
 1          | 1
 1          | 37
 1          | 44
 2          | 34

Так будет проще выполнять запросы для получения списка пользователей, имеющих доступ к статье X, или статей, к которым имеет доступ пользователь Y.

Будет проще поддерживать, о добавлении и удалении прав доступа

Большое спасибо, Сид, за то, что открыл мне глаза на такой подход. Намного лучше!

Diogo Pinto 10.12.2018 15:29

Другие вопросы по теме