uni-app結(jié)合PHP實(shí)現(xiàn)單用戶登陸demo及解析
即在一個(gè)應(yīng)用中,同一個(gè)用戶只能在線登陸一個(gè),一個(gè)用戶登陸,在其他設(shè)備上會(huì)被即時(shí)擠下線,確認(rèn)后清空登陸該設(shè)備上的登陸裝填并退回到登陸界面。
uni-app是目前能通過(guò)使用vue.js框架只需要編寫一套代碼同時(shí)打包Android,IOS,微信小程序,頭條支付寶小程序和H5,通過(guò)使用HBuilder工具方便調(diào)試與云打包,關(guān)于蘋果證書(shū),推薦CW.PUB
使用HBuilder打越獄包通過(guò)那個(gè)網(wǎng)站簽名就可以在正常蘋果手機(jī)安裝,不過(guò)網(wǎng)上還有其他些方法這里就不列舉了。
一般APP做單用戶登陸會(huì)使用第三方消息推送平臺(tái),雖然uni-app雖然也可以對(duì)接友盟,極光等推送平臺(tái)。但還是因?yàn)闀r(shí)間,對(duì)接平臺(tái)審核等流程時(shí)間不允許。之前使用gatewayworkman和websocket做了即時(shí)聊天,所以單用戶登陸也使用websocket實(shí)現(xiàn)。
uni-app socket單用戶登陸例1.uni-app前端在初始化socke時(shí)發(fā)送當(dāng)前設(shè)備的唯一標(biāo)識(shí),然后實(shí)時(shí)接收一個(gè)“強(qiáng)制退出”類型的消息,一下只是簡(jiǎn)單示例。
//初始化socket.on('init', () => { //連接初始化 socket.send({type: 'login',token: uni.getStorageSync('access_token'),device_no: plus.device.uuid, //手機(jī)設(shè)備唯一編號(hào) });}).on('quit_push',(res)=> { if(res) {uni.showModal({ title: '退出通知', content: '你的賬號(hào)在其他設(shè)備上登錄!', 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.后端接收“設(shè)備唯一標(biāo)識(shí)”參數(shù),先查找緩存是否存在,不存在記錄設(shè)備標(biāo)識(shí)和socket的clientid。
3.登陸接口接收設(shè)備標(biāo)識(shí),緩存或庫(kù)里取出標(biāo)識(shí)記錄與當(dāng)前接收的設(shè)備標(biāo)識(shí)判斷是否一致,不一致則根據(jù)緩存中的clientid發(fā)送消息。
$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' => '強(qiáng)制下線'])); }4.工具類sendToClient方法部分
public static function sendToClient($client_id, $message) {Gateway::sendToClient($client_id, $message); }推送單用戶登陸例1.首先對(duì)接了友盟,包括前端后端都加了SDK和使用上了他們的方法。
2.消息推送有一個(gè)唯一值"token",這里簡(jiǎn)稱“pushtoken”,由客戶端生成,可以標(biāo)識(shí)一個(gè)唯一的設(shè)備。
3.后端登陸時(shí),接收pushtoken,同樣判斷該pushtoken是否存在,不存在就以用戶ID為鍵存儲(chǔ)。
4.存在時(shí)再判斷與緩存是否一致,一致則加長(zhǎng)緩存時(shí)間,不一致則給舊的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 {// 換了手機(jī),客戶端重新發(fā)送pushtoken到服務(wù)端,服務(wù)端與緩存中的pushtoken比較,不同則給原來(lái)pushtoken手機(jī)推送一條并重新緩存新的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' => '您的賬號(hào)于:' . date('Y-m-d H:i:s') . '在' . $address . '處登錄,若不為您本人登錄,請(qǐng)您立即修改密碼!','pull_service' => 'login' ); \umeng\Push::send($OldToken, 'unicast', $content, 'message', true);} elseif (strlen($OldToken) == 44) { $content = array('pull_service' => 'login','msg' => '您的賬號(hào)于:' . date('Y-m-d H:i:s') . '在' . $address . '處登錄,若不為您本人登錄,請(qǐng)您立即修改密碼!' ); \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客戶端接收推送進(jìn)行彈窗提示和退出處理。
6.以上是根據(jù)友盟的SDK封裝的推送方法,其中包括單播,廣播,跳應(yīng)用activity,跳網(wǎng)頁(yè)連接等等。
以上就是uni-app結(jié)合PHP實(shí)現(xiàn)單用戶登陸的詳細(xì)內(nèi)容,更多關(guān)于uni-app結(jié)合PHP實(shí)現(xiàn)單用戶登陸的資料請(qǐng)關(guān)注好吧啦網(wǎng)其它相關(guān)文章!
