<button id="g80sy"></button>
  • <abbr id="g80sy"></abbr>
  • <button id="g80sy"></button>
    <rt id="g80sy"><delect id="g80sy"></delect></rt>
  • thinkphp6如何在本地IP不變的情況下自動登錄后臺

    程序猿 2021-03-12 22:40:52 2298瀏覽 加載中

    原理

    第一次登錄的時候設置cookie,再次登錄的時候先獲取cookie進行校驗,為了安全起見還要做一些簡單的加密。cookie在本地保存,容易泄漏,為了安全可以和本地IP做下綁定,這樣就算泄漏在其它電腦上也是登錄不了的,當然在同一個局域網內還是可以訪問的,同網中也沒有人黑你吧。

    代碼

    // 登錄成功后設置 cookie 
    $ip = get_real_ip();    // 獲取客戶真實的IP,下面有介紹
    $token = md5($pass . $ip); // $pass 為用戶的密碼,和真實的IP做一個簡單的MD5加密
    cookie("username",$username,604800); // 7天
    cookie("token",$token,3600*24*7); //7天

    第二次登錄代碼

    $username = cookie("username");
    $token = cookie("token");
    $ip = get_real_ip();  
    $user = UserModel::where("username",$username)->find();
    if ($user) {
        $pass = $user->pass;
        $t = md5(pass . $ip);
        if ($t == $token) {
            session("username",$username) // 記錄session登錄狀態
            $this->redirect("/admin",301); // 跳轉到后臺頁面
        }
    }
    // 其它邏輯自行腦補。

    說明

    get_real_ip()是自定義獲取真實IP的方法,點擊可以查看相應代碼。

    最后修改:2025-07-06 14:44:12

    非特殊說明,本博所有文章均為博主原創。

    主站蜘蛛池模板: 封开县| 淮南市| 镇坪县| 山阳县| 虞城县| 赫章县| 汉中市| 获嘉县| 潍坊市| 翼城县| 阳西县| 容城县| 文山县| 普洱| 东乌珠穆沁旗| 额敏县| 磐石市| 蓬安县| 都江堰市| 布拖县| 华宁县| 南昌县| 新巴尔虎右旗| 麦盖提县| 开封县| 葵青区| 金川县| 卢龙县| 大悟县| 玉环县| 勐海县| 无极县| 内乡县| 简阳市| 遂平县| 宁远县| 全南县| 偏关县| 柳江县| 乌拉特后旗| 惠东县|