我为用户编写了自定义登录脚本,以登录主控制页面。我发现即使用户没有登录,他们仍然可以访问我希望有人帮我编写限制访问页面()的主要控件。
请查看我的php登录脚本,并根据该代码帮助我写限制访问主控制页面。假设我的主要crontrol页面是:cecontrolpage.php
我知道我们使用$ _SESSION,但我对它一无所知。
这是我的login.php代码,工作正常:
<?php
Session_start();
$Email = $_POST["email"];
$Password = $_POST["password"];
$cn = "localhost";
$db_username = "root";
$pas = "***";
$db_name = "cemembers";
//Open a connection to a MySQL Server
if ($Email && $Password) {
$connect = mysqli_connect($cn, $db_username, $pas, $db_name) or die("Could not connect to database");
//sending MySqli query
$query = mysqli_query($connect, "SELECT * FROM users WHERE Email= '$Email'");
$numrows = mysqli_num_rows($query);
//After PHP declaration we are going to create index file[form]
if ($numrows !== 0) {
while ($row = mysqli_fetch_array($query)) {
$dbEmail = $row["Email"];
$dbPassword = $row["Password"];
}
if ($Email == $dbEmail && $Password == $dbPassword) {
header("location:ce membership birthday system control_pannel.php");
@$_SESSION("Email") == $Email;
} else
header("location:index.php?login_attempt=1");
} else
header("location:index.php?login_attempt=2");
} else
header("Location:index.php?login_attempt=0");
?>
请有人帮我写php代码来限制访问cecontrol.php ??
请逐步使用每个部分的php评论。
答案 0 :(得分:3)
首先,您需要检查用户是否已登录: 你通过检查会话是否已经设置来做到这一点。
//Check if the user is logged in
function userlogged_in()
{
return(isset($_SESSION['userid']))?true:false;
}
然后,您需要将用户重定向到一个页面,该页面表明访问权限未经授权,他们需要登录才能查看该页面:
您可以通过检查userlogged_in函数是否返回true或false
来执行此操作function user_restricted()
{
if (userlogged_in()=== false)
{
header('Location: permission.php ');
exit();
}
}
然后你需要在开始会话后在每个页面上调用user_restricted()函数。
答案 1 :(得分:0)
首先,你需要在数据库认证后的会话中保存用户值,如
$_SESSION['username'] = "name";
$_SESSION['user_id'] = 1;
function check_session() {
session_start();
if ($_SESSION['user_id']=='')
{
// redirect to login
}
}
在您要限制访问的每个页面上,您都可以致电check_session()
。