最近在做一個掃碼登入功能,為此我還在網路上搜了一下關於微信的掃描登入的實作方式。當這個功能完成了後,我決定將整個實現思路整理出來,方便自己以後查看也方便其他有類似需求的程式猿些。
要實現掃碼登入我們需要解決兩個問題:
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,大家可以去看看效果.

Python在自動化、腳本編寫和任務管理中表現出色。 1)自動化:通過標準庫如os、shutil實現文件備份。 2)腳本編寫:使用psutil庫監控系統資源。 3)任務管理:利用schedule庫調度任務。 Python的易用性和豐富庫支持使其在這些領域中成為首選工具。

要在有限的時間內最大化學習Python的效率,可以使用Python的datetime、time和schedule模塊。 1.datetime模塊用於記錄和規劃學習時間。 2.time模塊幫助設置學習和休息時間。 3.schedule模塊自動化安排每週學習任務。

Python在遊戲和GUI開發中表現出色。 1)遊戲開發使用Pygame,提供繪圖、音頻等功能,適合創建2D遊戲。 2)GUI開發可選擇Tkinter或PyQt,Tkinter簡單易用,PyQt功能豐富,適合專業開發。

Python适合数据科学、Web开发和自动化任务,而C 适用于系统编程、游戏开发和嵌入式系统。Python以简洁和强大的生态系统著称,C 则以高性能和底层控制能力闻名。

2小時內可以學會Python的基本編程概念和技能。 1.學習變量和數據類型,2.掌握控制流(條件語句和循環),3.理解函數的定義和使用,4.通過簡單示例和代碼片段快速上手Python編程。

Python在web開發、數據科學、機器學習、自動化和腳本編寫等領域有廣泛應用。 1)在web開發中,Django和Flask框架簡化了開發過程。 2)數據科學和機器學習領域,NumPy、Pandas、Scikit-learn和TensorFlow庫提供了強大支持。 3)自動化和腳本編寫方面,Python適用於自動化測試和系統管理等任務。

兩小時內可以學到Python的基礎知識。 1.學習變量和數據類型,2.掌握控制結構如if語句和循環,3.了解函數的定義和使用。這些將幫助你開始編寫簡單的Python程序。

如何在10小時內教計算機小白編程基礎?如果你只有10個小時來教計算機小白一些編程知識,你會選擇教些什麼�...


熱AI工具

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

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

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

AI Hentai Generator
免費產生 AI 無盡。

熱門文章

熱工具

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

SublimeText3漢化版
中文版,非常好用

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

SublimeText3 英文版
推薦:為Win版本,支援程式碼提示!

mPDF
mPDF是一個PHP庫,可以從UTF-8編碼的HTML產生PDF檔案。原作者Ian Back編寫mPDF以從他的網站上「即時」輸出PDF文件,並處理不同的語言。與原始腳本如HTML2FPDF相比,它的速度較慢,並且在使用Unicode字體時產生的檔案較大,但支援CSS樣式等,並進行了大量增強。支援幾乎所有語言,包括RTL(阿拉伯語和希伯來語)和CJK(中日韓)。支援嵌套的區塊級元素(如P、DIV),