2

我在 php 中创建了一个带有会话的简单登录页面,它在我的 LAMP 上运行良好。但是今天我不小心将我的 /var 目录的权限更改为 chmod 777 /var 之类的东西,尽管我将其权限改回了 chmod 755 /var 。但是现在当我再次尝试访问我的登录页面时,我无法登录。再次浏览代码时,我发现我的 SESSION 变量在传输到不同页面时没有保留其数据。我在每个页面(在页面顶部)都使用 session_start() ,而且我检查了 session_id() ,它在每个页面中都是相同的。我在 linux 环境(Ubuntu 12.04)中使用 Apache 和 Mysql。我的程序代码:

index2.php:

<?php 
session_start();

if(isset($_SESSION['username'])) 
{
header('Location: securepage.php');
}
?>

<html>
<head>
    <title>Secure LOGIN</title>
</head> 
<body>
    <h2>User Login </h2>
    <form method="POST" action="login.php">
        <br>UserName : <input type= "text" name="username">
        <br>Password : <input type="password" name="password">
        <br><input type="submit" value="Login">
    </form>

</body>
</html>

登录.php:

<?php
session_start();
include('load.php');
$obj = new load();
$conn = $obj-> connect();

if(!conn)
{
exit('Connection cannot be established');

}

mysqli_select_db($conn,'login') or die('Cannot be established');
$query = "SELECT * FROM users WHERE uname='".$_POST['username']."' and pass =  '".md5($_POST['password'])."';";

$login = mysqli_query($conn,$query);


if(mysqli_num_rows($login) == 1)
{
$_SESSION['username'] = $_POST['username'];
 header('Location: securepage.php');
}
else
{
header('Location: index2.php');
}

?>

安全页面.php:

<?php

session_start();


if (!isset($_SESSION['username'])) {
header('Location: index2.php');
}

?>
<html>

<head>
<title>Secured Page</title>
</head>

<body>

<p>This is secured page with session: <b><?php echo $_SESSION['username']; ?></b>
<br>You can put your restricted information here.</p>
</body>

</html>

echo $_SESSION['username']上,在 login.php 中的 if(mysqli_num_rows) 语句之后,它正确显示了username的值,但是在 securepage.php 中的print_r($_SESSION)上,它显示了一个空数组。这段代码直到昨天都运行良好,我不知道为什么它现在不起作用。
我什至创建了两个简单的测试页面来检查我的 SESSION 变量,但即使这样也不起作用。尽管 $_SESSION 中的值已设置,但它不会转移到第二页。我没有触及我的 LAMP 的任何配置设置。

我的 phpinfo() 截图
var direcroty 的权限

请告诉我哪里出错了。

我的error.log内容:

PHP Warning:  session_start(): open(/var/lib/php5/sess_mm4ja22k9n0r4gv512imc07ur0, O_RDWR) failed: Permission denied (13) in /var/www/public/index2.php on line 2, referer: http://localhost/index2.php

PHP Warning:  Unknown: open(/var/lib/php5/sess_mm4ja22k9n0r4gv512imc07ur0, O_RDWR) failed: Permission denied (13) in Unknown on line 0, referer: http://localhost/index2.php

PHP Warning:  Unknown: Failed to write session data (files). Please verify that the current setting of session.save_path is correct (/var/lib/php5) in Unknown on line 0, referer: http://localhost/index2.php
4

3 回答 3

0

这只是一个建议,因为我不确定是什么导致了问题。我犯了一个类似的权限相关错误,导致我的所有脚本都无法正常工作,而没有任何错误被登录/var/log/apache2/error.log。我做了以下事情来解决这个问题:

(在终端)

:$ chmod 775 -R /var/www
:$ chown <user-name>:www-data -R /var/www

请注意,sudo如果您不是root用户,则必须预先添加。

希望这可以帮助!

于 2013-03-31T09:08:08.350 回答
0

你提到你做了chmod 777然后回到755目录/var(甚至可能是子目录)。你的问题是在那之后开始的,所以它似乎是一个权限问题。

/var目录包含www/包含您的 Web 文档的文件夹,但也包含其他文件夹(logtmp等),如您的屏幕截图所示。您知道您的 php 配置 (php.ini) 将您的 php 会话文件保存在哪里吗?检查session.save_path行只是为了确定。

默认是/tmp,但也许你正在使用/var/tmpor /var/lib/php5。问题是,该/var/tmp文件夹是chmod 777默认的,所以你可以恢复到那个文件夹。

祝你好运 !

于 2013-03-31T09:47:59.873 回答
0

感谢您提供有用的建议。发现我的/var/lib没有组写入权限。使用以下方法解决了问题:

须藤 chmod 775 -R /var/lib

谢谢

于 2013-03-31T09:48:23.447 回答