来自:http://www.cnblogs.com/jdonson/archive/2009/07/22/1528466.html
基本原理:GUID是一个128位长的数字,一般用16进制表示。算法的核心思想是结合机器的网卡、当地时间、一个随即数来生成GUID。从理论上讲,如果一台机器每秒产生10000000个GUID,则可以保证(概率意义上)3240年不重复。
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的唯一缺陷在于生成的结果串会比较长。
在Java中生成UUID主要有以下几种方式:
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
![](https://images.cnblogs.com/OutliningIndicators/ContractedBlock.gif)
1 //下面就是实现为数据库获取一个唯一的主键id的代码 2 public class UUIDGenerator { 3 public UUIDGenerator() { 4 } 5 /** 6 * 获得一个UUID 7 * @return String UUID 8 */ 9 public static String getUUID(){ 10 String s = UUID.randomUUID().toString(); 11 //去掉“-”符号 12 return s.substring(0,8)+s.substring(9,13)+s.substring(14,18)+s.substring(19,23)+s.substring(24); 13 } 14 /** 15 * 获得指定数目的UUID 16 * @param number int 需要获得的UUID数量 17 * @return String[] UUID数组 18 */ 19 public static String[] getUUID(int number){ 20 if(number < 1){ 21 return null; 22 } 23 String[] ss = new String[number]; 24 for(int i=0;i<number;i++){ 25 ss[i] = getUUID(); 26 } 27 return ss; 28 } 29 public static void main(String[] args){ 30 String[] ss = getUUID(10); 31 for(int i=0;i<ss.length;i++){ 32 System.out.println(ss[i]); 33 } 34 } 35 }
两种方式生成guid 与uuid
需要comm log 库
1 /** 2 * @author Administrator 3 * 4 * TODO To change the template for this generated type comment go to 5 * Window - Preferences - Java - Code Style - Code Templates 6 */ 7 import java.net.InetAddress; 8 import java.net.UnknownHostException; 9 import java.security.MessageDigest; 10 import java.security.NoSuchAlgorithmException; 11 import java.security.SecureRandom; 12 import java.util.Random; 13 14 public class RandomGUID extends Object { 15 protected final org.apache.commons.logging.Log logger = org.apache.commons.logging.LogFactory 16 .getLog(getClass()); 17 18 public String valueBeforeMD5 = ""; 19 public String valueAfterMD5 = ""; 20 private static Random myRand; 21 private static SecureRandom mySecureRand; 22 23 private static String s_id; 24 private static final int PAD_BELOW = 0x10; 25 private static final int TWO_BYTES = 0xFF; 26 27 /* 28 * Static block to take care of one time secureRandom seed. 29 * It takes a few seconds to initialize SecureRandom. You might 30 * want to consider removing this static block or replacing 31 * it with a "time since first loaded" seed to reduce this time. 32 * This block will run only once per JVM instance. 33 */ 34 35 static { 36 mySecureRand = new SecureRandom(); 37 long secureInitializer = mySecureRand.nextLong(); 38 myRand = new Random(secureInitializer); 39 try { 40 s_id = InetAddress.getLocalHost().toString(); 41 } catch (UnknownHostException e) { 42 e.printStackTrace(); 43 } 44 45 }
1 /* 2 * Default constructor. With no specification of security option, 3 * this constructor defaults to lower security, high performance. 4 */ 5 public RandomGUID() { 6 getRandomGUID(false); 7 } 8 9 /* 10 * Constructor with security option. Setting secure true 11 * enables each random number generated to be cryptographically 12 * strong. Secure false defaults to the standard Random function seeded 13 * with a single cryptographically strong random number. 14 */ 15 public RandomGUID(boolean secure) { 16 getRandomGUID(secure); 17 } 18 19 /* 20 * Method to generate the random GUID 21 */ 22 private void getRandomGUID(boolean secure) { 23 MessageDigest md5 = null; 24 StringBuffer sbValueBeforeMD5 = new StringBuffer(128); 25 26 try { 27 md5 = MessageDigest.getInstance("MD5"); 28 } catch (NoSuchAlgorithmException e) { 29 logger.error("Error: " + e); 30 } 31 32 try { 33 long time = System.currentTimeMillis(); 34 long rand = 0; 35 36 if (secure) { 37 rand = mySecureRand.nextLong(); 38 } else { 39 rand = myRand.nextLong(); 40 } 41 sbValueBeforeMD5.append(s_id); 42 sbValueBeforeMD5.append(":"); 43 sbValueBeforeMD5.append(Long.toString(time)); 44 sbValueBeforeMD5.append(":"); 45 sbValueBeforeMD5.append(Long.toString(rand)); 46 47 valueBeforeMD5 = sbValueBeforeMD5.toString(); 48 md5.update(valueBeforeMD5.getBytes()); 49 50 byte[] array = md5.digest(); 51 StringBuffer sb = new StringBuffer(32); 52 for (int j = 0; j < array.length; ++j) { 53 int b = array[j] & TWO_BYTES; 54 if (b < PAD_BELOW) 55 sb.append('0'); 56 sb.append(Integer.toHexString(b)); 57 } 58 59 valueAfterMD5 = sb.toString(); 60 61 } catch (Exception e) { 62 logger.error("Error:" + e); 63 } 64 } 65 66 /* 67 * Convert to the standard format for GUID 68 * (Useful for SQL Server UniqueIdentifiers, etc.) 69 * Example: C2FEEEAC-CFCD-11D1-8B05-00600806D9B6 70 */ 71 public String toString() { 72 String raw = valueAfterMD5.toUpperCase(); 73 StringBuffer sb = new StringBuffer(64); 74 sb.append(raw.substring(0, 8)); 75 sb.append("-"); 76 sb.append(raw.substring(8, 12)); 77 sb.append("-"); 78 sb.append(raw.substring(12, 16)); 79 sb.append("-"); 80 sb.append(raw.substring(16, 20)); 81 sb.append("-"); 82 sb.append(raw.substring(20)); 83 84 return sb.toString(); 85 } 86 87 88 // Demonstraton and self test of class 89 public static void main(String args[]) { 90 for (int i=0; i< 100; i++) { 91 RandomGUID myGUID = new RandomGUID(); 92 System.out.println("Seeding String=" + myGUID.valueBeforeMD5); 93 System.out.println("rawGUID=" + myGUID.valueAfterMD5); 94 System.out.println("RandomGUID=" + myGUID.toString()); 95 } 96 } 97 98 99 }
同样
1 UUID uuid = UUID.randomUUID(); 2 System.out.println("{"+uuid.toString()+"}");
UUID是指在一台机器上生成的数字,它保证对在同一时空中的所有机器都是唯一的。通常平台会提供生成UUID的API。UUID按照开放软件基金会(OSF)制定的标准计算,用到了以太网卡地址、纳秒级时间、芯片ID码和许多可能的数字。由以下几部分的组合:当前日期和时间(UUID的第一个部分与时间有关,如果你在生成一个UUID之后,过几秒又生成一个UUID,则第一个部分不同,其余相同),时钟序列,全局唯一的IEEE机器识别号(如果有网卡,从网卡获得,没有网卡以其他方式获得),UUID的唯一缺陷在于生成的结果串会比较长。关于UUID这个标准使用最普遍的是微软的GUID(Globals Unique Identifiers)。
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的例子:
view plaincopy to clipboardprint?
1 package test; 2 3 import java.util.UUID; 4 5 public class UUIDGenerator { 6 public UUIDGenerator() { 7 } 8 9 public static String getUUID() { 10 UUID uuid = UUID.randomUUID(); 11 String str = uuid.toString(); 12 // 去掉"-"符号 13 String temp = str.substring(0, 8) + str.substring(9, 13) + str.substring(14, 18) + str.substring(19, 23) + str.substring(24); 14 return str+","+temp; 15 } 16 //获得指定数量的UUID 17 public static String[] getUUID(int number) { 18 if (number < 1) { 19 return null; 20 } 21 String[] ss = new String[number]; 22 for (int i = 0; i < number; i++) { 23 ss[i] = getUUID(); 24 } 25 return ss; 26 } 27 28 public static void main(String[] args) { 29 String[] ss = getUUID(10); 30 for (int i = 0; i < ss.length; i++) { 31 System.out.println("ss["+i+"]====="+ss[i]); 32 } 33 } 34 }
1 package test; 2 3 import java.util.UUID; 4 5 public class UUIDGenerator { 6 public UUIDGenerator() { 7 } 8 9 public static String getUUID() { 10 UUID uuid = UUID.randomUUID(); 11 String str = uuid.toString(); 12 // 去掉"-"符号 13 String temp = str.substring(0, 8) + str.substring(9, 13) + str.substring(14, 18) + str.substring(19, 23) + str.substring(24); 14 return str+","+temp; 15 } 16 //获得指定数量的UUID 17 public static String[] getUUID(int number) { 18 if (number < 1) { 19 return null; 20 } 21 String[] ss = new String[number]; 22 for (int i = 0; i < number; i++) { 23 ss[i] = getUUID(); 24 } 25 return ss; 26 } 27 28 public static void main(String[] args) { 29 String[] ss = getUUID(10); 30 for (int i = 0; i < ss.length; i++) { 31 System.out.println("ss["+i+"]====="+ss[i]); 32 } 33 } 34 }
结果:
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)的组件。
本文来自CSDN博客,转载请标明出处:http://blog.csdn.net/carefree31441/archive/2009/03/17/3998553.aspx