python-获取UUID
UUID
UUID 是 通用唯一識別碼(Universally Unique Identifier)的縮寫,是一種軟件建構(gòu)的標(biāo)準(zhǔn),亦為開放軟件基金會組織在分布式計算環(huán)境領(lǐng)域的一部分。
**UUID是由一個十六位的數(shù)字組成,表現(xiàn)出來的形式例如
**550E8400-E29B-11D4-A716-446655440000
UUID的用處
UUID在項目中文件上傳時使用
用來生成一個文件名的前綴,那么每次請求生成的前綴就會不同,從而不會讓新上傳的文件因為同名而覆蓋舊文件。
因為我工作當(dāng)中的接口需要傳uuid,所以需要封裝一個獲取uuid的方法
在python里能找到UUID的使用方法
python中的uuid模塊基于信息如MAC地址、時間戳、命名空間、隨機(jī)數(shù)、偽隨機(jī)數(shù)來uuid。
在源碼里看到具體的方法有如下幾個:
uuid.uuid1()
基于MAC地址,時間戳,隨機(jī)數(shù)來生成唯一的uuid,可以保證全球范圍內(nèi)的唯一性。
uuid.uuid2()
算法與uuid1相同,不同的是把時間戳的前4位置換為POSIX的UID。不過需要注意的是python中沒有基于DCE的算法,所以python的uuid模塊中沒有uuid2這個方法。
uuid.uuid3(namespace,name)
通過計算一個命名空間和名字的md5散列值來給出一個uuid,所以可以保證命名空間中的不同名字具有不同的uuid,但是相同的名字就是相同的uuid了。
namespace并不是一個自己手動指定的字符串或其他量,而是在uuid模塊中本身給出的一些值。比如uuid.NAMESPACE_DNS,uuid.NAMESPACE_OID,uuid.NAMESPACE_OID這些值。這些值本身也是UUID對象,根據(jù)一定的規(guī)則計算得出。
uuid.uuid4()
通過偽隨機(jī)數(shù)得到uuid,是有一定概率重復(fù)的
uuid.uuid5(namespace,name)
和uuid3基本相同,只不過采用的散列算法是sha1
一般而言,在對uuid的需求不是很復(fù)雜的時候,uuid1方法就已經(jīng)夠用了,使用方法如下:
返回的UUID碼類似這種
總結(jié)
以上是生活随笔為你收集整理的python-获取UUID的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: win10 SystemParamete
- 下一篇: Kubernetes K8s 平台中po