`
BucketLi
  • 浏览: 195819 次
  • 性别: Icon_minigender_1
  • 来自: 杭州
博客专栏
5a76a659-f8e6-3bf3-b39a-8ae8f7a0f9d9
Percolator与分布...
浏览量:5686
社区版块
存档分类
最新评论

java唯一ID生成

阅读更多
package com.taobao.tddl.client.util;

import java.io.IOException;
import java.io.UnsupportedEncodingException;
import java.net.InetAddress;
import java.security.MessageDigest;
import java.security.NoSuchAlgorithmException;
import java.security.SecureRandom;
import java.util.HashMap;
import java.util.Map;
import java.util.Random;
import java.util.concurrent.atomic.AtomicLong;
import java.util.concurrent.locks.ReentrantLock;

/**
 * @author huangshang
 * 
 */
public class UniqId {
	private static char[] digits = { '0', '1', '2', '3', '4', '5', '6', '7',
			'8', '9', 'a', 'b', 'c', 'd', 'e', 'f' };

	private static Map<Character, Integer> rDigits = new HashMap<Character, Integer>(
			16);
	static {
		for (int i = 0; i < digits.length; ++i) {
			rDigits.put(digits[i], i);
		}
	}

	private static UniqId me = new UniqId();
	private String hostAddr;
	private Random random = new SecureRandom();
	private MessageDigest mHasher;
	private UniqTimer timer = new UniqTimer();

	private ReentrantLock opLock = new ReentrantLock();

	private UniqId() {
		try {
			InetAddress addr = InetAddress.getLocalHost();

			hostAddr = addr.getHostAddress();
		} catch (IOException e) {
			hostAddr = String.valueOf(System.currentTimeMillis());
		}

		if (hostAddr == null || hostAddr.length() == 0
				|| "127.0.0.1".equals(hostAddr)) {
			hostAddr = String.valueOf(System.currentTimeMillis());
		}

		try {
			mHasher = MessageDigest.getInstance("MD5");
		} catch (NoSuchAlgorithmException nex) {
			mHasher = null;
		}
	}

	/**
	 * 获取UniqID实例
	 * 
	 * @return UniqId
	 */
	public static UniqId getInstance() {
		return me;
	}

	/**
	 * 获得不会重复的毫秒数
	 * 
	 * @return
	 */
	public long getUniqTime() {
		return timer.getCurrentTime();
	}

	/**
	 * 获得UniqId
	 * 
	 * @return uniqTime-randomNum-hostAddr-threadId
	 */
	public String getUniqID() {
		StringBuffer sb = new StringBuffer();
		long t = timer.getCurrentTime();

		sb.append(t);

		sb.append("-");

		sb.append(random.nextInt(8999) + 1000);

		sb.append("-");
		sb.append(hostAddr);

		sb.append("-");
		sb.append(Thread.currentThread().hashCode());

		return sb.toString();
	}

	/**
	 * 获取MD5之后的uniqId string
	 * 
	 * @return uniqId md5 string
	 */
	public String getUniqIDHashString() {
		return hashString(getUniqID());
	}

	/**
	 * 获取MD5之后的uniqId
	 * 
	 * @return byte[16]
	 */
	public byte[] getUniqIDHash() {
		return hash(getUniqID());
	}

	/**
	 * 对字符串进行md5
	 * 
	 * @param str
	 * @return md5 byte[16]
	 */
	public byte[] hash(String str) {
		opLock.lock();
		try {
			byte[] bt = mHasher.digest(str.getBytes("UTF-8"));
			if (null == bt || bt.length != 16) {
				throw new IllegalArgumentException("md5 need");
			}
			return bt;
		} catch (UnsupportedEncodingException e) {
			throw new RuntimeException("unsupported utf-8 encoding", e);
		} finally {
			opLock.unlock();
		}
	}

	/**
	 * 对二进制数据进行md5
	 * 
	 * @param str
	 * @return md5 byte[16]
	 */
	public byte[] hash(byte[] data) {
		opLock.lock();
		try {
			byte[] bt = mHasher.digest(data);
			if (null == bt || bt.length != 16) {
				throw new IllegalArgumentException("md5 need");
			}
			return bt;
		} finally {
			opLock.unlock();
		}
	}

	/**
	 * 对字符串进行md5 string
	 * 
	 * @param str
	 * @return md5 string
	 */
	public String hashString(String str) {
		byte[] bt = hash(str);
		return bytes2string(bt);
	}

	/**
	 * 对字节流进行md5 string
	 * 
	 * @param str
	 * @return md5 string
	 */
	public String hashBytes(byte[] str) {
		byte[] bt = hash(str);
		return bytes2string(bt);
	}

	/**
	 * 将一个字节数组转化为可见的字符串
	 * 
	 * @param bt
	 * @return
	 */
	public String bytes2string(byte[] bt) {
		int l = bt.length;

		char[] out = new char[l << 1];

		for (int i = 0, j = 0; i < l; i++) {
			out[j++] = digits[(0xF0 & bt[i]) >>> 4];
			out[j++] = digits[0x0F & bt[i]];
		}

		return new String(out);
	}

	/**
	 * 将字符串转换为bytes
	 * 
	 * @param str
	 * @return byte[]
	 */
	public byte[] string2bytes(String str) {
		if (null == str) {
			throw new NullPointerException("参数不能为空");
		}
		if (str.length() != 32) {
			throw new IllegalArgumentException("字符串长度必须是32");
		}
		byte[] data = new byte[16];
		char[] chs = str.toCharArray();
		for (int i = 0; i < 16; ++i) {
			int h = rDigits.get(chs[i * 2]).intValue();
			int l = rDigits.get(chs[i * 2 + 1]).intValue();
			data[i] = (byte) ((h & 0x0F) << 4 | (l & 0x0F));
		}
		return data;
	}

	/**
	 * 实现不重复的时间
	 * 
	 * @author dogun
	 */
	private static class UniqTimer {
		private AtomicLong lastTime = new AtomicLong(System.currentTimeMillis());

		public long getCurrentTime() {
			return this.lastTime.incrementAndGet();
		}
	}
}
分享到:
评论
2 楼 BucketLi 2014-10-17  
wangjian95 写道
tddl.....?

不是
1 楼 wangjian95 2014-07-28  
tddl.....?

相关推荐

    java根据时间生成唯一ID

    java根据时间生成唯一ID,普通的根据时间生成的ID放在循环内很容易重复。

    java语言生成唯一ID的方法

    ##### 唯一ID生成逻辑 1. **时间戳**:获取当前时间的毫秒数,确保每个ID的时间部分不同。 2. **随机数**:使用`SecureRandom`生成随机数,增加ID的随机性。 3. **主机地址**:获取主机IP地址,用于区分不同主机...

    java 获取分布式唯一ID.雪花ID

    在Java开发中,生成分布式唯一ID是常见的需求,特别是在大数据量和高并发的场景下,保证每个记录的ID独特性至关重要。雪花ID(Snowflake ID)是一种被广泛采用的解决方案,由Twitter开源,其设计目标就是生成全局...

    java基于雪花算法的唯一ID生成器

    java基于雪花算法的唯一ID生成器

    Springboot唯一编号整合,vesta全局唯一id生成器

    本篇将详细讲解如何在SpringBoot项目中整合Vesta ID Generator,以实现高效、可靠的全局唯一ID生成。 Vesta ID Generator是基于Twitter的Snowflake算法实现的,该算法的主要特点是将64位整数分为几个部分:时间戳...

    官方Java端口的Sqids生成短唯一的id从数字.zip

    总结来说,官方Java端口的Sqids是一个强大的工具,它为Java开发者提供了一种生成短而唯一ID的解决方案。通过对时间戳、序列号和工作节点ID的巧妙组合, Sqids能够在分布式环境中有效地保证ID的唯一性,同时保持较高...

    java生成唯一id(uuid)(不依赖jdk5,自己实现的)

    在Java编程中,生成唯一的ID(Universal Unique Identifier,UUID)是一项常见的需求,特别是在数据库记录、分布式系统中的对象标识等方面。UUID是一种128位的数字,通常以32个字符的16进制形式表示,确保在全球范围...

    JAVA自带的方法生成唯一ID

    java中有自带的方法可以自动帮助我们实现id的获取,可以作为稳定的工具类。可自定义。

    java数据库唯一id生成工具类

    Java数据库唯一ID生成工具类 Java数据库唯一ID生成工具类是指能够生成唯一的ID号码的Java工具类,主要用于解决数据库中ID的唯一性问题。本工具类通过使用JdbcTemplate对数据库进行操作,生成的ID号码具有唯一性和...

    JAVA 的ID生成策略

    JAVA ID生成策略 JAVA ID生成策略是一种在Hibernate框架中使用的策略,用于生成实体类的主键值。这种策略在Annotation情况下,主要有三种方式生成主键值。 第一种方式是使用数据库的自动增长字段生成。这种方式...

    java 分布式 代码生成器 唯一ID

    下面我们将深入探讨Java分布式代码生成器以及如何实现唯一ID。 首先,我们需要理解什么是分布式代码生成器。在分布式系统中,由于多个节点并行处理请求,每个节点都需要生成不重复的ID,以确保数据的一致性和完整性...

    全局唯一ID生成

    当系统需要为每条记录分配一个独一无二的身份标识时,全局唯一ID生成技术就显得尤为重要。本话题将深入探讨分布式ID生成以及相关实现策略。 分布式ID生成是解决大型分布式系统中生成不重复ID的关键技术。在单体应用...

    java自动生成id策略

    为了解决这个问题,可以考虑使用更复杂的分布式ID生成方案,如Twitter的Snowflake算法或Google的UUID。这些算法在保证全局唯一性的同时,还能提供更高的并发处理能力。 综上所述,"java自动生成id策略"涉及到对...

    javaID生成器javaID生成器

    ### Java ID生成器详解 #### 一、引言 在软件开发过程中,特别是在数据库操作时,经常需要为每个新创建的记录分配一个唯一的标识符(ID)。为了满足这一需求,Java 开发者们通常会设计一种高效且可靠的 ID 生成...

    java快速ID自增器

    在Java开发中,高效地生成唯一且自增...它可以是基于Java内置的原子类、数据库序列、分布式ID生成算法,或者是结合数据库和Spring框架的高级应用场景。选择哪种方案取决于具体的应用场景、性能需求以及系统是否分布式。

    Java邀请码生成工具类

    超级简单的Java邀请码生成器,输入一个数值类型生成一个6位的0-Z的邀请码,并且邀请码可以反向解析成数值! 非常好用,生成和反向生成的方法已经封装好了 超级简单

    java生成16位long类型id

    1.获取系统时间 + 随机数,但是由于系统时间前几位是相同的,所以截取几位数字; 2.获取随机数,math的方法,截取几位数字; 3.判重校验

    java生成UUID通用唯一识别码.docx

    Java中的UUID(Universally Unique Identifier)是一种用于生成全局唯一标识符的标准,由开源软件基金会(OSF)在分布式计算环境中提出。UUID的主要目的是确保在分布式系统中的任何元素都有其独特的识别信息,无需...

    唯一uuidid生成器

    总的来说,唯一ID生成器是构建分布式系统的关键组件,它确保了数据的一致性和完整性。Java中的UUID生成和特定的ID生成库如Vesta-ID-Generator,为开发者提供了灵活和可靠的工具来解决这一问题。在实际应用中,选择...

    Java中生成唯一ID的方法示例

    "Java中生成唯一ID的方法示例" Java中生成唯一ID的方法示例是指在Java编程语言中生成唯一标识符的多种方法。这些方法可以应用于各种场景,如生成订单号、用户ID、交易ID等。在本篇文章中,我们将介绍两种常见的生成...

Global site tag (gtag.js) - Google Analytics