java生成一个八位的全局唯一ID生成器(加MD5加密)

该博客介绍了一种分布式全局唯一ID生成器的设计方法,通过UUID去除特殊字符并转换为十进制,结合预定义的字符数组生成8位唯一ID。同时,使用MD5加密算法对生成的ID进行加密,确保数据安全性。代码实现包括ID生成和MD5加密两个部分,适合于分布式系统中需要唯一标识的情景。
摘要由CSDN通过智能技术生成

要求设计一个分布式的全局唯一ID生成器

1、要求长度为8

2、只能包含[a-zA-Z0-9]

3、必须唯一

思路

1、定义一个静态数组chars包含a-zA-Z0-9,总共62个
2、通过UUID.randomUUID().toString(),生成36位的uuid,生成的36位id带着4个‘-’字符,我们把字符‘-’去掉,剩下32个16进制的字符。
3、我们要生成一个8位的id,因此我们把32个字符分成8组,每组4个,**(算法的关键->)**我们把每组4个字符看成一个整体,把他变成十进制的数字,之后取余,并把chars数组中应余数位置的字符添加到id中。
4、引入MD5依赖,写加密算法
6、加密之后输出,下面上代码。

id生成部分

package cn.itcast.test.util;

import org.junit.Test;

import java.util.UUID;

public class Createid {
    public static String[] chars = new String[] { "a", "b", "c", "d", "e", "f",
            "g", "h", "i", "j", "k", "l", "m", "n", "o", "p", "q", "r", "s",
            "t", "u", "v", "w", "x", "y", "z", "0", "1", "2", "3", "4", "5",
            "6", "7", "8", "9", "A", "B", "C", "D", "E", "F", "G", "H", "I",
            "J", "K", "L", "M", "N", "O", "P", "Q", "R", "S", "T", "U", "V",
            "W", "X", "Y", "Z" };
    public static String creatUUID(){
        StringBuffer shortBuffer = new StringBuffer();
        System.out.println("原来生成的36位uuid");
        String uuid = UUID.randomUUID().toString();
        System.out.println(uuid);
        uuid=uuid.replace("-", "");
        System.out.println("替换-后的32位uuid");
        System.out.println(uuid);
        for (int i = 0; i < 8; i++) {
            String str = uuid.substring(i * 4, i * 4 + 4);
            int x = Integer.parseInt(str, 16);
            shortBuffer.append(chars[x % 62]);
        }
        return shortBuffer.toString();
    }
    @Test
    public void test(){
        String str=creatUUID();
        System.out.println("生成的随机字符"+str);
        String MDStr=MD5Util.md5(str);
        System.out.println("生成的随机字符加密之后"+MDStr);
    }

}

MD5依赖

    <dependency>
      <groupId>commons-codec</groupId>
      <artifactId>commons-codec</artifactId>
      <version>1.10</version>
    </dependency>
    <dependency>
      <groupId>org.apache.commons</groupId>
      <artifactId>commons-lang3</artifactId>
      <version>3.6</version>
    </dependency>

MD5加密算法

package cn.itcast.test.util;

import org.apache.commons.codec.digest.DigestUtils;

public class MD5Util {
	
	public static String md5(String src) {
		return DigestUtils.md5Hex(src);
	}
	
	private static final String salt = "1a2b3c4d";
	
	public static String idMd5(String inputPass) {
		String str = ""+salt.charAt(0)+salt.charAt(2) + inputPass +salt.charAt(5) + salt.charAt(4);
		System.out.println(str);
		return md5(str);
	}
}

程序运行结果

在这里插入图片描述

评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值