我正在編寫一個調用各種 API 的應用程序。每個 API 都有自己的日志記錄,我想讓跟蹤所有各種日志文件的事務變得容易。為此,我在事務開始時創建一個唯一(ish)字符串,記錄它,并將該字符串傳遞給其他 API,以便它們都可以將其包含在日志記錄中。這是我正在使用的代碼:s = '%s %s' % (username, datetime.datetime.now())token = hashlib.md5(s.encode('utf-8')).hexdigest()這運行良好,但仍有改進的余地。 hexdigest()(顯然)只使用十六進制字符,即0-9和a-f. 如果我偶爾遇到令牌沖突,我不會太在意,但我想盡可能避免它。是否有類似的函數可以使用所有 26 個字母?
2 回答

慕標琳琳
TA貢獻1830條經驗 獲得超9個贊
嘗試https://en.wikipedia.org/wiki/Ascii85及其 URL 安全變體以獲得更密集的表示。
當然,您必須對原始字節進行編碼。(此外,從加密的角度來看,MD5 是一個糟糕的選擇,SHA2 更好。)

一只名叫tom的貓
TA貢獻1906條經驗 獲得超3個贊
您可以對數據進行哈希處理,然后使用 base64 對哈希進行編碼,而不是直接獲取十六進制摘要:
s = '%s %s' % (username, datetime.datetime.now())
digest = hashlib.md5(s.encode('utf-8')).digest()
token = base64.b64encode(digest)
這使用所有 26×2+10 = 62 個字母數字字符,加上+和/。
您的實現可能會產生如下內容:
d88cc7dea0fee57975187d4b30950f7b
用 base64 編碼會稍微減少長度:
2IzH3qD+5Xl1GH1LMJUPew==
然而,如果你想避免沖突,你需要增加摘要的長度——所以使用像 SHA512 這樣的散列函數,而不是 MD5,甚至只是生成一個隨機數!
添加回答
舉報
0/150
提交
取消