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]   

> Без описания
Rooner
Отправлено: 12 Апреля, 2012 - 09:05:22
Post Id


Посетитель


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


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




Как обычно есть множество файлов с классами, с функциями, все они вызываются в различных страницах. Например есть файл catalog.php с классом каталога, он вызывается на сайте на странице categories.php. Так вот как мне запретить обращение напрямую к странице catalog.php?
 
 Top
Viper
Отправлено: 12 Апреля, 2012 - 09:20:57
Post Id



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


Покинул форум
Сообщений всего: 4555
Дата рег-ции: Февр. 2007  
Откуда: Симферополь


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




В categories.php в начале

В подключаемых файлах которые вызываются из него(catalog.php к примеру)


-----
Список фильмов с описанием, блекджеком и... для Joomla? -> https://киноархив[dot]com
Демо нового движка для сайта php.su -> php[dot]su, проект на гитхабе
 
 Top
Rooner
Отправлено: 12 Апреля, 2012 - 09:27:52
Post Id


Посетитель


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


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




Viper спасибо, очень быстро и удобно)
А зачем к переменной в начале добавляют знак подчеркивания?

(Отредактировано автором: 12 Апреля, 2012 - 09:29:15)

 
 Top
DelphinPRO
Отправлено: 12 Апреля, 2012 - 09:35:15
Post Id



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


Покинул форум
Сообщений всего: 7187
Дата рег-ции: Февр. 2012  


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




Rooner пишет:
А зачем к переменной в начале добавляют знак подчеркивания?

просто так захотелось Улыбка

в идеале хорошо вынести все файлы кроме точки входа за пределы DOCUMENT_ROOT. Тогда к ним точно доступа не будет Улыбка


-----
Чем больше узнаю, тем больше я не знаю.
 
 Top
Rooner
Отправлено: 12 Апреля, 2012 - 09:37:20
Post Id


Посетитель


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


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




И еще небольшой вопрос: обычно делают переадресацию так:

Но как в данном случае поставить exit();? или он не нужен(тогда зачем его в первом случае советуют ставить)?

Протестил по шагам данную строчку, и действительно, сначала проверяется значение переменной, потом содержимое текущей страницы(возникает ошибка), и только после этого осуществляется переадресация.

(Добавление)
DelphinPRO пишет:
в идеале хорошо вынести все файлы кроме точки входа за пределы DOCUMENT_ROOT. Тогда к ним точно доступа не будет Улыбка

Точно, только пока это не нужно(на этапе постоянной модернизации, переделывания и т.д.), да и не знаю как это делается, надо будет почитать. Пока отметил себе в план)
(Добавление)
Походу вот так правильно:
PHP:
скопировать код в буфер обмена
  1. if (!defined('CATS')) { header('Location: ../404.php'); exit(); }

(Отредактировано автором: 12 Апреля, 2012 - 09:45:08)

 
 Top
Viper
Отправлено: 12 Апреля, 2012 - 10:11:56
Post Id



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


Покинул форум
Сообщений всего: 4555
Дата рег-ции: Февр. 2007  
Откуда: Симферополь


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




Rooner пишет:
А зачем к переменной в начале добавляют знак подчеркивания?
обычно знак подчеркивания перед переменной или функцией означает что они private. Т.е. используются внутри конструкции и к ним нет доступа из вне.

PS! Это чисто для наглядности кода, но ни в коем случае не означает что php5 будет интерпретировать их как private.

Rooner пишет:
Походу вот так правильно
да.

(Отредактировано автором: 12 Апреля, 2012 - 10:12:55)



-----
Список фильмов с описанием, блекджеком и... для Joomla? -> https://киноархив[dot]com
Демо нового движка для сайта php.su -> php[dot]su, проект на гитхабе
 
 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