Python內建模組hashlib、hmac與uuid用法分析,hashlibuuid

來源:互聯網
上載者:User

Python內建模組hashlib、hmac與uuid用法分析,hashlibuuid

本文執行個體講述了Python內建模組hashlib、hmac與uuid用法。分享給大家供大家參考,具體如下:

一、hashlib

md5和sha演算法通過訊息摘要演算法產生定長的訊息摘要,訊息摘要演算法是無法復原的。但同一段訊息通過摘要演算法後得到的值是一樣的,可一通過比對訊息摘要驗證資料的完整性。

sha演算法比MD5演算法安全,但所需的時間也稍長。

1、原始訊息摘要

import hashlib# ######## md5 ########hash = hashlib.md5()hash.update('admin')print hash.hexdigest()#21232f297a57a5a743894a0e4a801fc3# ######## sha1 ########hash = hashlib.sha1()hash.update('admin')print hash.hexdigest(),len(hash.hexdigest())# d033e22ae348aeb5660fc2140aec35850c4da997 40# ######## sha256 ########hash = hashlib.sha256()hash.update('admin')print hash.hexdigest(),len(hash.hexdigest())# 8c6976e5b5410415bde908bd4dee15dfb167a9c873fc4bb8a81f6f2ab448a918 64# ######## sha384 ########hash = hashlib.sha384()hash.update('admin')print hash.hexdigest(),len(hash.hexdigest())# 9ca694a90285c034432c9550421b7b9dbd5c0f4b6673f05f6dbce58052ba20e4248041956ee8c9a2ec9f10290cdc0782 96# ######## sha512 ########hash = hashlib.sha512()hash.update('admin')print hash.hexdigest(),len(hash.hexdigest())# c7ad44cbad762a5da0a452f9e854fdc1e0e7a52a38015f23f3eab1d80b931dd472634dfac71cd34ebc35d16ab7fb8a90c81f975113d6c7538dc69dd8de9077ec 128

2、加鹽(salt)後摘要

由於同一個訊息通過摘要演算法得到的摘要是相同的,因此可以通過撞庫的方式得到原始訊息值。解決方式是,添加一個salt拼接原始訊息後再進行計算。

import hashlib# ######## md5 ########hash = hashlib.md5('898oaFs09f')hash.update('admin')print hash.hexdigest()#以上等價與hash = hashlib.md5()hash.update('898oaFs09fadmin')print hash.hexdigest()

二、HMAC

HAMC它內部對我們建立 key 和 內容 再進行處理然後再加密,相當安全。一般用於挑戰應答。

import hashlibimport hmach = hmac.new('keysstring')h.update('hello')print h.hexdigest(),len(h.hexdigest())# 2ca7ac50a9bca542e58e0baad15f8383 32

三、UUID

UUID是128位的通用唯一識別碼,通常由32位元組的字串表示。它可以保證時間和空間的唯一性,python中稱為UUID,其他語言中可能稱為GUID。

它通過MAC地址、時間戳記、命名空間、隨機數、偽隨機數來保證產生ID的唯一性。

UUID主要有五個演算法,也就是五種方法來實現:

1、uuid1()——基於時間戳記。由MAC地址、目前時間戳、隨機數產生。可以保證全球範圍內的唯一性,但MAC的使用同時帶來安全性問題,區域網路中可以使用IP來代替MAC。
2、uuid2()——基於分散式運算。環境DCE(Python中沒有這個函數)演算法與uuid1相同,不同的是把時間戳記的前4位置換為POSIX的UID。實際中很少用到該方法。
3、uuid3()——基於名字的MD5散列值。通過計算名字和命名空間的MD5散列值得到,保證了同一命名空間中不同名字的唯一性,和不同命名空間的唯一性,但同一命名空間的同一名字產生相同的uuid。
4、uuid4()——基於隨機數。由偽隨機數得到,有一定的重複機率,該機率可以計算出來。
5、uuid5()——基於名字的SHA-1散列值。演算法與uuid3相同,不同的是使用 SHA-1演算法。

python中沒有實現uuid2演算法。

import uuidprint uuid.uuid1()print uuid.uuid3(uuid.NAMESPACE_DNS, 'testme')print uuid.uuid4()print uuid.uuid5(uuid.NAMESPACE_DNS, 'testme')# 1a52b39e-a197-11e6-b5c6-8056f2d4c814# 7a67f5d4-50fd-36f7-bbeb-1c739ab40b8c# 0c0cc4f0-6ad0-40d3-a796-119dcfaddf60# dac48d1f-a443-578c-8754-856842a2f98d

PS:關於加密解密感興趣的朋友還可以參考本站線上工具:

文字線上加密解密工具(包含AES、DES、RC4等):
http://tools.jb51.net/password/txt_encode

MD5線上加密工具:
http://tools.jb51.net/password/CreateMD5Password

線上散列/雜湊演算法加密工具:
http://tools.jb51.net/password/hash_encrypt

線上MD5/hash/SHA-1/SHA-2/SHA-256/SHA-512/SHA-3/RIPEMD-160加密工具:
http://tools.jb51.net/password/hash_md5_sha

線上sha1/sha224/sha256/sha384/sha512加密工具:
http://tools.jb51.net/password/sha_encode

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.