Logo Море(!) аналитической информации!
IT-консалтинг Software Engineering Программирование СУБД Безопасность Internet Сети Операционные системы Hardware
Архив форумов ЦИТФорума
Море(!) вопросов - Море(!) ответов
 
 FAQFAQ   ПоискПоиск   ПользователиПользователи   ГруппыГруппы   РегистрацияРегистрация 
 ПрофильПрофиль   Войти и проверить личные сообщенияВойти и проверить личные сообщения   ВходВход 
Как правильно задавать вопросы

Не могу понять авторизацию HTTP в PHP...

 
Перейти:  
Этот форум закрыт, вы не можете писать новые сообщения и редактировать старые.   Эта тема закрыта, вы не можете писать ответы и редактировать сообщения.    Список форумов Архив форумов ЦИТФорума -> Программирование
Предыдущая тема :: Следующая тема  
Автор Сообщение
Pingvinenok



Зарегистрирован: 30.06.2005
Сообщения: 171

СообщениеДобавлено: Пн Июл 04 2005 07:17    Заголовок сообщения: Не могу понять авторизацию HTTP в PHP... Ответить с цитатой

Всем добрый день!
Есть web-интерфейс на PHP к некой проге под Linux.
В каждом скрипте прописано:
require('lib/auth.php');
Содержимое lib/auth.php:
$auth = 0;

if (isset($_SERVER['PHP_AUTH_USER'], $_SERVER['PHP_AUTH_PW'])) $auth = User::Auth($_SERVER['PHP_AUTH_USER'], $_SERVER['PHP_AUTH_PW']);

if (! $auth) {
header('WWW-Authenticate: Basic realm="--- squidlog ---"');
header('HTTP/1.0 401 Unauthorized');
exit;
}

Создал в конфиге апача соттвет. Directory, где определил доступ и правила авторизации, завел юзера\пароль.
Теперь при открытии index.php апач заставляет авторизоваться, авторизуюсь успешно, но при запуске каждого скрипта опять требует авторизоваться. Как побороть?
.htaccess не использую. Может, из-за этого?
Вернуться к началу
Посмотреть профиль Отправить личное сообщение
Ehri



Зарегистрирован: 01.07.2005
Сообщения: 9

СообщениеДобавлено: Пн Июл 04 2005 12:59    Заголовок сообщения: Ответить с цитатой

В начале каждого скрипта Вы устанавливаете значение $auth на нуль. Это приводит к тому, что процесс авторизации запускается каждый раз.

Переменная $auth должна иметь два значения: соответствующее состоянии не-авторизации(например, "нуль") и авторизации(например, "единица"). Я бы сделал так:
Код:
 if( !isset($auth) or $auth == "0")
  {
  Запускается процесс авторизации, и если пользователь передаёт правильные данные, то ставится кукис на переменную $auth со значением "единица"
  }
 elseif( $auth == "1")
  {
  Сеанс без авторизации
  }

Этот способ достаточно универсален и при определённой модификации может использоваться практически при любой веб-авторизации.
Вернуться к началу
Посмотреть профиль Отправить личное сообщение
Pingvinenok



Зарегистрирован: 30.06.2005
Сообщения: 171

СообщениеДобавлено: Вт Июл 05 2005 11:59    Заголовок сообщения: Ответить с цитатой

Спасибо за ответ.
Пожалуйста, поправьте, где я не прав:

Проблема заключалась в том, что, начиная с PHP 4.3.0 переменные PHP_AUTH не устанавливаются.
Но, можно пользоваться переменной REMOTE_USER.
Далее, при вызове аутентификации из скрипта, необходимо в скрипте же проверять валидность юзера, т.е это уже не Апач (как при первом доступе к index.php) производит? Вот этот момент для меня важен!

В итоге я сделал так
/lib/auth.php

if (! isset($_SERVER['REMOTE_USER']) {

header('HTTP/1.0 401 Unauthorized');
exit;
}
т.е. пусть апач авторизует согласно <Directory>, а мы потом просто проверим, не пустое ли REMOTE_USER.
Нормально ли так делать?

З.Ы. Епрст, как все сложно-то!
Это со всеми линуксовыми прогами так? Или все-таки есть такие, что юзаются без становления програмером на PHP, C, etc Sad
Вернуться к началу
Посмотреть профиль Отправить личное сообщение
Показать сообщения:   
Этот форум закрыт, вы не можете писать новые сообщения и редактировать старые.   Эта тема закрыта, вы не можете писать ответы и редактировать сообщения.    Список форумов Архив форумов ЦИТФорума -> Программирование Часовой пояс: GMT + 3
Страница 1 из 1

 
Перейти:  
Вы не можете начинать темы
Вы не можете отвечать на сообщения
Вы не можете редактировать свои сообщения
Вы не можете удалять свои сообщения
Вы не можете голосовать в опросах


Powered by phpBB © 2001, 2002 phpBB Group
Русская поддержка phpBB

 

IT-консалтинг Software Engineering Программирование СУБД Безопасность Internet Сети Операционные системы Hardware

Информация для рекламодателей PR-акции, размещение рекламы — adv@citforum.ru,
тел. +7 495 6608306, ICQ 232284597
Пресс-релизы — pr@citforum.ru
Послать комментарий
Информация для авторов
This Web server launched on February 24, 1997
Copyright © 1997-2000 CIT, © 2001-2006 CIT Forum
Внимание! Любой из материалов, опубликованных на этом сервере, не может быть воспроизведен в какой бы то ни было форме и какими бы то ни было средствами без письменного разрешения владельцев авторских прав. Подробнее...