搜尋
首頁後端開發PHP問題php怎麼做到只有一個使用者登入

php做到只有一個使用者登入的方法:1、在uni-app前端中初始化socke;2、即時接收一個「強制登出」類型的訊息;3、使用PHP後端接收「裝置唯一標識」參數;4、根據快取中的clientid發送訊息即可。

php怎麼做到只有一個使用者登入

本教學操作環境:Windows10系統、PHP8.1版、Dell G3電腦。

php怎麼做到只有一個用戶登入?

uni-app結合PHP實作單一用戶登陸

單一用戶登陸,即在一個應用程式中,同一個使用者只能在線上登陸一個,一個使用者登陸,在其他裝置上會被即時擠下線,確認後清空登陸該裝置上的登陸裝填並退回到登陸介面。

    uni-app是目前能透過使用vue.js框架只需要編寫一套程式碼同時打包Android,IOS,微信小程序,頭條支付寶小程式和H5,透過使用HBuilder工具方便調試與雲端打包,關於蘋果證書,推薦CW.PUB,https://cw.pub/index/document/index。使用HBuilder打越獄包透過那個網站簽名就可以在正常蘋果手機安裝,不過網路上還有其他些方法這裡就不列舉了。

     一般APP做單一使用者登陸會使用第三方訊息推播平台,雖然uni-app雖然也可以對接友盟,極光等推播平台。但還是因為時間,對接平台審核等流程時間不允許。之前使用gatewayworkman和websocket做了即時聊天,所以單一使用者登陸也使用websocket實作。

 

uni-app socket單一使用者登陸範例

#1. uni-app前端在初始化socke時發送目前裝置的唯一標識,然後即時接收一個「強制退出」類型的消息,一下只是簡單範例。

//初始化
socket.on('init', () => { //连接初始化
socket.send({
type: 'login',
token: uni.getStorageSync('access_token'),
device_no: plus.device.uuid,//手机设备唯一编号
});
}).on('quit_push',(res)=> {
if(res) {
uni.showModal({
title: '退出通知',
content: '你的账号在其他设备上登录!',
showCancel: true,
cancelText: '取消',
confirmText: '确定',
success: res => {
if(res.confirm) {
uni.clearStorageSync()
store.commit('chat/clear')
uni.reLaunch({
url:"../../pages/login/index"
})
}else if(res.cancel) {
uni.clearStorageSync()
store.commit('chat/clear')
uni.reLaunch({
url:"../../pages/login/index"
})
}
}
});
}
});

 

2. 後端接收「裝置唯一識別」參數,先找出快取是否存在,不存在記錄裝置識別碼和socket的clientid。

 

3. 登陸介面接收裝置標識,快取或庫裡取出標識記錄與目前接收的裝置標識判斷是否一致,不一致則根據快取中的clientid發送訊息。

$is_online = Db::name('UserLoginClient')->where('user_id',$user['id'])->order('id desc')->find();
if(isset($device_no) && $device_no && $is_online['device_no'] != $device_no && !empty($is_online['device_no'])) { 
Tools::sendToClient($is_online['client_id'],json_encode([
'type' => 'quit_push',
'data' => 'ip',
'message' => '强制下线'
]));
}

 

4. 工具類別sendToClient方法部分

public static function sendToClient($client_id, $message)
    {
        Gateway::sendToClient($client_id, $message);
    }

 

推送單一使用者登陸範例

#1. 首先對接了友盟,包括前端後端都加了SDK和使用上了他們的方法。

 

2. 訊息推送有一個唯一值"token",這裡簡稱為“pushtoken”,由客戶端生成,可以標識一個唯一的裝置。

 

3. 後端登陸時,接收pushtoken,同樣判斷該pushtoken是否存在,不存在就以用戶ID為鍵存儲。

 

4. 存在時再判斷與快取是否一致,一致則加長快取時間,不一致則給予舊的pushtoken(快取中的)推送訊息,並快取新的pushtoken。

if (self::$headToken && Cache::has(self::$prefix . self::$userId)) {
            if (self::$headToken == Cache::get(self::$prefix . self::$userId)) {
                Cache::set(self::$prefix . self::$userId, self::$headToken, self::$timeOut);
            } else {        // 换了手机,客户端重新发送pushtoken到服务端,服务端与缓存中的pushtoken比较,不同则给原来pushtoken手机推送一条并重新缓存新的token
                // modify by wensen on 20180816
                // $addr = getCity();
                $addr = getMobCity();
                $ip = request()->ip();
                
                if ($addr) {
                    $addr['province'] = empty($addr['province']) ? '' : $addr['province'];
                    $addr['city'] = empty($addr['city']) ? '' : $addr['city'];
                    // $address = "\t" . $addr['country'] . "-" . $addr['region'] . "-" . $addr['city'] . " (IP:" . $ip . ")\t";
                    $address = "\t" . $addr['country'] . "-" . $addr['province'] . "-" . $addr['city'] . " (IP:" . $ip . ")\t";
                } else {
                    $address = "IP:" . $ip . "";
                }
                $OldToken = Cache::get(self::$prefix . self::$userId);
                if (strlen($OldToken) == 64) {
                    $content = array(
                        'title' => 'APP紧急通知',
                        'body' => '您的账号于:' . date('Y-m-d H:i:s') . '在' . $address . '处登录,若不为您本人登录,请您立即修改密码!',
                        'pull_service' => 'login'
                    );
                    \umeng\Push::send($OldToken, 'unicast', $content, 'message', true);
                } elseif (strlen($OldToken) == 44) {
                    $content = array(
                        'pull_service' => 'login',
                        'msg' => '您的账号于:' . date('Y-m-d H:i:s') . '在' . $address . '处登录,若不为您本人登录,请您立即修改密码!'
                    );
                    \umeng\Push::send($OldToken, 'unicast', $content, 'message', true);
                }
                Cache::set(self::$prefix . self::$userId, self::$headToken, self::$timeOut);
            }
        } else {
            Cache::set(self::$prefix . self::$userId, self::$headToken, self::$timeOut);
        }

 

5. APP客戶端接收推送進行彈窗提示和退出處理。

 

6. 以上是根據友盟的SDK封裝的推送方法,其中包括單播,廣播,跳應用activity,跳網頁連接等等。

推薦學習:《PHP影片教學

以上是php怎麼做到只有一個使用者登入的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn

熱AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Clothoff.io

Clothoff.io

AI脫衣器

Video Face Swap

Video Face Swap

使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱工具

DVWA

DVWA

Damn Vulnerable Web App (DVWA) 是一個PHP/MySQL的Web應用程序,非常容易受到攻擊。它的主要目標是成為安全專業人員在合法環境中測試自己的技能和工具的輔助工具,幫助Web開發人員更好地理解保護網路應用程式的過程,並幫助教師/學生在課堂環境中教授/學習Web應用程式安全性。 DVWA的目標是透過簡單直接的介面練習一些最常見的Web漏洞,難度各不相同。請注意,該軟體中

MantisBT

MantisBT

Mantis是一個易於部署的基於Web的缺陷追蹤工具,用於幫助產品缺陷追蹤。它需要PHP、MySQL和一個Web伺服器。請查看我們的演示和託管服務。

SublimeText3漢化版

SublimeText3漢化版

中文版,非常好用

SecLists

SecLists

SecLists是最終安全測試人員的伙伴。它是一個包含各種類型清單的集合,這些清單在安全評估過程中經常使用,而且都在一個地方。 SecLists透過方便地提供安全測試人員可能需要的所有列表,幫助提高安全測試的效率和生產力。清單類型包括使用者名稱、密碼、URL、模糊測試有效載荷、敏感資料模式、Web shell等等。測試人員只需將此儲存庫拉到新的測試機上,他就可以存取所需的每種類型的清單。

SublimeText3 Mac版

SublimeText3 Mac版

神級程式碼編輯軟體(SublimeText3)