如何解决PHP登录无法正常工作-登录后,用户仍会在受保护页面上看到登录表单
|| - - - 解决了 - - - 大家好,我现在已经解决了这个问题,正是由于我的经验不足和试图变得聪明才导致了此问题,您还可以从下面的评论中看到,问题出在我的.htaccess文件中。我放了RewriteRule ^admin adminlogin.php
,所以这会将包含admin的任何页面改回adminlogin.php
------原始问题------
我试图让一个简单的登录脚本在网站上工作。它是用php编码的,如下所示:
管理员登录:
<div class=\"login\">
<form name=\"form1\" method=\"post\" action=\"checklogin.php\">
<table width=\"379px\" border=\"0px\" cellpadding=\"3px\" cellspacing=\"1px\">
<tr>
<td colspan=\"3\"><strong>Admin Login</strong></td>
</tr>
<tr>
<td width=\"78px\">Username</td>
<td width=\"6px\">:</td>
<td width=\"294px\"><input name=\"myusername\" type=\"text\"></td>
</tr>
<tr>
<td>Password</td>
<td>:</td>
<td><input name=\"mypassword\" type=\"password\"></td>
</tr>
<tr>
<td> </td>
<td> </td>
<td><input type=\"submit\" name=\"Submit\" value=\"Login\"></td>
</tr>
</table>
</td>
</form>
</tr>
</table>
</div>
checklogin.php:
<?php
$host=\"localhost\"; // Host name
$username=\"\"; // Mysql username
$password=\"\"; // Mysql password
$db_name=\"\"; // Database name
$tbl_name=\"Logins\"; // Table name
// Connect to server and select databse.
mysql_connect(\"$host\",\"$username\",\"$password\")or die(\"cannot connect\");
mysql_select_db(\"$db_name\")or die(mysql_error());
// username and password sent from form
$myusername=$_POST[\'myusername\'];
$mypassword=$_POST[\'mypassword\'];
// To protect MySQL injection
$myusername = stripslashes($myusername);
$mypassword = stripslashes($mypassword);
$myusername = mysql_real_escape_string($myusername);
$mypassword = mysql_real_escape_string($mypassword);
$sql=\"SELECT * FROM `$tbl_name` WHERE UN=\'$myusername\' and PWD=md5(\'$mypassword\')\";
$result=mysql_query($sql);
// Mysql_num_row is counting table row
$count=mysql_num_rows($result);
// If result matched $myusername and $mypassword,table row must be 1 row
if($count==1){
// Register $myusername,$mypassword and redirect to file “adminloginsuccess.php\"
session_start();
$_SESSION[\'user\'] = $myusername;
header(\'location:adminhome.php\');
}
else {
header(\'location:adminloginretry.php\');
}
?>
adminhome.php:
<?php $thisPage=\"Admin Home\";
session_start();
if(!(isset($_SESSION[\'user\']) && $_SESSION[\'user\'] != \'\')) {
header(\"location:adminlogin.php\");
}
?>
<!DOCTYPE html PUBLIC \"-//W3C//DTD XHTML 1.0 Transitional//EN\" \"http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd\">
<html xmlns=\"http://www.w3.org/1999/xhtml\">
<head>
<?php include($_SERVER[\'DOCUMENT_ROOT\'].\'/includes/meta.php\'); ?>
</head>
<body>
<div id=\"wrapper\">
<div id=\"container\">
<div id=\"header\">
<?php include($_SERVER[\'DOCUMENT_ROOT\'].\'/includes/header.php\'); ?>
<div id=\"links\">
<?php include($_SERVER[\'DOCUMENT_ROOT\'].\'/includes/links.php\'); ?>
</div><!--close links-->
</div><!--close header-->
<div id=\"sidebar\">
<?php include($_SERVER[\'DOCUMENT_ROOT\'].\'/includes/sidebarimage.php\'); ?>
</div><!--close sidebar-->
<div id=\"content\">
<?php include($_SERVER[\'DOCUMENT_ROOT\'].\'/includes/adminhomecontent.php\'); ?>
</div><!--close content-->
<div id=\"extra\" align=\"center\">
<?php include($_SERVER[\'DOCUMENT_ROOT\'].\'/includes/fblb.php\'); ?>
</div><!--close extra-->
<div id=\"footer\">
<?php include($_SERVER[\'DOCUMENT_ROOT\'].\'/includes/footer.php\'); ?>
</div><!--close footer-->
</div><!--close container-->
</div><!--close wrapper-->
</body>
</html>
adminhomecontent.php:
You Have Successfully Logged In.<br>
<a href=\"logout.php\">Log Out </a>
现在由于某种原因,当我登录时,我被重定向了,地址栏显示为www.gemma-hyde-fashion-sketches.co.cc/adminhome.php,但仍显示登录表单,如果我查看源代码,请参阅adminlogin.php的源代码。
我是PHP的新手,可以帮助任何人,我在线上找到了此代码,所以我尝试着尽自己最大的理解。
- - - 编辑 - - -
我已经为stackoverflow用户创建了一个登录。如果您转到www.gemma-hyde-fashion-sketches.co.cc/adminlogin.php并使用用户名stackoverflow和密码stackoverflow,您应该会看到与我相同的结果(实际上,管理中没有任何内容无论如何,这时的区域)
------编辑朱达------
是的,我的意思是,如果我登录,地址栏将显示:http://www.gemma-hyde-fashion-sketches.co.cc/adminhome.php,这是我希望重定向到的地址。但是,如果我右键单击并查看源,我会看到
<!DOCTYPE html PUBLIC \"-//W3C//DTD XHTML 1.0 Transitional//EN\" \"http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd\">
<html xmlns=\"http://www.w3.org/1999/xhtml\">
<head>
<title>Gemma Hyde Fashion Sketches | Admin Login</title>
<meta name=\"title\" content=\"Gemma Hyde Fashion Sketches | Admin Login\" />
<meta name=\"keywords\" content=\"Admin Login,gemma hyde fashion sketches,fashion,fashion design,fashion sketches,fashion design sketches,clothes design sketches\" />
<meta http-equiv=\"content-type\" content=\"text/html; charset=iso-8859-1\" />
这与adminlogin.php页面显示的内容相同,这让我认为这是adminhome.php顶部的部分:
session_start();
if(!(isset($_SESSION[\'user\']) && $_SESSION[\'user\'] != \'\')) {
header(\"location:adminlogin.php\");
}
只是重定向,因为它无法获取已登录的信息。
这样清除了吗?
解决方法
在我看来,如果您能够看到文件的实际PHP,PHP就不会在该文件上运行(我可以从语句“”中了解到,如果我查看源代码,则会看到adminlogin.php \的源代码”)。 )。其他PHP页面是否可以工作(即
<?php phpinfo();?>
)?
,如果您怀疑未设置会话,请在adminhome.php中进行检查
更改此代码
Session_start();
if(!(isset($_SESSION[\'user\']) && $_SESSION[\'user\'] != \'\')) {
header(\"location:adminlogin.php\");
对此
Session_start();
exit(var_dump($_SESSION));
,我现在已经解决了这个问题,正是由于我的经验不足和尝试变得聪明才导致了此问题,正如您从下面的注释中还可以看到,问题出在我的.htaccess文件中。我放了RewriteRule ^admin adminlogin.php
,所以这会将包含admin的任何页面改回adminlogin.php
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。