转载来自 https://www.cnblogs.com/lijingchn/p/5299000.html
UUID: 通用唯一标识符 ( Universally Unique Identifier ), 对于所有的UUID它可以保证在空间和时间上的唯一性. 它是通过MAC地址, 时间戳, 命名空间, 随机数, 伪随机数来保证生成ID的唯一性, 有着固定的大小( 128 bit ). 它的唯一性和一致性特点使得可以无需注册过程就能够产生一个新的UUID.
UUID可以被用作多种用途, 既可以用来短时间内标记一个对象, 也可以可靠的辨别网络中的持久性对象.
为什么要使用UUID?
很多应用场景需要一个id, 但是又不要求这个id 有具体的意义, 仅仅用来标识一个对象. 常见的例子有数据库表的id 字段. 另一个例子是前端的各种UI库, 因为它们通常需要动态创建各种UI元素, 这些元素需要唯一的id , 这时候就需要使用UUID了.
python提供了uuid模块
python提供了uuid模块,只需要自己通过import uuid 就可以导入使用。uuid模块提供了UUID类和uuid1(),uuid3,uuid4(),uudi5()四个函数。
以下是四个函数的总结
1.uuid.uuid1([node[, clock_seq]]):基于时间戳
使用主机ID, 序列号, 和当前时间来生成UUID, 可保证全球范围的唯一性. 但由于使用该方法生成的UUID中包含有主机的网络地址, 因此可能危及隐私. 该函数有两个参数, 如果 node 参数未指定, 系统将会自动调用 getnode() 函数来获取主机的硬件地址. 如果 clock_seq 参数未指定系统会使用一个随机产生的14位序列号来代替.
print(uuid.uuid1()) # 8c1a12cc-34e7-11e9-8fa7-80fa5b62e2dc
-
uuid.uuid3(namespace, name) : 基于名字的MD5散列值
通过计算命名空间和名字的MD5散列值来生成UUID, 可以保证同一命名空间中不同名字的唯一性和不同命名空间的唯一性, 但同一命名空间的同一名字生成的UUID相同.
namespace:随便一个uuid的属性都可以print(uuid.uuid3(uuid.NAMESPACE_URL,'pydrg')) # 6fa459ea-ee8a-3ca4-894e-db77e160355e
=============
def uuid3(namespace, name):
"""Generate a UUID from the MD5 hash of a namespace UUID and a name."""
from hashlib import md5
hash = md5(namespace.bytes + bytes(name, "utf-8")).digest()
return UUID(bytes=hash[:16], version=3)
-
uuid.uuid4() : 基于随机数
通过随机数来生成UUID. 使用的是伪随机数有一定的重复概率.print(uuid.uuid4()) # 8ac05b01-963e-48ac-a1b9-a597a26cfbcd def uuid4(): """Generate a random UUID.""" return UUID(bytes=os.urandom(16), version=4)
-
uuid.uuid5(namespace, name) : 基于名字的SHA-1散列值
通过计算命名空间和名字的SHA-1散列值来生成UUID, 算法与 uuid.uuid3() 相同.def uuid5(namespace, name): """Generate a UUID from the SHA-1 hash of a namespace UUID and a name.""" from hashlib import sha1 hash = sha1(namespace.bytes + bytes(name, "utf-8")).digest() return UUID(bytes=hash[:16], version=5)
参考资料:
Python_uuid模块参考手册 : https://docs.python.org/2/library/uuid.html
UUID算法 : http://www.ietf.org/rfc/rfc4122.txt