我的注册页面和登录表单工作正常。如果任何成员注册然后登录,用户来到member.php页面。会员页面有他们的个人资料信息,仅供会员使用。现在我想创建一个管理员登录,管理员将重定向到admin.php页面。此页面包含所有信息 喜欢: 关于有多少用户注册(完成) 所有其他管理任务(完成)
我已经完成了我的管理页面,但我不知道如何授权管理员登录和密码,如果我使用它然后它将带我到管理区域。
这是我的登录表单代码
<form id="loginForm" name="loginForm" method="post" action="login-exec.php">
<table width="700" border="0" align="center" cellpadding="2" cellspacing="0">
<tr>
<td width="112"><b>User id (Email-id)</b></td>
<td width="188"><input name="user_email" type="text" class="textfield" id="login" /></td>
</tr>
<tr>
<td><b>Password</b></td>
<td><input name="password" type="password" class="textfield" id="password" /></td>
</tr>
<tr>
<td> </td>
<td><input type="submit" name="Submit" value="Login" /></td>
</tr>
</table>
</form>
</body>
</html>
login-exec.php的代码
<?php
//Start session
session_start();
//Include database connection details
require_once('config.php');
//Array to store validation errors
$errmsg_arr = array();
//Validation error flag
$errflag = false;
//Connect to mysql server
//Select database
----something----
//Function to sanitize values received from the form. Prevents SQL injection
function clean($str) {
$str = @trim($str);
if(get_magic_quotes_gpc()) {
$str = stripslashes($str);
}
return mysql_real_escape_string($str);
}
//Sanitize the POST values
$user_email = clean($_POST['user_email']);
$pwd = clean($_POST['password']);
//Input Validations
if($user_email == '') {
$errmsg_arr[] = 'Login ID missing';
$errflag = true;
}
if($pwd == '') {
$errmsg_arr[] = 'Password missing';
$errflag = true;
}
//If there are input validations, redirect back to the login form
if($errflag) {
$_SESSION['ERRMSG_ARR'] = $errmsg_arr;
session_write_close();
header("location: login-form.php");
exit();
}
//Create query
$qry="SELECT * FROM customer WHERE user_email='$user_email' AND password='$pwd' ";
if ($user_email= )
$result=mysql_query($qry);
//Check whether the query was successful or not
if($result) {
if(mysql_num_rows($result) == 1) {
//Login Successful
session_regenerate_id();
$customer = mysql_fetch_assoc($result);
$_SESSION['SESS_id'] = $customer['id'];
$_SESSION['SESS_fname'] = $customer['first_name'];
$_SESSION['SESS_lname'] = $customer['last_name'];
session_write_close();
header("location: member-index.php");
exit();
}else {
//Login failed
header("location: login-failed.php");
exit();
}
}else {
die("Query failed");
}
?>
答案 0 :(得分:3)
您可以在数据库中为所有成员添加一个额外字段,包括admin以设置用户权限以存储用户权限。 如果该字段是admin,那么如果该用户是成员,则可以拥有该用户的管理区域,而不是成员区域。
答案 1 :(得分:1)
您可以拥有数据库索引的额外部分来分类权限IE:像“级别”权限,然后检查该级别。 AKA:如果级别高于3或某事,允许访问自动访问管理员页面。
答案 2 :(得分:1)
所以要重新解决这个问题,你已经从某个地方抓取代码(这里可能是:http://www.phpfreaks.com/forums/index.php?topic=314604),现在你想改变它的行为以允许管理员用户。我最好的建议是先了解您使用的代码。
查找行header("Location: member-index.php");
,该行是将用户重定向到成员索引页面的行。由于您已表明不希望使用数据库字段正确执行此操作,因此可以对$ user_email的值进行硬编码测试;如果是admin @ blah,则可以设置一个特殊的Session变量,例如'SESS_isadmin',然后重定向到另一个页面。该新页面可以测试'SESS_isadmin'值以确保用户已登录;如果不是,您可以将它们重定向到登录页面。
实际上没有为您编写代码,因为它获得了“用户级”。 :)
提醒一句:不要使用这种方法来编码实际的生产级代码;通过这种方式学习编程语言很好,但是在将这些东西放到野外之前还有很多事情需要考虑。