熱點推薦:
您现在的位置: 電腦知識網 >> 編程 >> Java編程 >> JSP教程 >> 正文

php中如何同時使用session和cookie來保存用戶登錄信息

2022-06-13   來源: JSP教程 
本篇文章是對在php中同時使用session和cookie來保存用戶登錄信息的實現代碼進行了詳細的分析介紹需要的朋友參考下  

  同時使用session和cookie來保存用戶登錄信息
數據庫連接配置頁面connectvarsphp

復制代碼 代碼如下:
<?php
//數據庫的位置
define(DB_HOST );
//用戶名
define(DB_USER root);
//口令
define(DB_PASSWORD );
//數據庫名
define(DB_NAMEtest) ;
?>

  
登錄頁面logInphp

復制代碼 代碼如下:
<?php
//插入連接數據庫的相關信息
require_once connectvarsphp;
//開啟一個會話
session_start();
$error_msg = "";
//如果用戶未登錄即未設置$_SESSION[user_id]時執行以下代碼
if(!isset($_SESSION[user_id])){
    if(isset($_POST[submit])){//用戶提交登錄表單時執行如下代碼
        $dbc = mysqli_connect(DB_HOSTDB_USERDB_PASSWORDDB_NAME);
        $user_username = mysqli_real_escape_string($dbctrim($_POST[username]));
        $user_password = mysqli_real_escape_string($dbctrim($_POST[password]));
        if(!empty($user_username)&&!empty($user_password)){
            //MySql中的SHA()函數用於對字符串進行單向加密
            $query = "SELECT user_id username FROM mismatch_user WHERE username = $user_username AND ""password = SHA($user_password)";
            $data = mysqli_query($dbc$query);
            //用用戶名和密碼進行查詢若查到的記錄正好為一條則設置SESSION和COOKIE同時進行頁面重定向
            if(mysqli_num_rows($data)==){
                $row = mysqli_fetch_array($data);
                $_SESSION[user_id]=$row[user_id];
                $_SESSION[username]=$row[username];
                setcookie(user_id$row[user_id]time()+(***));
                setcookie(username$row[username]time()+(***));
                $home_url = logedphp;
                header(Location: $home_url);
            }else{//若查到的記錄不對則設置錯誤信息
                $error_msg = Sorry you must enter a valid username and password to log in;
            }
        }else{
            $error_msg = Sorry you must enter a valid username and password to log in;
        }
    }
}else{//如果用戶已經登錄則直接跳轉到已經登錄頁面
    $home_url = logedphp;
    header(Location: $home_url);
}
?>
<html>
    <head>
        <title>Mismatch Log In</title>
        <link rel="stylesheet" type="text/css" href="stylecss" />
    </head>
    <body>
        <h>Msimatch Log In</h>
        <!通過$_SESSION[user_id]進行判斷如果用戶未登錄則顯示登錄表單讓用戶輸入用戶名和密碼>
        <?php
        if(!isset($_SESSION[user_id])){
            echo <p class="error">$error_msg</p>;
        ?>
        <! $_SERVER[PHP_SELF]代表用戶提交表單時調用自身php文件 >
        <form method = "post" action="<?php echo $_SERVER[PHP_SELF];?>">
            <fieldset>
                <legend>Log In</legend>
                <label for="username">Username:</label>
                <input type="text" id="username" name="username"
                value="<?php if(!empty($user_username)) echo $user_username; ?>" />
                <br/>
                <label for="password">Password:</label>
                <input type="password" id="password" name="password"/>
            </fieldset>
            <input type="submit" value="Log In" name="submit"/>
        </form>
        <?php
        }
        ?>
    </body>
</html>

  
效果圖

  

登入頁面logedphp

復制代碼 代碼如下:
<?php
//使用會話內存儲的變量值之前必須先開啟會話
session_start();
//如果會話沒有被設置查看是否設置了cookie
if(!isset($_SESSION[user_id])){
    if(isset($_COOKIE[user_id])&&isset($_COOKIE[username])){
        //用cookie給session賦值
        $_SESSION[user_id]=$_COOKIE[user_id];
        $_SESSION[username]=$_COOKIE[username];
    }
}
//使用一個會話變量檢查登錄狀態
if(isset($_SESSION[username])){
    echo You are Logged as $_SESSION[username]<br/>;
    echo <a href="logOutphp"> Log Out($_SESSION[username])</a>;
}
/**在已登錄頁面中可以利用用戶的session如$_SESSION[username]
 * $_SESSION[user_id]對數據庫進行查詢可以做好多好多事情*/
?>

  
效果圖

注銷session與cookie頁面logOutphp(注銷後重定向到lonInphp)

復制代碼 代碼如下:

  
<?php
/**同時注銷session和cookie的頁面*/
//即使是注銷時也必須首先開始會話才能訪問會話變量
session_start();
//使用一個會話變量檢查登錄狀態
if(isset($_SESSION[user_id])){
    //要清除會話變量將$_SESSION超級全局變量設置為一個空數組
    $_SESSION = array();
    //如果存在一個會話cookie通過將到期時間設置為之前個小時從而將其刪除
    if(isset($_COOKIE[session_name()])){
        setcookie(session_name()time());
    }
    //使用內置session_destroy()函數調用撤銷會話
    session_destroy();
}
//同時將各個cookie的到期時間設為過去的某個時間使它們由系統刪除時間以秒為單位
setcookie(user_idtime());
setcookie(usernametime());
//location首部使浏覽器重定向到另一個頁面
$home_url = logInphp;
header(Location:$home_url);
?>


From:http://tw.wingwit.com/Article/program/Java/JSP/201311/20469.html
    推薦文章
    Copyright © 2005-2022 電腦知識網 Computer Knowledge   All rights reserved.