PHP實(shí)現(xiàn)用session來實(shí)現(xiàn)記錄用戶登陸信息
以下是【金聰采編】分享的內(nèi)容全文:
PHP中session實(shí)現(xiàn)記錄用戶登錄信息的問題,也是PHP面試題中比較常見的考點(diǎn)之一,是PHP學(xué)習(xí)者必須掌握的一個(gè)知識點(diǎn)。
對于初入門的PHP新手來說,或許有一定的難度。那么在之前的文章【PHP中session如何存儲及刪除變量的】中,也為大家介紹了PHP中session的基礎(chǔ)含義,需要的朋友可以選擇參考。
下面我們就通過具體的代碼示例,為大家詳細(xì)的介紹PHP中session實(shí)現(xiàn)記錄用戶登錄信息的具體方法。
1.簡單的登錄界面代碼示例:
login.html
<!DOCTYPE html><html><head> <meta charset="utf-8"> <title>登錄</title> <style type="text/css"> body { background: url(images/bg.png); } .clear { clear: both; } .login { width: 370px; margin: 100px auto 0px; text-align: center; } input[type="text"] { width: 360px; height: 50px; border: none; background: #fff; border-radius: 10px; margin: 5px auto; padding-left: 10px; color: #745A74; font-size: 15px; } input[type="checkbox"] { float: left; margin: 5px 0px 0px; } span { float: left; } .botton { width: 130px; height: 40px; background: #745A74; border-radius: 10px; text-align: center; color: #fff; margin-top: 30px; line-height: 40px; } </style></head><body><div class="login"> <form action="check.php" method="post"> <img src="images/header.png"><br> <input type="text" name="username" placeholder="請輸入用戶名!" value=""><br> <input type="text" name="password" placeholder="請輸入密碼!" value=""><br> <input type="submit" class="botton" value="login"> </form> <div class="clear"></div></div></body> </html>2.簡單的用于連接數(shù)據(jù)庫的PHP文件代碼示例:
db.php
<?php $dbName = 'demo';$host = '127.0.0.1';$user = 'root';$password = 'root'; $dsn = "mysql:host=$host;dbname=$dbName";$pdo = new PDO($dsn, $user, $password); function sql($table, $field = '*', $where = ''){ global $pdo; $sql = 'select' . ' ' . $field . ' ' . 'from' . ' ' . $table . ' where ' . $where; $data = $pdo->query($sql)->fetch(); return $data;}這里我們定義了一個(gè)sql方法用來查詢數(shù)據(jù)庫表中字段,并返回?cái)?shù)據(jù)。
那么如果有新手不清楚PHP連接數(shù)據(jù)庫的方法,可以參考學(xué)習(xí)這篇文章【PHP怎么連接Mysql數(shù)據(jù)庫】。
3.檢驗(yàn)用戶登錄信息的代碼示例:
check.php
<?phpsession_start();include "db.php";@$name = $_POST['username'];@$pas = $_POST['password']; $row = sql('user', '*', "username = '$name'");if (!$row) { return "用戶名不存在!請檢查用戶名~~";} if ($row['password'] == $pas) { $_SESSION['username'] = "$name"; echo "<script> alert('登錄成功!正在跳轉(zhuǎn)...')</script>"; echo "<a href='index.php'>如果跳轉(zhuǎn)失敗請點(diǎn)擊跳轉(zhuǎn)~~</a>"; header("Refresh:1;url=index.php");}這里我們要開啟session,并用include引入數(shù)據(jù)庫,然后用if語句判斷查詢提交過來的數(shù)據(jù)并將用戶名提交給session來記錄,即判斷用戶名密碼是否存在及是否相等。
4.登錄成功后跳轉(zhuǎn)的頁面代碼示例:
index.php
<?phpecho "<h1>這里是主頁</h1>";session_start();$name = $_SESSION['username'];if ($name) { echo "<script> alert(/"尊敬的$name ,歡迎回來??!/");</script>";}else{ echo "<script> alert('您還尚未登錄!請返回登錄~~')</script>"; echo "<a href='index.php'>如果跳轉(zhuǎn)失敗請點(diǎn)擊跳轉(zhuǎn)~~</a>"; header("Refresh:1;url=login.html");}那么上述代碼login.html,db.php,check.php和index.php就是一個(gè)簡單的用session來實(shí)現(xiàn)記錄用戶登錄信息的程序。
我們可以通過瀏覽器訪問進(jìn)行測試,首先我們可以在login登錄界面,輸入用戶名密碼,效果如下圖:

點(diǎn)擊login登錄,跳轉(zhuǎn)到check.php。

點(diǎn)擊確定

如果跳轉(zhuǎn)失敗就點(diǎn)擊上圖中鏈接,如果跳轉(zhuǎn)成功,則直接跳轉(zhuǎn)到index.php主頁面,顯示如下圖:


本篇文章就是關(guān)于PHP中session來實(shí)現(xiàn)記錄用戶登錄信息的具體方法介紹,具有一定的參考價(jià)值,希望對需要的朋友有所幫助!
1.軟件源碼推廣展示:目的展示軟件相關(guān)功能,接收技術(shù)學(xué)習(xí)者測試、測評;
2.教程課程信息展示:展示課程信息,傳授課程各階段內(nèi)容;
3.設(shè)計(jì)素材圖片展示:展示素材設(shè)計(jì)理念、思維方式、傳播設(shè)計(jì)理念;
4.福利優(yōu)惠信息展示:分享各類最新的福利信息,各種優(yōu)惠信息展示;
以上分享目的僅供學(xué)習(xí)、參考使用,請勿用于其他用途,如果想商業(yè)使用或者代理,請自行聯(lián)系版權(quán)方獲取授權(quán)。任何未獲取授權(quán)的商業(yè)使用與本站無關(guān),請自行承擔(dān)相應(yīng)責(zé)任。
本站不存儲任何資源文件,敬請周知!
如果您認(rèn)為本頁信息內(nèi)容侵犯了您的相關(guān)權(quán)益(包含但不限于:著作權(quán)、首發(fā)權(quán)、隱私權(quán)等權(quán)利),或者您認(rèn)為自己是此信息的權(quán)利人但是此信息不是自己發(fā)布的,可以直接版權(quán)舉報(bào)投訴,我們會根據(jù)網(wǎng)站注冊協(xié)議、資源分享協(xié)議等協(xié)議處理,以保護(hù)您的合法權(quán)益。
本網(wǎng)站采用 BY-NC-SA 協(xié)議進(jìn)行授權(quán) 轉(zhuǎn)載請注明原文鏈接:PHP實(shí)現(xiàn)用session來實(shí)現(xiàn)記錄用戶登陸信息

侵權(quán)舉報(bào)/版權(quán)申訴



