2013-11-28 64 views
0

看來,會議工作時,我立即設置他們,然後他們被銷燬。 這是我的phpinfo頁面,任何人都可以看到問題? 我無權訪問phpini文件。 你可以檢查我的cookie設置並告訴我是否可以使用這些設置嗎? http://cksgrill.net/phpinfo.php即時摧毀PHP會話

[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

AFAIK增大會話超時默認情況下,你的PHP信息文件是好的。我們可以看到你的代碼嗎? –

+0

http://www.php.net/manual/en/function.session-cache-expire.php這可以幫助你設置你自己的到期時間。 –

+0

好吧,但我認爲你可以解決這個問題,只是PHP的信息,我看到cashe大小設置爲0和cokie時間設置爲0,所以我認爲這是問題,但我不知道。代碼是非常大,但生病嘗試發佈它 編輯:亞這個網站不會讓我提出代碼 – user3044508

回答

0

只需添加下面的session_start這個碼();

<?php session_start(); 
ob_start(); 
?> 
0

您可以通過使用

 session_set_cookie_params(3000); 

    Then start your session this will allow you to increase session timout you 
    don't have to edit php.ini 
+0

確定繼承人我的代碼的開始,我treid添加您的解決方案,但會話仍然在1頁加載後銷燬 [code] <! ?DOCTYPE HTML> < 在session_start(); ob_start(); 函數ini_set( '的session.gc_maxlifetime',6 * 60 * 60); $ session_expiration = time()+ 3600 * 24 * 2; session_set_cookie_params(3000); [/ code] – user3044508

+0

session_set_cookie_params(3000);然後session_start()試試這個 – rohitr

+0

是的,我試過了,我意識到發佈後我的錯誤,工作壽命。我當然希望我可以發佈更多我的代碼。 ((($ _ POST ['name'])和($ _ POST ['password']))或(($ _ POST ['name')')來設置會話變量, ']!=「」)和($ _ POST ['password']!=「」))) { \t $ _SESSION ['name'] = $ _ POST ['name']; \t $ _SESSION ['password'] = $ _ POST ['password']; – user3044508