Py的UUID介紹

UUID —— Universally Unique IDentifier 是128位的全局唯一標識符,通常由32字節的字符串表示。 它可以保證時間和空間的唯一性,也稱爲GUID,Python 中叫 UUID ,C# 中叫 GUID —— Globally Unique IDentifier ,它通過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相同,不同的是使用 Secure Hash Algorithm 1 算法使用方面: 

 首先,Python中沒有基於DCE的,所以uuid2可以忽略; 

 其次,uuid4存在概率性重複,由無映射性,最好不用; 

 再次,若在Global的分佈式計算環境下,最好用uuid1; 

 最後,若有名字的唯一性要求,最好用uuid3或uuid5。 

 例子:

>>> import uuid 

>>> uuid.uuid1() UUID('488c39c0-c2a4-11e1-93a3-60d819fc4d9b')

>>> str(uuid.uuid1())'50308e0f-c2a4-11e1-a6e4-60d819fc4d9b' 

>>> str(uuid.uuid1()).replace('-','') '5cbe8380c2a411e1b5fd60d819fc4d9b' 

>>> str(uuid.uuid1()).replace('-','')[0:15] '62c1f90fc2a411e'

>>>dir(uuid)>>>dir(uuid.uuid1())

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章