未定义索引:用户注销时用户名错误

Undefined index: username error when user has logged out

这是我的 index.php 代码的一部分,它打印当前用户登录 $SESSION。但是,当用户单击注销时,它会在第 x 行显示一条错误消息,指出 "Undefined index: username"。 这是什么意思,我该如何解决?

 <?php

  $dbname = 'lw17894'; # Change to your username
  $dbuser = 'lw17894';
  $dbpass = 'obscure';
  $dbhost = 'localhost';

  $link = mysqli_connect( $dbhost, $dbuser, $dbpass )
  or die( "Unable to Connect to '$dbhost'" );

  mysqli_select_db( $link, $dbname )
  or die("Could not open the db '$dbname'");


    if($_SESSION['username']) {
        echo "Welcome, User: {$_SESSION['username']}";
    } else {
        echo "User not logged in!";
    }
    ?>

这是我的 logout.php 代码:

<?php
session_start()
?>
<!DOCTYPE html>
<html>
<body>

<?php
session_unset(); 
session_destroy();
echo "<h1>You are logged out!</h1>";
echo "<br>";
echo "<h2><strong>You will be redirected back to Home in 3 seconds</strong></h2>";
?>
<meta http-equiv="refresh" content="3;URL=index.php" />
</body>
</html>

当用户未登录时,您仍在检查会话变量中的用户名密钥。

检查是否有session,session中是否存在用户名密钥,如下所示

  $dbname = 'lw17894'; # Change to your username
  $dbuser = 'lw17894';
  $dbpass = 'obscure';
  $dbhost = 'localhost';

  $link = mysqli_connect( $dbhost, $dbuser, $dbpass )
  or die( "Unable to Connect to '$dbhost'" );

  mysqli_select_db( $link, $dbname )
  or die("Could not open the db '$dbname'");

    if (session_status() != PHP_SESSION_NONE) {
        if(array_key_exists ('username' , $_SESSION ) {
            echo "Welcome, User: {$_SESSION['username']}";
        } else {
            echo "User not logged in!";
        }
    }

由于会话正在被破坏,请尝试在 if 语句中使用 isset($_SESSION) && isset($_SESSION['username'])。