php實現簡單的登陸功能(附原始碼)

2020-07-16 10:05:57

php實現簡單的登陸功能(附原始碼)

在一個網站中登陸功能是必不可少的,本文簡單的講述了在php中如何實現登陸功能。

登入介面:

denglu.png

html程式碼(login.html):

<form action="login.php" method="post">
<fieldset>
<legend>使用者登入</legend>
<ul>
<li>
<label>使用者名稱:</label>
<input type="text" name="username">
</li>
<li>
<label>密   碼:</label>
<input type="password" name="password">
</li>
<li>
<label> </label>
<input type="checkbox" name="remember" value="yes">7天內自動登入
</li>
<li>
<label> </label>
<input type="submit" name="login" value="登入">
</li>
</ul>
</fieldset>
</form>

login.php:(登陸處理頁)

<?php 
header('Content-type:text/html; charset=utf-8');
// 開啟Session
session_start();
 
// 處理使用者登入資訊
if (isset($_POST['login'])) {
# 接收使用者的登入資訊
$username = trim($_POST['username']);
$password = trim($_POST['password']);
// 判斷提交的登入資訊
if (($username == '') || ($password == '')) {
// 若為空,視為未填寫,提示錯誤,並3秒後返回登入介面
header('refresh:3; url=login.html');
echo "使用者名稱或密碼不能為空,系統將在3秒後跳轉到登入介面,請重新填寫登入資訊!";
exit;
} elseif (($username != 'username') || ($password != 'password')) {
# 使用者名稱或密碼錯誤,同空的處理方式
header('refresh:3; url=login.html');
echo "使用者名稱或密碼錯誤,系統將在3秒後跳轉到登入介面,請重新填寫登入資訊!";
exit;
} elseif (($username = 'username') && ($password = 'password')) {
# 使用者名稱和密碼都正確,將使用者資訊存到Session中
$_SESSION['username'] = $username;
$_SESSION['islogin'] = 1;
// 若勾選7天內自動登入,則將其儲存到Cookie並設定保留7天
if ($_POST['remember'] == "yes") {
setcookie('username', $username, time()+7*24*60*60);
setcookie('code', md5($username.md5($password)), time()+7*24*60*60);
} else {
// 沒有勾選則刪除Cookie
setcookie('username', '', time()-999);
setcookie('code', '', time()-999);
}
// 處理完附加項後跳轉到登入成功的首頁
header('location:index.php');
}
}
 ?>

index.php(預設主頁):

<?php 
header('Content-type:text/html; charset=utf-8');
// 開啟Session
session_start();
 
// 首先判斷Cookie是否有記住了使用者資訊
if (isset($_COOKIE['username'])) {
# 若記住了使用者資訊,則直接傳給Session
$_SESSION['username'] = $_COOKIE['username'];
$_SESSION['islogin'] = 1;
}
if (isset($_SESSION['islogin'])) {
// 若已經登入
echo "你好! ".$_SESSION['username'].' ,歡迎來到個人中心!<br>';
echo "<a href='logout.php'>登出</a>";
} else {
// 若沒有登入
echo "您還沒有登入,請<a href='login.html'>登入</a>";
}
 ?>

logout.php登出頁

<?php 
header('Content-type:text/html; charset=utf-8');
// 登出後的操作
session_start();
// 清除Session
$username = $_SESSION['username'];  //用於後面的提示資訊
$_SESSION = array();
session_destroy();
 
// 清除Cookie
setcookie('username', '', time()-99);
setcookie('code', '', time()-99);
 
// 提示資訊
echo "歡迎下次光臨, ".$username.'<br>';
echo "<a href='login.html'>重新登入</a>";
 
 ?>

登入成功的狀態:

01.png

若勾選7天內自動登入,則會將登入資訊通過Cookie和Session技術儲存在本地Cookie檔案中,7天內會自動登入。

登出頁面:

01.png

登入錯誤的幾種情況都做了處理:

02.jpg

感謝大家的閱讀,希望大家有所收益。

本文轉自:https://blog.csdn.net/l269798518/article/details/80462216

推薦教學:《PHP教學

以上就是php實現簡單的登陸功能(附原始碼)的詳細內容,更多請關注TW511.COM其它相關文章!