On Sat, 2002-05-11 at 14:53, Phil Powell wrote:
> TCL 1, PHP 0
> 
> Ok, I am frustrated.. here is my code and this portion has to be done in
> PHP.  I have a frame that can only be accessed if 1 of 2 things occur:
> 
> 1) if $HTTP_REFERER has a specific value
> 2) if your nickname passed in the query string is found in the existing
> nicknames.txt file found in /chat/nicknames.txt
> 
> Here is the code:

Notes:

 o What version of PHP? 
 o Is register_globals on or off? i.e. are you sure $DOCUMENT_ROOT
   has a value and that you're not trying to open '/chat/nicknames.txt'?
 o Quote the 'r' in the fopen() call.
 o Try this all with error_reporting(E_ALL) and fix (not with '@') 
   everything it complains about.
 o Your second regex checks that $contents contains at least one alpha-
   numeric or an underscore or a hyphen. Looks like it should be
   checking that the string contains *only* those characters.
 o fread() takes 2 parameters, not one.
 o 'damage galore' doesn't tell us anything. What *exactly* is the 
   current result of running the below?

> <?
>  // Security measure to prevent bookmarking of page unless nickname exists
> in nicknames.txt
>  $contents = "";
>  if (!preg_match("/\bchat_process_nickname\b/i", $HTTP_REFERER)) {
>   $canAccessChatroom = 1;
>   if (strlen($nickname) < 2) $canAccessChatroom = 0;
>   if (!file_exists($DOCUMENT_ROOT . "/chat/nicknames.txt"))
> $canAccessChatroom = 0;
>   if ($canAccessChatroom == 1) {
>    $fileID = fopen($DOCUMENT_ROOT. "/chat/nicknames.txt", r) or die ("could
> not open file");
>    if (!$fileID) {
>     $canAccessChatroom = 0;
>    } else {
>     $contents = fread($fileID);
>     fclose($fileID);
>    }
>   }
>   if ($canAccessChatroom == 1 && strlen($contents) == 0) $canAccessChatroom
> = 0;
>   if ($canAccessChatroom == 1 && !preg_match("/[a-zA-Z0-9_\-]+/",
> $contents)) $canAccessChatroom == 0;
>   if ($canAccessChatroom == 1) {
>    if (!preg_match("/\b$nickname\b/i", $contents)) $canAccessChatroom == 0;
>   }
>   if ($canAccessChatroom == 0) {
>    echo "<meta http-equiv=Refresh content='1;URL=http://"; . $SERVER_NAME .
> "/chat/chat_login.php'>\n";
>    echo "<script>\n<!--\n  location.href='http://"; . $SERVER_NAME .
> "/chat/chat_login.php';\n\/\/-->\n</script>\n";
>   }
>  }
> ?>
> 
> No matter what I do, however, the file cannot be accessed if it exists and
> causes damage galore.  Can anyone out there help me figure out what I did
> wrong; I'm completely stumped and may have to rewrite this portion of the
> chatroom in TCL, all of my TCL scripts have had NO problems whatsoever
> accessing the txt files.
> 
> Phil


-- 
 Torben Wilson <[EMAIL PROTECTED]>
 http://www.thebuttlesschaps.com
 http://www.hybrid17.com
 http://www.inflatableeye.com
 +1.604.709.0506


-- 
PHP General Mailing List (http://www.php.net/)
To unsubscribe, visit: http://www.php.net/unsub.php

Reply via email to