我已经挣扎了几个小时,但我无法让它发挥作用。当我重定向到另一个PHP页面时,我的所有会话变量都为null。我在xampp服务器上。
session.php文件
<?php
session_start();
if(isset($_POST['submitted']))
{
$_SESSION['first_name'] = "MAX";
var_dump($_SESSION);
header("Location: http://localhost:8080/secure login/session2.php");
die();
}
?>
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd">
<html xmlns="http://www.w3.org/1999/xhtml" lang="en" xml:lang="en">
<head> <meta http-equiv="Content-Type" content="text/html; charset=ISO-8859- 1" />
<title>You Logged In</title>
</head>
<body>
<form action="session.php" method="post">
<div align="center"><input type="submit" name="submit" value="Login" /></div>
<input type="hidden" name="submitted" value="TRUE" />
</form>
</body>
</html>
session2.php
<?php
session_start();
?>
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd">
<html xmlns="http://www.w3.org/1999/xhtml" lang="en" xml:lang="en">
<head> <meta http-equiv="Content-Type" content="text/html; charset=ISO-8859-1" />
<title>You Logged In</title>
</head>
<body>
<div id="main">
<?php
echo '<pre>' . print_r($_SESSION, TRUE) . '</pre>';
echo 'You are welcome to session2.php <br></br>';
if (isset($_SESSION['first_name']))
{
echo $_SESSION['first_name'] . "<br></br>";
}
else
{
echo "Your session doesn't exist. I hate php <br></br>";
echo $_SESSION['first_name'];
}
?>
</div>
</body>
</html>
会话无法保存,输出为;
Array
(
)
You are welcome to session2.php
Your session doesn't exist. I hate php
Notice: Undefined index: first_name in C:\xampp\htdocs\secure login\session2.php on line 28
我尝试过其他一些事情,例如将会话变量从xampp / tmp保存到另一个目录,但这并没有解决问题。我有一个程序,当我进行重定向时,我需要让用户登录,但这已经阻止了我超过一天。
更新:
目录之间的空间不是问题,它暂时解决了问题,但那是因为新目录还没有缓存。无论如何,再过几天,我调试并意识到我在我的localhost上运行了两个程序。两者都使用会话,因此如果终止会话,它也会终止另一个会话,因为localhost就像一个域名,并且只存在一个会话。特别是,我的其他程序的logout.php并没有破坏会话,而是因为你必须删除浏览器缓存而不是它的混乱。我正在清空会话数组,破坏会话,破坏cookie,这就是问题所以我无法再次登录。我所要做的就是只破坏会话;
参见 - &gt; Killing off Global Session Variable as a logout button
答案 0 :(得分:3)
因为您有一个名为secure login
localhost:8080/secure%20login/session.php
因此,请尝试使用下划线secure_login
更改名称,并更改代码
<?php
session_start();
if(isset($_POST['submitted']))
{
$_SESSION['first_name'] = "MAX";
var_dump($_SESSION);
header("Location: http://localhost:8080/secure_login/session2.php");
die();
}
?>
答案 1 :(得分:2)
很可能是由于die()
调用,我认为这导致它不会写会话。
在此之前尝试session_write_close();
。
答案 2 :(得分:2)
更改此
<?php
session_start();
if(isset($_POST['submitted']))
{
$user = $_SESSION['first_name'] = "MAX";
if(isset($user))
{
header("Location: http://localhost:8080/secure login/session2.php");
}
else
{
header("Location: ");//index page
}
}
?>
在$user = $_SESSION['first_name'] = "MAX";
首先执行$_SESSION['first_name'] = "MAX";
,然后将结果分配给$user
。所以在isset($user)
中检查是否设置
答案 3 :(得分:2)
首先,在<?php
和session.php
文件中启动session2.php
标记之前,请检查是否有空格。
从var_dump($_SESSION);
删除session.php
。
并将文件夹名称更改为secure_login