html/php登录页面(基于索引页面的登录自动登录到第二个页面)


html/php login pages (automatic login to second page based in login of index page)

我有两页。两页都有身份验证表单。我希望第二个页面在成功登录第一个页面(索引)时自动登录。

我该怎么做?我应该使用单一登录吗?如果是,在这种情况下如何使用单一登录?

通常应该有一个单独的登录表单和机制。如果需要,应检查其他页面的身份验证。以下是的基本机制

loginform.php

<?php
session_start();
if(isset($_SESSION['usr']))){
    if(!is_null($_SESSION['usr']) || $_SESSION['usr'] != ''){ 
    header('Location: yourpage.php');
    }
}
?>
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.0 Transitional//EN">
<html>
<head>
<title> Login Form</title>
</head>
<body>
<div class="container">
 <form method="post" action="login.php">
      <div class="txt-big">Login</div>
      <div class="field">
       <label for="user_name">Username </label>
       <input type="text" size="30" name="usr" id="usr" class="text-input">
      </div>
      <div class="field">
       <label for="user_name">Password </label>
       <input type="password" size="30" name="pswd" id="pswd" class="text-input">
      </div> 
       <div class="field">
      <input type="submit" value="Login" name="login" class="btn btn-submit" >
       <input type="reset" value="Cancel" name="reset" class="btn btn-submit">
      </div>
    </form>

</div>
</body>
</html>

login.php

<?php
session_start();
require ("mysqli.inc.php");
$username = $_REQUEST['usr'];
$password = $_REQUEST['pswd'];
$query = "Select * FROM `admin` WHERE username LIKE '" . $username . "' AND password LIKE '" . $password . "' ";
$r = mysqli_do($query);
if( $r ){
$_SESSION['usr'] = $username;
header("Location:"." yourpage.php");
}
else{
header("Location:"." loginform.php");
}
?>

注销.php

<?php
session_start();
session_destroy();
header('Location: loginform.php');
?> 

在您的page.php中检查是否登录。这是进行的基本方法

您的页面.php

<?php
session_start();
    if(!isset($_SESSION['usr']) || is_null($_SESSION['usr']) || $_SESSION['usr'] == ''){
    header("Location:"." loginform.php");
        } 
....
....
    ?>

注:这是一个基本样本,不打算成为一个完整的解决方案。需要增强!