0

我开始在 Windows Server 2008 上使用 php 并与 MS SQL SERVER 建立数据连接。现在过去我在 apache 和 mysql 上做过。但是现在我已经改变了,我的会话变量不再起作用了。我在服务器上的会话文件中只存储了一个会话变量。虽然我在多个文件上有多个会话变量。唯一存储的行如下:

if (!isset($_SESSION["language"])){$_SESSION["language"] = 
substr($_SERVER['HTTP_ACCEPT_LANGUAGE'], 0, 2);}

在我的文件中:

语言|s:2:"nl";

当我继续登录我的应用程序时,我存储以下会话变量:

$result = sqlsrv_query($conn,$sql,$params,$options);
$numrows = sqlsrv_num_rows($result);
$row = sqlsrv_fetch_array($result);
if ($numrows > 0) {
    $_SESSION['loggedin']= TRUE;
    $_SESSION['username']= $row['username'];
    $_SESSION['name']= $row['firstname'].' '.$row['lastname'];
    $_SESSION['language']= $row['language'];
    //if ($row['admin'] == 1){$_SESSION['admin']= TRUE;}
    //if ($row['all_orders'] == 1){$_SESSION['allorders']= TRUE;}
    //if ($row['validate'] == 1){$_SESSION['validate'] = TRUE;}
    echo 'Welcome '.strtoupper(trim($_SESSION['name']));    }
else {
    echo 'Login niet correct '.$username.' '.$password; };

但是在文件中我找不到这些会话变量。它们没有存储在任何地方,因此我无法在其他页面上调用它们。任何人都有一个想法。

4

1 回答 1

1
session_start();//session_start — Start new or resume existing session 
$result = sqlsrv_query($conn,$sql,$params,$options);
$numrows = sqlsrv_num_rows($result);
$row = sqlsrv_fetch_array($result);
if ($numrows > 0) {
    $_SESSION['loggedin']= TRUE;
    $_SESSION['username']= $row['username'];
    $_SESSION['name']= $row['firstname'].' '.$row['lastname'];
    $_SESSION['language']= $row['language'];
    //if ($row['admin'] == 1){$_SESSION['admin']= TRUE;}
    //if ($row['all_orders'] == 1){$_SESSION['allorders']= TRUE;}
    //if ($row['validate'] == 1){$_SESSION['validate'] = TRUE;}
    echo 'Welcome '.strtoupper(trim($_SESSION['name']));    }
else {
    echo 'Login niet correct '.$username.' '.$password; };

如果你得到 if ($numrows > 0){ return TRUE;} 那么它一定是由于 session_start(); 您无法存储会话值。

于 2013-06-27T09:06:07.680 回答