首頁 > 後端開發 > Python教學 > Python Websocket實作掃碼二維碼登入---GoEasy

Python Websocket實作掃碼二維碼登入---GoEasy

巴扎黑
發布: 2016-12-19 13:31:30
原創
1714 人瀏覽過

最近在做一個掃碼登入功能,為此我還在網路上搜了一下關於微信的掃描登入的實作方式。當這個功能完成了後,我決定將整個實現思路整理出來,方便自己以後查看也方便其他有類似需求的程式猿些。
要實現掃碼登入我們需要解決兩個問題:
1.  在沒有輸入使用者名稱及密碼的情況下,如何解決權限安全問題?換句話說,如何讓伺服器知道掃碼二維碼的客戶端是一個合法的使用者?
2.  伺服器根據使用者在客戶端的選擇如何即時在網頁上做出相應的回應?

首先我們先理一下微信的實現思路,來方便我們理解解決這一難題的思路方向。微信登入的二維碼其實是將一個URL轉換成二維碼的形式,而透過微信客戶端掃碼後,無非就是打開了這個url, 我捕捉到的微信二維碼的url為https:/ /login.weixin.qq.com/l/YdmTu30I5A== ,這個url裡的YdmTu30I5A==代表的是本次會話的唯一ID, 這個有點類似瀏覽器裡的session id,透過這個ID,微信就能定向將確認結果回饋到網頁上。使用微信二維碼登入功能,需要有兩個前提:一是客戶端上需要安裝微信app。二是用戶需要登入微信app。 https://wx.qq.com/

 

Python Websocket訊息推播

 

為什麼要有這兩個條件呢?那是因為微信在確認是否允許登入網頁版的時候,微信需要提取當前app的登入資訊並將上面的session ID一併發給伺服器,這樣伺服器收到了登入資訊和sessionID後就可以確認兩件事:一是用來確認登入的客戶端的使用者是驗證過的;二是透過session ID伺服器知道將回饋結果推送到哪個網頁。

   所以針對第一點,我們的關鍵在於,在掃描前要確保用戶是已經被驗證過且合法的用戶(驗證方式可以是用戶名+密碼,也可以是一個secure key),在選擇是否登錄時將這個結果一併推送到伺服器端,就好了。如果使用者沒有驗證是否合法,可以像微信的處理方式一樣直接告訴使用者二維碼不可識別或提示請先登入app。

  有了身份驗證,那麼現在就解決第二個問題,如何將回饋結果即時顯示在網頁上呢?有朋友可能會說,客戶端這邊很簡單發一個請求到後台就好了,而網頁上用ajax定時發送到伺服器端看是否有回饋。我不贊成這種做法,因為ajax輪詢方式十分消耗客戶端和伺服器端資源!這裡涉及到另一個技術-web即時推送技術,使用推播技術可以節約伺服器端和客戶端的資源,可以穩定地推送和接收任何訊息。我在實現的過程中我採用了第三方推送服務-GoEasy推送,用它是實現非常簡單,我們專案裡的其他功能也用到了GoEasy web實時推送服務,所以在此我直接就用的GoEasy推送來將登入回饋結果推送到伺服器。我的實作步驟非常簡單,將傳送的session ID當作客戶端與網頁端的通訊channel,網頁端訂閱用session ID作為值得channel,客戶端將驗證結果和session ID傳送到伺服器端,伺服器端可以透過這個channel主動將結果推送給網頁版!如果客戶端也需要做相應的回饋的話,那麼客戶端也只需要訂閱這個channel,然後伺服器端會同時將結果推送給網頁版和客戶端,收到消息後,就可以根據需求在goeasy的回調函數裡做你想做的事了。關於goeasy推送的使用,大家可以參考這篇部落格: http://www.cnblogs.com/jishaochengduo/articles/5552645.html,另外GoEasy推送官網上也有一個demo:GoEasy二維碼掃碼登入demo,大家可以去看看效果.



相關標籤:
來源:php.cn
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板