php判斷當(dāng)前用戶已在別處登錄的方法
本文實(shí)例講述了php判斷當(dāng)前用戶已在別處登錄的方法。分享給大家供大家參考。具體分析如下:
主要思路如下:
1.登錄時(shí),將用戶的SessionID記錄下來
2.驗(yàn)證登錄時(shí),將記錄的該用戶SessionID與當(dāng)前SessionID匹配
3.如果不相同,說明在別處登錄
完整實(shí)例代碼點(diǎn)擊此處本站下載。
首先,進(jìn)入http://localhost/login_single/index.php可查看登錄狀態(tài)。
index.php頁面代碼如下:
<?php
//開啟Session
session_start();
header("Content-type: text/html; charset=utf-8");
//取Session中的用戶信息
$username=$_SESSION['username'];
//判斷是否有效
if(!isset($username)){
echo "您未登錄!<a href='login.html'>登錄</a>";
exit();
}
//登錄時(shí)保存的該用戶SessionID
$sessin_id=file_get_contents('session_id/'.$username);
//如果當(dāng)前的SessionID與之前記錄的SessionID不匹配
//說明已在別處登錄
if(session_id() != $sessin_id){
//注銷當(dāng)前用戶
unset($_SESSION['username']);
echo "您已在別處登錄!<a href='login.html'>從新登錄</a>";
exit();
}else{
echo "歡迎您:".$username;
echo " <a href='logout.php'>注銷</a>";
}
echo "<p>--這是登錄之后才能看到的內(nèi)容--</p>";
對(duì)于未登錄的用戶則提示跳轉(zhuǎn)到 http://localhost/login_single/login.html登錄頁面,login.html頁面代碼如下:
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
<html>
<head>
<meta http-equiv="Content-Type" content="text/html;charset=UTF-8">
<title>登錄</title>
</head>
<body>
<form method="post" action="login.php">
用戶名:<input name="username"><br>
密 碼:<input name="password" type="password"><br>
<input type="submit" value="登錄">
</form>
<div>
提示:測(cè)試用戶名:admin 密碼:123
</div>
</body>
</html>
登錄成功后由login.php頁面進(jìn)行相應(yīng)的session判斷。
login.php頁面代碼如下:
<?php
//開啟Session
session_start();
//設(shè)置編碼
header("Content-type: text/html; charset=utf-8");
//接收表單提交的內(nèi)容
$username=$_POST['username'];
$password=$_POST['password'];
//模擬驗(yàn)證用戶登錄
if($username=="admin" && $password=="123"){
//登錄成功,將用戶名保存到Session中
$_SESSION['username']=$username;
//創(chuàng)建目錄
if(!file_exists('session_id')){
mkdir('session_id');
}
//保存的文件名
$filename='session_id/'.$username;
//當(dāng)前登錄用戶的SessionId
$session_id=session_id();
//當(dāng)SessionID保存到對(duì)應(yīng)的文件中
//實(shí)際應(yīng)用,可以保存到數(shù)據(jù)庫、memcache等
file_put_contents($filename,$session_id);
//跳到主頁
header ('Location: index.php');
}else{
echo ('<script>alert("登錄失敗");window.location="login.html"</script>');
exit();
}
希望本文所述對(duì)大家的php程序設(shè)計(jì)有所幫助。
- Joomla實(shí)現(xiàn)組件中彈出一個(gè)模式(modal)窗口的方法
- joomla組件開發(fā)入門教程
- joomla數(shù)據(jù)庫操作示例代碼
- joomla jce editor 解決上傳中文名文件失敗問題
- xml在joomla表單中的應(yīng)用詳解分享
- ajax在joomla中的原生態(tài)應(yīng)用代碼
- CKeditor與syntaxhighlight打造joomla代碼高亮
- joomla內(nèi)置的表單驗(yàn)證功能使用方法
- Joomla下利用configuration.php存儲(chǔ)簡單數(shù)據(jù)
- 了解Joomla 這款來自國外的php網(wǎng)站管理系統(tǒng)
- Joomla簡單判斷用戶是否登錄的方法
相關(guān)文章
phpmyadmin導(dǎo)入(import)文件限制的解決辦法
最近一次在用phpmyadmin備份mysql數(shù)據(jù)庫時(shí),沒有分段大小,一下子備份了一百多M的sql數(shù)據(jù);在導(dǎo)入的時(shí)候,提示超過2M導(dǎo)入限制,前一段時(shí)間,遇到過一次,后來利用網(wǎng)站后臺(tái)的自動(dòng)分段處理了;這次又遇到這個(gè)問題,決心解決一下。2009-12-12php上傳圖片客戶端和服務(wù)器端實(shí)現(xiàn)方法
這篇文章主要介紹了php上傳圖片客戶端和服務(wù)器端實(shí)現(xiàn)方法,涉及php操作文件的技巧,涉及圖片后綴驗(yàn)證、文件重命名等常用方法,具有一定參考借鑒價(jià)值,需要的朋友可以參考下2015-03-03PHP進(jìn)制轉(zhuǎn)換實(shí)例分析(2,8,16,36,64進(jìn)制至10進(jìn)制相互轉(zhuǎn)換)
這篇文章主要介紹了PHP進(jìn)制轉(zhuǎn)換,結(jié)合具體實(shí)例形式分析了2,8,16,36,64進(jìn)制至10進(jìn)制相互轉(zhuǎn)換實(shí)現(xiàn)技巧,具有一定參考借鑒價(jià)值,需要的朋友可以參考下2017-02-02PHP下用rmdir實(shí)現(xiàn)刪除目錄的三種方法小結(jié)
PHP本身有一個(gè)rmdir()函數(shù)可以用來刪除目錄,不過要求必須是空目錄,本文列舉了三種方法。1、遞規(guī)法;2、系統(tǒng)調(diào)用法;3、循環(huán)法 。2008-04-04PHP從二維數(shù)組得到N層分類樹的實(shí)現(xiàn)代碼
這篇文章主要介紹了PHP從二維數(shù)組得到N層分類樹的實(shí)現(xiàn)代碼,需要的朋友可以參考下2016-10-10