Warning: Cannot use a scalar value as an array in /home/admin/public_html/forum/include/fm.class.php on line 757

Warning: Invalid argument supplied for foreach() in /home/admin/public_html/forum/include/fm.class.php on line 770

Warning: Invalid argument supplied for foreach() in /home/admin/public_html/forum/topic.php on line 737
Форумы портала PHP.SU :: Запрет доступа к методам класса

 PHP.SU

Программирование на PHP, MySQL и другие веб-технологии
PHP.SU Портал     На главную страницу форума Главная     Помощь Помощь     Поиск Поиск     Поиск Яндекс Поиск Яндекс     Вакансии  Пользователи Пользователи


 Страниц (1): [1]   

> Без описания
iflight
Отправлено: 31 Июля, 2011 - 21:51:13
Post Id



Гость


Покинул форум
Сообщений всего: 119
Дата рег-ции: Март 2011  
Откуда: Россия, Сыктывкар


Помог: 2 раз(а)




Есть класс, с помощью которого организованна админ панель. Авторизация на сайте организована с помощью сессий.
Нужно запретить доступ, а точнее отдавать 403 ошибку, если клиент не автоизован или его права не админские.
Проверить на авторизованность и права доступа можно в __construct'е, а каким образом организовать ответ всех методов класса в данном случае?
 
 Top
White
Отправлено: 31 Июля, 2011 - 22:05:42
Post Id



Частый посетитель


Покинул форум
Сообщений всего: 830
Дата рег-ции: Июнь 2011  
Откуда: Днепропетровск


Помог: 28 раз(а)




если я вас понял правильно, то в класс добавляем

в конструктор:
PHP:
скопировать код в буфер обмена
  1. if(условие авторизации) self::$deny=false;

а в методы в начале:
PHP:
скопировать код в буфер обмена
  1. if(self::$deny) die('403 Access denied');


-----
if(time()>1356048000) die();
 
 Top
LIME
Отправлено: 31 Июля, 2011 - 22:07:10
Post Id


Активный участник


Покинул форум
Сообщений всего: 10732
Дата рег-ции: Нояб. 2010  


Помог: 322 раз(а)




может проверять вне класса и создавать объект или нет в зависимости от итога?
 
 Top
iflight
Отправлено: 31 Июля, 2011 - 22:17:30
Post Id



Гость


Покинул форум
Сообщений всего: 119
Дата рег-ции: Март 2011  
Откуда: Россия, Сыктывкар


Помог: 2 раз(а)




White Спасибо. Черт все элементарно, надо ж было самому не додуматься %)
LIME В принципе можно и до, но уже пошел по этой дорожке. Такая проверка только на админке нужна, думаю логичней только там проверять, чем при любом запросе?

(Отредактировано автором: 31 Июля, 2011 - 22:20:55)

 
 Top
LIME
Отправлено: 31 Июля, 2011 - 22:22:24
Post Id


Активный участник


Покинул форум
Сообщений всего: 10732
Дата рег-ции: Нояб. 2010  


Помог: 322 раз(а)




iflight да не...
если авторизован создается 1 класс если нет то другой
оба наследуют какойто абстрактный класс ...1 переопределяет методы на запрет
и проверять в методах ненадо
короче патерн стратегия
ну тут вам виднее
 
 Top
Страниц (1): [1]
Сейчас эту тему просматривают: 0 (гостей: 0, зарегистрированных: 0)
« Объектно-ориентированное программирование »


Все гости форума могут просматривать этот раздел.
Только зарегистрированные пользователи могут создавать новые темы в этом разделе.
Только зарегистрированные пользователи могут отвечать на сообщения в этом разделе.
 



Powered by PHP  Powered By MySQL  Powered by Nginx  Valid CSS  RSS

 
Powered by ExBB FM 1.0 RC1. InvisionExBB