Python 實現(xiàn)簡單的客戶端認(rèn)證
問題
你想在分布式系統(tǒng)中實現(xiàn)一個簡單的客戶端連接認(rèn)證功能,又不想像SSL那樣的復(fù)雜。
解決方案
可以利用 hmac 模塊實現(xiàn)一個連接握手,從而實現(xiàn)一個簡單而高效的認(rèn)證過程。下面是代碼示例:
import hmac import os def client_authenticate(connection, secret_key): ''' Authenticate client to a remote service. connection represents a network connection. secret_key is a key known only to both client/server. ''' message = connection.recv(32) hash = hmac.new(secret_key, message) digest = hash.digest() connection.send(digest) def server_authenticate(connection, secret_key): ''' Request client authentication. ''' message = os.urandom(32) connection.send(message) hash = hmac.new(secret_key, message) digest = hash.digest() response = connection.recv(len(digest)) return hmac.compare_digest(digest,response)
基本原理是當(dāng)連接建立后,服務(wù)器給客戶端發(fā)送一個隨機的字節(jié)消息(這里例子中使用了 os.urandom() 返回值)。 客戶端和服務(wù)器同時利用hmac和一個只有雙方知道的密鑰來計算出一個加密哈希值。然后客戶端將它計算出的摘要發(fā)送給服務(wù)器, 服務(wù)器通過比較這個值和自己計算的是否一致來決定接受或拒絕連接。摘要的比較需要使用 hmac.compare_digest() 函數(shù)。 使用這個函數(shù)可以避免遭到時間分析攻擊,不要用簡單的比較操作符(==)。 為了使用這些函數(shù),你需要將它集成到已有的網(wǎng)絡(luò)或消息代碼中。例如,對于sockets,服務(wù)器代碼應(yīng)該類似下面:
from socket import socket, AF_INET, SOCK_STREAM secret_key = b'peekaboo' def echo_handler(client_sock): if not server_authenticate(client_sock, secret_key): client_sock.close() return while True: msg = client_sock.recv(8192) if not msg: break client_sock.sendall(msg) def echo_server(address): s = socket(AF_INET, SOCK_STREAM) s.bind(address) s.listen(5) while True: c,a = s.accept() echo_handler(c) echo_server(('', 18000)) Within a client, you would do this: from socket import socket, AF_INET, SOCK_STREAM secret_key = b'peekaboo' s = socket(AF_INET, SOCK_STREAM) s.connect(('localhost', 18000)) client_authenticate(s, secret_key) s.send(b'Hello World') resp = s.recv(1024)
討論
hmac 認(rèn)證的一個常見使用場景是內(nèi)部消息通信系統(tǒng)和進程間通信。 例如,如果你編寫的系統(tǒng)涉及到一個集群中多個處理器之間的通信, 你可以使用本節(jié)方案來確保只有被允許的進程之間才能彼此通信。 事實上,基于 hmac 的認(rèn)證被 multiprocessing 模塊使用來實現(xiàn)子進程直接的通信。
還有一點需要強調(diào)的是連接認(rèn)證和加密是兩碼事。 認(rèn)證成功之后的通信消息是以明文形式發(fā)送的,任何人只要想監(jiān)聽這個連接線路都能看到消息(盡管雙方的密鑰不會被傳輸)。
hmac認(rèn)證算法基于哈希函數(shù)如MD5和SHA-1,關(guān)于這個在IETF RFC 2104中有詳細(xì)介紹。
以上就是Python 實現(xiàn)簡單的客戶端認(rèn)證的詳細(xì)內(nèi)容,更多關(guān)于Python 客戶端認(rèn)證的資料請關(guān)注腳本之家其它相關(guān)文章!
- PythonPC客戶端自動化實現(xiàn)原理(pywinauto)
- python中的socket實現(xiàn)ftp客戶端和服務(wù)器收發(fā)文件及md5加密文件
- python mqtt 客戶端的實現(xiàn)代碼實例
- python使用多線程編寫tcp客戶端程序
- 基于Python的ModbusTCP客戶端實現(xiàn)詳解
- python實現(xiàn)websocket的客戶端壓力測試
- python3+PyQt5 創(chuàng)建多線程網(wǎng)絡(luò)應(yīng)用-TCP客戶端和TCP服務(wù)器實例
- Python一個簡單的通信程序(客戶端 服務(wù)器)
- python如何創(chuàng)建TCP服務(wù)端和客戶端
- python搭建服務(wù)器實現(xiàn)兩個Android客戶端間收發(fā)消息
相關(guān)文章
spark dataframe 將一列展開,把該列所有值都變成新列的方法
今天小編就為大家分享一篇spark dataframe 將一列展開,把該列所有值都變成新列的方法,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2019-01-01Python數(shù)據(jù)可視化處理庫PyEcharts柱狀圖,餅圖,線性圖,詞云圖常用實例詳解
這篇文章主要介紹了Python數(shù)據(jù)可視化處理庫PyEcharts柱狀圖、餅圖、線性圖常用實例詳解,需要的朋友可以參考下2020-02-02Python實現(xiàn)捕獲異常發(fā)生的文件和具體行數(shù)
這篇文章主要介紹了Python實現(xiàn)捕獲異常發(fā)生的文件和具體行數(shù)。具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2020-04-04Python使用quote()函數(shù)對接口請求值進行URL編碼
在接口測試自動化中,我們經(jīng)常會遇到需要構(gòu)建HTTP請求的情況,尤其是POST請求,確保所有的參數(shù)都正確地進行了URL編碼是非常重要的一步,Python標(biāo)準(zhǔn)庫中的urllib.parse.quote函數(shù)就是專門用來進行這種轉(zhuǎn)碼的工具,所以本文介紹了使用quote()函數(shù)對接口請求值進行URL編碼2024-08-08