我无法在第二个PHP文件中检索会话变量

时间:2015-11-01 21:11:29

标签: php session

我要做的是,我有一个HTML页面,它是一个管理员登录表单。我想将用户名传递给其他页面以验证用户是否已登录,然后才被允许访问被调用页面的功能。

我将此代码放在.html文件中包含的PHP文件中:

session_start();
session_register('username');
$_SESSION['id']=10;
echo "Login session id is " .$_SESSION['id'];

unset($_SESSION['username']);
// Only process POST reqeusts.
if ($_SERVER["REQUEST_METHOD"] == "POST") 
{
    require_once 'config.inc.php';

    $connect = mysqli_connect($host_name, $user_name, $password, $database);

    if (mysqli_connect_errno())
    {
        echo "Failed to connect to MySQL: " . mysqli_connect_error();
    }
    else
    {
        $uName = $_POST['name'];
        $_SESSION['username'] = $uName;
        echo $_SESSION['username'];

.....>更多的文件,但这显示用户名就好了。

在第二个文件中,文件中带有PHP内联的.html文件:

<?php

        session_start();

        echo "Add user session id is ";
        echo "<br>";
        echo $_SESSION['id'];
        echo "<br>";
        echo "Hello";
        echo "<br>";
        echo $_SESSION['username'];
        echo "<br>";
        echo $_SESSION;
        echo "<br>";
        echo $_SESSION['time'];
        echo "<br>";
        echo date('Y m d H:i:s', $_SESSION['time']);

硬代码文字和&#34;回音日期(&#39; Y m d H:i:s&#39;,$ _SESSION [&#39; time&#39;]);&#34;显示很好。线路回波日期(&#39; Y m d H:i:s&#39;,$ _SESSION [&#39; time&#39;]);显示麦汁阵列。

任何人都可以告诉我为什么我无法获得用户名的价值吗?

2 个答案:

答案 0 :(得分:1)

你的问题就像你自己说的那样,

  

在第二个文件中,文件中带有PHP内联的.html文件:

PHP必须位于.php文件中,而不是.html文件扩展名。

修改1:

根据PHP.net

警告 自PHP 5.3.0开始,此函数已被弃用,自PHP 5.4.0起已被删除。

你应该停止使用它。

编辑2:

您也在回应$_SESSION

echo $_SESSION;
如果您的错误报告已启用且文件扩展名为array to string conversion,则应该抛出.php错误。

答案 1 :(得分:0)

这是我能提出的最简单的例子。我希望它有所帮助。

HTML

<form action="signin.php" method="post">
    Username: <input type="text" name="username"><br>
    Password: <input type="text" name="password"><br>
    <input type="submit">
</form>

PHP [signin.php]

<?php
    if($_POST['username'] == 'username') && $_POST['password'] == 'password')
    {
        session_start();
        $_SESSION['username'] = $username;
        header("location: admin.php");
    }
    else
    {
        header('location: error.php?msg=Invalid_Username';
    }
?>

PHP [error.php]

<?php
    $msg = '';
    if(isset($_GET['msg']))
    {
         if($_GET['msg'] == "Invalid_Username")
         {
            $msg = "Your username or password didn't match.";
        }
        else if($_GET['msg'] == "Invalid_Access")
        {
            $msg = 'You are not allowed on that page.';
        }
    }
    else
    {
        $msg = 'Unknown Error';
    }
?>
<html>
    <body>
        <h1>ERROR</h1>
        <p><?php echo $msg;?></p>
    </body>
</html>

PHP [admin.php]

<?php
    session_start();
    if($_SESSION['username'])
    {
       echo 'your signed in';
    }
    else
    {
        header('location: error.php?msg=Invalid_Access');
    }
?>