2013-11-28 5 views
-2

Это сообщение, потому что я понял, как опубликовать мой код. пожалуйста, не сердитесь на админов! Кажется, что сеансы работают, когда я устанавливаю их на мгновение, а затем они уничтожаются. Вот моя страница phpinfo, может ли кто-нибудь увидеть проблему? У меня нет доступа к файлу phpini. Можете ли вы проверить настройки моего файла cookie и сказать, могу ли я использовать их вместо этого? http://cksgrill.net/phpinfo.phpсеансы instanly уничтожены после загрузки одной страницы

[code] 

<!DOCTYPE html> 
<script src="/javascript/header.js"></script> 
<? 

session_set_cookie_params(3000); 
session_start(); 
ob_start(); 
ini_set('session.gc_maxlifetime', 6 * 60 * 60); 
$session_expiration = time() + 3600 * 24 * 2; 
if((($_POST['name'])and($_POST['password']))or(($_POST['name']!="")and($_POST['password']!=""))) 
{ 
    $_SESSION['name']=$_POST['name']; 
    $_SESSION['password']=$_POST['password']; 
    echo $_SESSION['name']; 
    echo $_POST['name']; 
    echo $_SESSION['password']; 
    echo $_POST['password']; 
} 


// redifine variables for different server 
require_once "mysqlconfig.php"; 
require_once "textprep.php"; 

// connect to database 
global $connection; 
$connection = mysql_connect(DB_SERVER,DB_USER,DB_PASS); 
if (!$connection) 
{ 
    die("Database connection failed: " . mysql_error()); 
} 

// select database 
$db_select = mysql_select_db(DB_NAME,$connection); 
if (!$db_select) 
{ 
    die("Database selection failed: " . mysql_error()); 
} 

//check if logged in 
$result = mysql_query("SELECT * FROM admin"); 
if (!$result) 
{ 
    die("Database query failed: " . mysql_error()); 
} 

// get table names as mysql feedback 
$i=0; 
while ($row = mysql_fetch_array($result)) 
{ 
    $name[$i]=$row['name']; 
    $password[$i]=$row['password']; 
    $rank[$i]=$row['rank']; 

    //echo "\$name[$i]=".$row['name']; 
    //echo "\$password[$i]=".$row['password']; 
    //echo "\$rank[$i]=".$row['rank']; 

    $i++; 
} 

//check if logged in 
$log=false; 
for($j=0;$j<$i;$j++) 
{ 
    //echo "<p>(".$name[$j]."==".$_SESSION['name'].")and(".$password[$j]."==".$_SESSION['password'].")</p>"; 
    if(($name[$j]==$_SESSION['name'])and($password[$j]==$_SESSION['password'])) 
    { 
     $log=true; 
     echo logged." ".$log; 
    } 
} 
if($log==true) 
{ 
[/code] 
+0

'session_start(); 'должен быть перед любым выходом – bansi

+0

' session.gc_maxlifetime' не является хорошим way.You можете найти больше на этом посту http://stackoverflow.com/questions/520237/how-do-i-expire-a-php-session-after-30-minutes?lq=1 –

+0

Вы просили это всего 40 минут назад. Спам [так] с тем же вопросом даст вам вопрос запрета. См. [Справочный центр] (http://stackoverflow.com/help/no-one-answers) –

ответ

0

Вы должны начать сеанс, прежде чем что-нибудь выход

session_start(); 
+0

кто-то на этом сайте сказал мне установить параметры сеанса cookie перед началом сеанса. он сказал мне это дважды – user3044508

+0

http://stackoverflow.com/questions/20172009/best-practice-start-session-handling-before-or-after-post-data-has-been-checked – tinybyte

+0

http: // stackoverflow. com/questions/8711282/session-start-works-after-output-being-sent – tinybyte

Смежные вопросы