Проблема header() и глобальных переменных

Slavik

Guest
Проблема header() и глобальных переменных

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

вот пример первого файла (auth.php):

PHP:
<?
$loginheaders = apache_request_headers();    // Recuperation des l'entetes client 

if ($loginheaders['Authorization'] == NULL) { // если заголовка авторизации нет
  header('HTTP/1.0 401 Unauthorized');   // требуем от клиента авторизации
  header('WWW-Authenticate: NTLM');      // тип требуемой авторизации - NTLM
//echo isset($loginheaders['Authorization']);
echo "first if";
  exit;                                  // завершаем выполнение скрипта
}


if($loginheaders['Authorization'] != NULL)                //dans le cas d'une authorisation (identification) 
{        

    if(substr($loginheaders['Authorization'],0,4) == 'NTLM'){   // on verifit que le client soit en NTLM 
     
        $chaine=$loginheaders['Authorization'];                   
        $chaine=substr($chaine, 5);             // recuperation du base64-encoded type1 message 
        $chained64=base64_decode($chaine);      // decodage base64 dans $chained64 
         
        if(ord($chained64{8}) == 1){                     
        //          |_ byte signifiant l'etape du processus d'identification (etape 3)       
     
        // verification du drapeau NTLM "0xb2" a l'offset 13 dans le message type-1-message : 
        if (ord($chained64[13]) != 178){ 
        echo "Votre navigateur Internet n'est pas compatible avec le NTLM, utiliser IE...Merci"; 
        exit; 
        } 
            $retAuth = "NTLMSSP";                    
            $retAuth .= chr(0);                   
            $retAuth .= chr(2); 
            $retAuth .= chr(0); 
            $retAuth .= chr(0); 
            $retAuth .= chr(0); 
            $retAuth .= chr(0); 
            $retAuth .= chr(0); 
            $retAuth .= chr(0); 
            $retAuth .= chr(0); 
            $retAuth .= chr(40); 
            $retAuth .= chr(0); 
            $retAuth .= chr(0); 
            $retAuth .= chr(0); 
            $retAuth .= chr(1); 
            $retAuth .= chr(130); 
            $retAuth .= chr(0); 
            $retAuth .= chr(0); 
            $retAuth .= chr(0); 
            $retAuth .= chr(2); 
            $retAuth .= chr(2); 
            $retAuth .= chr(2); 
            $retAuth .= chr(0); 
            $retAuth .= chr(0); 
            $retAuth .= chr(0); 
            $retAuth .= chr(0); 
            $retAuth .= chr(0); 
            $retAuth .= chr(0); 
            $retAuth .= chr(0); 
            $retAuth .= chr(0); 
            $retAuth .= chr(0); 
            $retAuth .= chr(0); 
            $retAuth .= chr(0); 
            $retAuth .= chr(0); 
             
            $retAuth64 =base64_encode($retAuth);        // encode en base64 
            $retAuth64 = trim($retAuth64);          // enleve les espaces de debut et de fin 
            header( "HTTP/1.0 401 Unauthorized" );      // envoi le nouveau header 
            header( "WWW-Authenticate: NTLM $retAuth64" );  // avec l'identification supplementaire 
            exit; 
             
        } 

        else if(ord($chained64{8}) == 3){ 
        //               |_ byte signifiant l'etape du processus d'identification (etape 5) 
     
        // on recupere le domaine 
         
//        $lenght_domain = (ord($chained64[31])*256 + ord($chained64[30])); // longueur du domain 
//        $offset_domain = (ord($chained64[33])*256 + ord($chained64[32])); // position du domain.     
//        $domain = substr($chained64, $offset_domain, $lenght_domain); // decoupage du du domain 
         
        //le login 
        $lenght_login = (ord($chained64[39])*256 + ord($chained64[38])); // longueur du login. 
        $offset_login = (ord($chained64[41])*256 + ord($chained64[40])); // position du login. 
        $myloginis = substr($chained64, $offset_login, $lenght_login); // decoupage du login 
         
        } 
    } 
} 

?>
<form method="post" action="next.php">
<input type="text" name = "Loginname" class="formboxes" value="<?echo $myloginis?>">
<input type="submit" name="buttlogin" value="далее...">
</form>
вот второго (next.php):
PHP:
<?
$Loginname=trim($Loginname);
echo "Loginname: ".$Loginname."<BR>";
echo "myloginis: ".$myloginis;
?>
на первой странице все благополучно выводится, на второй нет.

В настройках PHP глобальные переменные включены.
Конфигурация сервера:
Win2003+Apache2+PHP4

Сеть с доменом.

В ходе экспериментов выяснилось, что это происходит из-за header() в первой секции if

В чем подводный камень?
 

Фанат

oncle terrible
Команда форума
Проблема в том, что после использования скрипта переменные не передаются в последующие страницы
ты хорошо себе представляешь, что такое пхп, и как работает?
прочитай-ка вот этот текст:
PHP FAQ: Самые основы. Отличие веб-приложения от обычной программы
а после этого вынеси данный код проверки в отдельный файл и включай во все скрипты, в которых должна быть проверка пароля
 

amorfis

я стараюсь
Slavik
А вообще такие посты даже читать не хочется. Кратче надо быть.
 

Slavik

Guest
ну я же не виноват, что исходный код такой длинный
 
Сверху