日日操夜夜添-日日操影院-日日草夜夜操-日日干干-精品一区二区三区波多野结衣-精品一区二区三区高清免费不卡

公告:魔扣目錄網(wǎng)為廣大站長(zhǎng)提供免費(fèi)收錄網(wǎng)站服務(wù),提交前請(qǐng)做好本站友鏈:【 網(wǎng)站目錄:http://www.ylptlb.cn 】, 免友鏈快審服務(wù)(50元/站),

點(diǎn)擊這里在線咨詢客服
新站提交
  • 網(wǎng)站:51998
  • 待審:31
  • 小程序:12
  • 文章:1030137
  • 會(huì)員:747

前言

隨著wx的普及對(duì)開發(fā)同學(xué)來(lái)說(shuō)一些業(yè)務(wù)場(chǎng)景會(huì)使用到“掃碼登錄”功能,特別是PC網(wǎng)頁(yè)端,在此之前沒(méi)有這方面的開發(fā)經(jīng)歷,所以接到這個(gè)需求的時(shí)候還是有點(diǎn)慌的,最終通過(guò)查閱網(wǎng)上的資料以及老大的指導(dǎo)下實(shí)現(xiàn)了這個(gè)功能,目前已經(jīng)投入使用,實(shí)現(xiàn)之后還是蠻興奮的。特此記錄一下實(shí)現(xiàn)的過(guò)程。

原理解析

掃碼登陸的實(shí)現(xiàn)需要手機(jī)端的服務(wù)器和Web端的服務(wù)器配合實(shí)現(xiàn)。大致分為以下幾步:

step1:網(wǎng)頁(yè)端請(qǐng)求登陸二維碼

簡(jiǎn)單解析一下掃碼登陸原理

 

要實(shí)現(xiàn)網(wǎng)頁(yè)版的掃碼登陸,用戶必須先要請(qǐng)求一個(gè)登陸的二維碼。Web端的服務(wù)器收到用戶申請(qǐng)登陸二維碼的請(qǐng)求后,會(huì)隨機(jī)生成一個(gè)uuid(這個(gè)uuid作為頁(yè)面的唯一標(biāo)識(shí)符),并且會(huì)將這個(gè)uuid當(dāng)做一個(gè)鍵值對(duì)的key存入后臺(tái)redis。存入Redis的這個(gè)鍵值對(duì)的value是什么我們待會(huì)再說(shuō)。

需要注意的是存入Redis的鍵值對(duì)必須設(shè)置一個(gè)過(guò)期時(shí)間,不然的話拿著這個(gè)uuid登陸一次后就一直處于登陸狀態(tài)了。

當(dāng)瀏覽器端拿到Web服務(wù)端返回的二維碼信息后,解析其中的uuid,并拿這個(gè)uuid不斷去后臺(tái)輪詢是否已經(jīng)登陸成功。如果后臺(tái)已經(jīng)登陸成功,Web端就自動(dòng)跳轉(zhuǎn)到登陸成功頁(yè)面。不然的話會(huì)一直輪詢,直到二維碼失效(這里我們發(fā)現(xiàn)給二維碼設(shè)置有效時(shí)間真的很有必要,如果二維碼沒(méi)有有效時(shí)間的話,會(huì)不斷的輪詢后臺(tái),給后臺(tái)造成很大的壓力)。

那么上面的關(guān)鍵點(diǎn)是Web端服務(wù)器是怎么判斷用戶是否已經(jīng)掃碼登陸成功過(guò)的呢? 請(qǐng)看下面的步驟。

step2:手機(jī)端將用戶id存入Redis

簡(jiǎn)單解析一下掃碼登陸原理

 

用戶請(qǐng)求到二維碼后,就開始拿出手機(jī),打開相應(yīng)的App掃描二維碼。掃描過(guò)程中手機(jī)會(huì)將uuid和手機(jī)端登陸后獲得的token信息一起提交到手機(jī)端服務(wù)器。

手機(jī)端服務(wù)器會(huì)先拿token信息判斷這個(gè)用戶是否合法,是否已經(jīng)正常登陸。如果判斷已經(jīng)正常登陸,那么會(huì)將這個(gè)用戶的userId和提交過(guò)來(lái)的uuid當(dāng)做一個(gè)鍵值對(duì)(uudi-userId)存入Redis。這邊回答了步驟一種留下的問(wèn)題。

簡(jiǎn)單來(lái)講手機(jī)端做的工作就這么多。讓我們繼續(xù)回到Web端。

step3:web端輪詢成功

簡(jiǎn)單解析一下掃碼登陸原理

 

步驟一中講到:二維碼登陸頁(yè)會(huì)不停的輪詢是否登陸成功。這邊的依據(jù)就是Redis中存在uuid-userId鍵值對(duì)。如果這個(gè)鍵值對(duì)已經(jīng)存在,說(shuō)明手機(jī)端已經(jīng)掃碼登陸過(guò)。

Web端服務(wù)器一旦判斷到手機(jī)端已經(jīng)掃碼登陸過(guò),就可以拿著userId進(jìn)行登陸。并將必要的用戶信息和token信息返回Web前端。至此Web端登陸成功。

簡(jiǎn)單總結(jié)

本文記錄了一個(gè)掃碼登陸的簡(jiǎn)單版本,但是也能描述掃碼登陸的大致原理。實(shí)際開發(fā)過(guò)程中應(yīng)該還是有許多細(xì)節(jié)需要考慮。比如安全問(wèn)題等。具體的還是需要我們進(jìn)行實(shí)戰(zhàn)了。

歡迎大家一起討論~

作者: 寫代碼的木公

出處:https://www.cnblogs.com/54chensongxia/p/12530268.html

分享到:
標(biāo)簽:登陸
用戶無(wú)頭像

網(wǎng)友整理

注冊(cè)時(shí)間:

網(wǎng)站:5 個(gè)   小程序:0 個(gè)  文章:12 篇

  • 51998

    網(wǎng)站

  • 12

    小程序

  • 1030137

    文章

  • 747

    會(huì)員

趕快注冊(cè)賬號(hào),推廣您的網(wǎng)站吧!
最新入駐小程序

數(shù)獨(dú)大挑戰(zhàn)2018-06-03

數(shù)獨(dú)一種數(shù)學(xué)游戲,玩家需要根據(jù)9

答題星2018-06-03

您可以通過(guò)答題星輕松地創(chuàng)建試卷

全階人生考試2018-06-03

各種考試題,題庫(kù),初中,高中,大學(xué)四六

運(yùn)動(dòng)步數(shù)有氧達(dá)人2018-06-03

記錄運(yùn)動(dòng)步數(shù),積累氧氣值。還可偷

每日養(yǎng)生app2018-06-03

每日養(yǎng)生,天天健康

體育訓(xùn)練成績(jī)?cè)u(píng)定2018-06-03

通用課目體育訓(xùn)練成績(jī)?cè)u(píng)定