您好,登錄后才能下訂單哦!
這篇文章主要介紹php怎么實現一個賬號只能有一個人登錄,文中介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們一定要看完!
php實現一個賬號只能有一個人登錄的方法:首先將session信息存在redis中;然后將session_id存到mysql數據庫中;接著驗證session是否過期;最后利用openfire推送消息,并將session_id更新到數據庫中。
php 實現同一個賬號同時只能一個人登錄
以前考慮過這個問題,今天實現了一下,挺快的,從研究到開發完成差不多4個小時。有點類似QQ,二臺電腦登錄,一臺會把另一臺擠掉線,并提示其他地點登錄信息。
一,實現原理
1,用戶在電腦A登錄,session信息存放在redis當中,并將session_id存到mysql數據庫中。
2,同一用戶在電腦B登錄,驗證完用戶名和密碼后,將該用戶信息從數據庫讀出,取得用戶在電腦A登錄的session_id,然后在到redis中驗證session是否過期。
3,如果過期,不用openfire推送提示信息。如果沒有過期,php利用openfire推送消息后,在將redis中用戶在電腦A中登錄的session刪除掉,刪除后,在將用戶在電腦B登錄的個人信息放到session中,并將電腦B登錄的session_id更新到數據庫中,在這里一定要先發送推送,然后在清空session,不然用戶在電腦A收不到xmpp發過來的消息。
注意:
openfire是java cms的一種,自身有數據庫,您創建的用戶表根openfire自帶的用戶表之間要建立某種聯系(如:手機號,郵箱等),方便信息推送。
同一session_id肯定是在相同媒介上登錄的,這個時候,也不用更新數據庫和推送消息
下面簡單說一下安裝過程,以及要注意的地方。
【推薦學習:《PHP視頻教程》】
二,安裝所用到的工具
# yum install php php-fpm nginx mysql mysql-server redis php-redis php-devel php-pdo php-mysql
修改session存儲方式:
查看復制打印?
# vim /etc/php-fpm.d/www.conf ;php_value[session.save_handler] = files //注釋掉舊的 ;php_value[session.save_path] = /var/lib/php/session php_value[session.save_handler] = redis //添加以下內容 php_value[session.save_path] = "tcp://127.0.0.1:6379"
啟動服務后,如果以下內容說明,session存redis成功了
redis telnet查看session
openfire下載地址:http://www.igniterealtime.org/downloads/
查看復制打印?
# rpm -ivh ./*.rpm //下載的是rpm安裝包
openfire啟動后,然后訪問http://ip:9090,一步一步配置就成了,有一點要注意就是數據庫的編碼。
以上是“php怎么實現一個賬號只能有一個人登錄”這篇文章的所有內容,感謝各位的閱讀!希望分享的內容對大家有幫助,更多相關知識,歡迎關注億速云行業資訊頻道!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。