【发布时间】:2011-11-25 16:58:22
【问题描述】:
我正在为我的网站开发一个简单的登录和注销模块,没有任何安全措施。我在 windows xp 机器上使用 wamp。当用户提交登录信息时,我正在创建会话,它将重定向到 process.php 文件,该文件创建会话变量并启动会话。现在,如果登录成功,用户将被重定向到包含头文件的欢迎页面(显示涉及登录注销帮助选项的标题)问题是当用户成功登录时,标题没有将登录链接更改为注销。下面的代码来自 process.php,它启动了一个登录。
$username = $_POST['username'];
$password = $_POST['password'];
//echo "{$username}:{$password}";
$connection = mysql_connect("localhost","root","");
if(!$connection)
{
die("Database Connection Failed".mysql_error());
}
$db_select = mysql_select_db("tester",$connection);
if(!$db_select)
{
die("Database Selection Failed".mysql_error());
}
$result = mysql_query("SELECT * FROM user",$connection);
if(!$result)
{
die("Database Selection Failed".mysql_error());
}
$q = "SELECT * FROM user " ."WHERE Name='".$username."' AND Password='".$password. "' ";
// Run query
$r = mysql_query($q);
if ( $obj = @mysql_fetch_object($r) )
{
session_start();
// Login good, create session variables
$_SESSION["valid_id"] = session_id();
$_SESSION["valid_user"] = $_POST["username"];
$_SESSION["valid_time"] = time();
Header('Location: welcome.php');
以下代码来自welcome.php中包含的header.php
</div>
<div id = "userdetail">
<?php
if(isset($_SESSION["valid_user"]))
{
echo($_SESSION["valid_user"]." " );
echo("<a href=logout.php>Logout</a>");
}
else
{
echo("<a href = login.php>Sign In</a>");
}
?>
| Help | Search
<input type = "text" name = "searchbox" value = "" />
</div>
</div>
【问题讨论】:
-
您的示例代码包含 sql 注入错误。 $q = "SELECT * FROM user " ."WHERE Name='".$username."' AND Password='".$password. "'";您必须转义参数名称和密码!