>백엔드 개발 >PHP 문제 >PHP에서 로그인 없이 7일을 달성하는 방법

PHP에서 로그인 없이 7일을 달성하는 방법

藏色散人
藏色散人원래의
2022-10-25 11:13:281858검색

PHP에서 7일 로그인 없음을 구현하는 방법: 1. 사용자가 7일 로그인 없음을 선택할 수 있도록 프런트 엔드에 버튼을 만듭니다. 2. 백엔드에서 다음을 기반으로 사용자 ID를 쿼리합니다. 사용자가 제출한 사용자 이름과 비밀번호 3. 사용자 ID를 저장합니다. 4. 만료 시간을 7일로 설정합니다.

PHP에서 로그인 없이 7일을 달성하는 방법

이 튜토리얼의 운영 환경: Windows 7 시스템, PHP 버전 8.1, Dell G3 컴퓨터.

php 로그인 없이 7일을 달성하는 방법은 무엇인가요?

쿠키 스푸핑을 방지하기 위해 PHP에 7일 로그인 없음 기능을 구현합니다

1. 로그인 없음 아이디어

사용자가 7일 로그인 없음 버튼을 선택하면 백엔드에서 사용자 ID를 기반으로 쿼리합니다. 사용자가 제출한 사용자 이름과 비밀번호를 쿠키에 저장하고 만료 시간을 7일로 설정합니다. 쿠키정보가 삭제되지 않은 경우(비정상적으로 종료한 경우) 백그라운드에서 로그인을 도와줍니다. 실제로 쿠키를 사용하여 구현됩니다.

2. 확인 로그인 파일: checkLogin.php

<?php
header(&#39;content-type:text/html;charset=utf-8&#39;);
require &#39;./config.php&#39;;
$username = $_POST[&#39;uname&#39;];
$password = md5($_POST[&#39;pwd&#39;]);
$islogin = $_POST[&#39;islogin&#39;];
$sql = "SELECT * FROM `mu_user` WHERE `username`=? AND `password`=? ";
$stm = $pdo -> prepare($sql);
$stm ->bindParam(1,$username);
$stm ->bindParam(2,$password);
$stm ->execute();
$res = $stm->fetch(PDO::FETCH_ASSOC);
if($stm->rowCount() == 1){
    //验证成功
    clearCookie();
    if($islogin==1){
        //记住密码
        setcookie("username",$res[&#39;username&#39;],strtotime(&#39;+7 days&#39;));
        $token = settoken($res[&#39;username&#39;],$res[&#39;password&#39;],$res[&#39;id&#39;]);
        setcookie("token",$token,strtotime(&#39;+7 days&#39;));
    }else{
        // 无记住密码
        setcookie("username",$res[&#39;username&#39;]);
        $token = settoken($res[&#39;username&#39;],$res[&#39;password&#39;],$res[&#39;id&#39;]);
        setcookie("token",$token);
    }
    exit("
        <script>
            alert(&#39;登录成功!&#39;);
            location.href =&#39;index.php&#39;;
        </script>
    ");
}else{
    //验证失败
    exit("
        <script>
            alert(&#39;用户名或密码有误!&#39;);
            location.href =&#39;login.php&#39;;
        </script>
    ");
}
//清除cookie
function clearCookie(){
    setcookie("username",&#39;&#39;,time()-1800);
    setcookie("token",&#39;&#39;,time()-1800);
}
//设置token
function settoken($username,$password,$id)
{
    $salk = "czx";
    $token = md5($salk.$username.$password)."*".$id;
    return $token;
}

3. 데이터베이스 구성 파일: config.php

<?php
//主机地址
define("DB_HOST","localhost");
//数据库用户名
define("DB_USER","root");
//数据库密码
define("DB_PASSWORD","root123");
// 数据库型号
define("DB_TYPE","mysql");
// 数据库名称
define("DB_NAME","my_user");
//数据库编码
define(&#39;DB_CHARSET&#39;, &#39;utf8&#39;);
//数据库端口号
define(&#39;DB_PORT&#39;, &#39;3306&#39;);
//定义PDO的DSN,数据源名,包括主机名,端口号和数据库名称。
define(&#39;DSN&#39;, DB_TYPE.":host=".DB_HOST.";dbname=".DB_NAME.";charset=".DB_CHARSET);
try{
    //连接数据款
    $pdo = new PDO(DSN,DB_USER,DB_PASSWORD);
} catch(PDOException $e){
     //捕捉特定于数据库信息的PDOEXCEPTION 异常
    echo  $e->getMessage();
} catch(Throwable $e){
    //捕捉拥有Throwable接口的错误或者其他异常
    echo $e->getMessage();
}

4. 로그인 페이지 파일: login.php

<?php
    if($_GET[&#39;act&#39;] == &#39;out&#39;){
        setcookie("username",&#39;&#39;,time()-1800);
        setcookie("token",&#39;&#39;,time()-1800);
    }
    $token = $_COOKIE[&#39;token&#39;];
    $username = $_COOKIE[&#39;username&#39;];
    if(!empty($username) &&!empty($token)&& ($_GET[&#39;act&#39;] != &#39;out&#39;)){
        exit("
            <script>
                alert(&#39;用户已登录,请直接访问!&#39;);
                location.href =&#39;index.php&#39;;
            </script>
        ");
    }
?>
<!DOCTYPE html>
<html>
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>登录</title>
</head>
<style>
    *{
        margin: 0px;
        padding: 0;
    }
    .contater {
        border: 1px solid #000;
        width: 300px;
        display: flex;
        flex-direction: column;
        margin: auto;
    }
    .contater>div {
        margin-top: 20px;
    }
    h3 {
        text-align: center;
    }
    .contater > .submit >input{
        margin: 15px 140px;
        font-size: 1.5rem;
    }
</style>
<body>
<h3 >登录</h3>
    <form action="checkLogin.php" method="post">
        <div>
            <div>
                <span>用户名:</span>
                <input type="text" name="uname">
            </div>
            <div>
                <span>密   码:</span>
                <input type="password" name="pwd">
            </div>
            <div>
                <input type="radio"" name="islogin" value="1">
                <span>记住密码</span>
            </div>
            <div>
                <input  type="submit" value="登录">
            </div>
        </div>
    </form>
</body>
</html>

5. : index.php

<?php
    $token = $_COOKIE[&#39;token&#39;];
    $token_arr = explode("*",$token);
    $uid = end($token_arr);//获取用户id
    require "./config.php";
    $sql = "SELECT * FROM `mu_user` WHERE `id`=?";
    $stm = $pdo ->prepare($sql);
    $stm ->bindParam(1,$uid);
    $stm ->execute();
    $result =$stm->fetch(PDO::FETCH_ASSOC);
    if($stm->rowCount()==1){
        $salk = "czx";
        $token_res = md5($salk.$result[&#39;username&#39;].$result[&#39;password&#39;]);
        if($token_res != $token_arr[0]){
            exit("
                <script>
                alert(&#39;请先登录&#39;);
                loction.href =&#39;login.php&#39;;    
                </script>            
            ");
        }
    }else{
        exit("
            <script>
                alert(&#39;请您先登录&#39;);
                location.href=&#39;login.php&#39;;
            </script>
        ");
    }
?>
<!DOCTYPE html>
<html>
  <head>
    <meta charset="UTF-8" />
    <meta name="viewport" content="width=device-width, initial-scale=1.0" />
    <title>首页</title>
  </head>
  <style>
    * {
      margin: 0px;
      padding: 0px;
      box-sizing: border-box;
    }
    h1 {
      text-align: center;
    }
    a {
      text-decoration: none;
      font-size: 1.5rem;
      color: darkgray;
    }
    a:hover {
      background-color: lightskyblue;
      border-radius: 5%;
      /* font-size: 2rem; */
    }
    li {
        list-style-type: none;
        color: darkgray;
    }
    span {
        color: darkgray;
        font-size: 1.5rem;
        margin-right: 15px;
        color:burlywood
    }
    .top {
      /* width: 960px; */
      background-color: linen;
      display: flex;
      flex-flow: row nowrap;
      justify-content: space-between;
    }
    .top > div {
      margin: 10px 40px;
    }
    .column {
      /* width: 960px; */
      display: flex;
      flex-flow: row nowrap;
      justify-content: space-around;
    }
    .column > li {
      margin-right: 65px;
      padding: 0px 20px;
    }
  </style>
  <body>
    <h1>陶转转首页</h1>
    <div>
      <div>
        <ul>
          <li><a href="">LOGO</a></li>
          <li><a href="">首页</a></li>
          <li><a href="">分类一</a></li>
        </ul>
      </div>
      <div>
        <span>欢迎您,<?php echo $result[&#39;username&#39;];?></span>
        <a href="./login.php?act=out">退出</a>
      </div>
    </div>
  </body>
</html>

추천 학습: "PHP 비디오 튜토리얼"

위 내용은 PHP에서 로그인 없이 7일을 달성하는 방법의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.