java生成随机字符串uuid

转自:https://www.cnblogs.com/yadongliang/p/5481410.htmlhtml

GUID是一个128位长的数字,通常用16进制表示。算法的核心思想是结合机器的网卡、当地时间、一个随机数来生成GUID。从理论上讲,若是一台机器每秒产生10000000个GUID,则能够保证(几率意义上)3240年不重复。java

UUID是1.5中新增的一个类,在java.util下,用它能够产生一个号称全球惟一的ID:算法

复制代码
package com.mytest; import java.util.UUID; public class UTest { public static void main(String[] args) { UUID uuid = UUID.randomUUID(); System.out.println(uuid); } } 
复制代码

UUID(Universally Unique Identifier)全局惟一标识符,是指在一台机器上生成的数字,它保证对在同一时空中的全部机器都是惟一的。按照开放软件基金会(OSF)制定的标准计算,用到了以太网卡地址、纳秒级时间、芯片ID码和许多可能的数字。由如下几部分的组合:当前日期和时间(UUID的第一个部分与时间有关,若是你在生成一个UUID以后,过几秒又生成一个UUID,则第一个部分不一样,其他相同),时钟序列,全局惟一的IEEE机器识别号(若是有网卡,从网卡得到,没有网卡以其余方式得到),UUID的惟一缺陷在于生成的结果串会比较长。 关于UUID这个标准使用最广泛的是微软的GUID(Globals Unique Identifiers)。数据库

在Java中生成UUID主要有如下几种方式:dom

JDK1.5
若是使用的JDK1.5的话,那么生成UUID变成了一件简单的事,觉得JDK实现了UUID:
java.util.UUID,直接调用便可.
分布式

UUID uuid = UUID.randomUUID(); String s = UUID.randomUUID().toString();//用来生成数据库的主键id很是不错。。

UUID是由一个十六位的数字组成,表现出来的形式例如 函数

550E8400-E29B-11D4-A716-446655440000

===================================================分割线==================================================ui

 

UUID含义是通用惟一识别码 (Universally Unique Identifier),这 是一个软件建构的标准,也是被开源软件基金会 (Open Software Foundation, OSF) 的组织在分布式计算环境 (Distributed Computing Environment, DCE) 领域的一部份。UUID 的目的,是让分布式系统中的全部元素,都能有惟一的辨识资讯,而不须要透过中央控制端来作辨识资讯的指定。如此一来,每一个人均可以创建不与其它人冲突的 UUID。在这样的状况下,就不需考虑数据库创建时的名称重复问题。目前最普遍应用的 UUID,便是微软的 Microsoft's Globally Unique Identifiers (GUIDs),而其余重要的应用,则有 Linux ext2/ext3 档案系统、LUKS 加密分割区、GNOME、KDE、Mac OS X 等等。加密

如下是具体生成UUID的例子:spa

复制代码
package test; import java.util.UUID; public class UUIDGenerator {   public UUIDGenerator() {   }   public static String getUUID() {     UUID uuid = UUID.randomUUID();     String str = uuid.toString();     // 去掉"-"符号     String temp = str.substring(0, 8) + str.substring(9, 13) + str.substring(14, 18) + str.substring(19, 23) + str.substring(24);       return str+","+temp;     }     //得到指定数量的UUID     public static String[] getUUID(int number) {     if (number < 1) {       return null;     }       String[] ss = new String[number];       for (int i = 0; i < number; i++) {         ss[i] = getUUID();       }       return ss;     }   public static void main(String[] args) {     String[] ss = getUUID(10);     for (int i = 0; i < ss.length; i++) {       System.out.println("ss["+i+"]====="+ss[i]);     }   } }
复制代码

结果:

复制代码
view plaincopy to clipboardprint? ss[0]=====4cdbc040-657a-4847-b266-7e31d9e2c3d9,4cdbc040657a4847b2667e31d9e2c3d9 ss[1]=====72297c88-4260-4c05-9b05-d28bfb11d10b,72297c8842604c059b05d28bfb11d10b ss[2]=====6d513b6a-69bd-4f79-b94c-d65fc841ea95,6d513b6a69bd4f79b94cd65fc841ea95 ss[3]=====d897a7d3-87a3-4e38-9e0b-71013a6dbe4c,d897a7d387a34e389e0b71013a6dbe4c ss[4]=====5709f0ba-31e3-42bd-a28d-03485b257c94,5709f0ba31e342bda28d03485b257c94 ss[5]=====530fbb8c-eec9-48d1-ae1b-5f792daf09f3,530fbb8ceec948d1ae1b5f792daf09f3 ss[6]=====4bf07297-65b2-45ca-b905-6fc6f2f39158,4bf0729765b245cab9056fc6f2f39158 ss[7]=====6e5a0e85-b4a0-485f-be54-a758115317e1,6e5a0e85b4a0485fbe54a758115317e1 ss[8]=====245accec-3c12-4642-967f-e476cef558c4,245accec3c124642967fe476cef558c4 ss[9]=====ddd4b5a9-fecd-446c-bd78-63b70bb500a1,ddd4b5a9fecd446cbd7863b70bb500a1 ss[0]=====4cdbc040-657a-4847-b266-7e31d9e2c3d9,4cdbc040657a4847b2667e31d9e2c3d9 ss[1]=====72297c88-4260-4c05-9b05-d28bfb11d10b,72297c8842604c059b05d28bfb11d10b ss[2]=====6d513b6a-69bd-4f79-b94c-d65fc841ea95,6d513b6a69bd4f79b94cd65fc841ea95 ss[3]=====d897a7d3-87a3-4e38-9e0b-71013a6dbe4c,d897a7d387a34e389e0b71013a6dbe4c ss[4]=====5709f0ba-31e3-42bd-a28d-03485b257c94,5709f0ba31e342bda28d03485b257c94 ss[5]=====530fbb8c-eec9-48d1-ae1b-5f792daf09f3,530fbb8ceec948d1ae1b5f792daf09f3 ss[6]=====4bf07297-65b2-45ca-b905-6fc6f2f39158,4bf0729765b245cab9056fc6f2f39158 ss[7]=====6e5a0e85-b4a0-485f-be54-a758115317e1,6e5a0e85b4a0485fbe54a758115317e1 ss[8]=====245accec-3c12-4642-967f-e476cef558c4,245accec3c124642967fe476cef558c4 ss[9]=====ddd4b5a9-fecd-446c-bd78-63b70bb500a1,ddd4b5a9fecd446cbd7863b70bb500a1
复制代码

  能够看出,UUID 是指在一台机器上生成的数字,它保证对在同一时空中的全部机器都是惟一的。一般平台会提供生成的API。按照开放软件基金会(OSF)制定的标准计算,用到了以太网卡地址、纳秒级时间、芯片ID码和许多可能的数字

  UUID由如下几部分的组合:

  (1)当前日期和时间,UUID的第一个部分与时间有关,若是你在生成一个UUID以后,过几秒又生成一个UUID,则第一个部分不一样,其他相同。

  (2)时钟序列

  (3)全局惟一的IEEE机器识别号,若是有网卡,从网卡MAC地址得到,没有网卡以其余方式得到。

  UUID的惟一缺陷在于生成的结果串会比较长。关于UUID这个标准使用最广泛的是微软的GUID(Globals Unique Identifiers)。在ColdFusion中能够用CreateUUID()函数很简单的生成UUID,其格式为:xxxxxxxx-xxxx- xxxx-xxxxxxxxxxxxxxxx(8-4-4-16),其中每一个 x 是 0-9 或 a-f 范围内的一个十六进制的数字。而标准的UUID格式为:xxxxxxxx-xxxx-xxxx-xxxxxx-xxxxxxxxxx (8-4-4-4-12),能够从cflib 下载CreateGUID() UDF进行转换。

  使用UUID的好处在分布式的软件系统中(好比:DCE/RPC, COM+,CORBA)就能体现出来,它能保证每一个节点所生成的标识都不会重复,而且随着WEB服务等整合技术的发展,UUID的优点将更加明显。根据使用的特定机制,UUID不只须要保证是彼此不相同的,或者最少也是与公元3400年以前其余任何生成的通用唯一标识符有很是大的区别。

  通用唯一标识符还能够用来指向大多数的可能的物体。微软和其余一些软件公司都倾向使用全球唯一标识符(GUID),这也是通用唯一标识符的一种类型,可用来指向组建对象模块对象和其余的软件组件。第一个通用唯一标识符是在网罗计算机系统(NCS)中建立,而且随后成为开放软件基金会(OSF)的分布式计算环境(DCE)的组件。

相关文章
相关标签/搜索