使用id生成6位数(字母加数字),亲测不会重复

该博客介绍了一个根据ID生成6位唯一邀请码的算法,通过自定义进制转换和随机补全确保不重复。主要步骤包括:ID转自定义进制、添加特定字符、随机补全至固定长度。博客提供了生成和解析邀请码的完整Java代码实现。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

使用id生成6位数(字母加数字),亲测不会重复

package cn.wkgb.common.utils;

import java.util.HashMap;
import java.util.Map;
import java.util.Random;

/**

  • 根据id生成6位数
  • @author Administrator

/
public class ShareCodeUtil {
/
*
* 邀请码生成器,算法原理:
* 1) 获取id: 1111111
* 2) 使用自定义进制转为:gpm6
* 3) 转为字符串,并在后面加’O’字符:gpm6o
* 4)在后面随机产生若干个随机数字字符:gpm6o7
* 转为自定义进制后就不会出现o这个字符,然后在后面加个’o’,这样就能确定唯一性。最后在后面产生一些随机字符进行补全。
*/

    /** 自定义进制(0,1没有加入,容易与o,l混淆) */
    private static final char[] r=new char[]{'Q', 'W', 'E', '8', 'A', 'S', '2', 'D', 'Z', 'X', '9', 'C', '7', 'P', '5', 'I', 'K', '3', 'M', 'J', 'U', 'F', 'R', '4', 'V', 'Y', 'l', 'T', 'N', '6', 'B', 'G', 'H'};

    /** (不能与自定义进制有重复) */
    private static final char b='O';

    /** 进制长度 */
    private static final int binLen=r.length;

    /** 序列最小长度 */
    private static final int s=6;

    /**
     * 根据ID生成六位随机码
     * @param id ID
     * @return 随机码
     */
    public static String toSerialCode(long id) {
        char[] buf=new char[32];
        int charPos=32;

        while((id / binLen) > 0) {
            int ind=(int)(id % binLen);
            buf[--charPos]=r[ind];
            id /= binLen;
        }
        buf[--charPos]=r[(int)(id % binLen)];
        String str=new String(buf, charPos, (32 - charPos));
        // 不够长度的自动随机补全
        if(str.length() < s) {
            StringBuilder sb=new StringBuilder();
            sb.append(b);
            Random rnd=new Random();
            for(int i=1; i < s - str.length(); i++) {
                sb.append(r[rnd.nextInt(binLen)]);
            }
            str+=sb.toString();
        }
        return str;
    }

    public static long codeToId(String code) {
        char chs[]=code.toCharArray();
        long res=0L;
        for(int i=0; i < chs.length; i++) {
            int ind=0;
            for(int j=0; j < binLen; j++) {
                if(chs[i] == r[j]) {
                    ind=j;
                    break;
                }
            }
            if(chs[i] == b) {
                break;
            }
            if(i > 0) {
                res=res * binLen + ind;
            } else {
                res=ind;
            }
        }
        return res;
    }

    public static void main(String[] args) {
    	Map<String, Object> map = new HashMap<String, Object>();
    	int a=0;
    	for (int i = 0; i < 10000000; i++) {
	        String s = toSerialCode(i);
    		if (map.get(s)!=null) {
				a++;
			}else {
				map.put(s, "2");
			}
		}
        System.out.println(a);
    }

}

好的,以下是一个用 HTML 和 JavaScript 生成指定位数随机验证码的示例代码: ```html <!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <title>随机验证码</title> </head> <body> <h1>随机验证码</h1> <p>请在下面的文本框中输入下图中显示的验证码:</p> <img id="captchaImg"> <input type="text" id="captchaInput"> <button onclick="checkCaptcha()">提交</button> <p id="message"></p> <script> function generateCaptcha(length) { var chars = "0123456789abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ"; var captcha = ""; for (var i = 0; i < length; i++) { captcha += chars.charAt(Math.floor(Math.random() * chars.length)); } return captcha; } function showCaptcha() { var captchaImg = document.getElementById("captchaImg"); var captchaInput = document.getElementById("captchaInput"); var captcha = generateCaptcha(6); // 生成 6 位验证码 captchaImg.src = "http://placehold.it/120x40?text=" + captcha; // 在这里用占位图代替真正的验证码图片 captchaInput.value = ""; } function checkCaptcha() { var captchaInput = document.getElementById("captchaInput"); var message = document.getElementById("message"); if (captchaInput.value === captchaImg.alt) { message.textContent = "验证码正确!"; } else { message.textContent = "验证码错误,请重试。"; showCaptcha(); } } var captchaImg = document.getElementById("captchaImg"); captchaImg.alt = generateCaptcha(6); // 生成 6 位验证码并保存在 alt 属性中 showCaptcha(); // 页面载完成时显示验证码 </script> </body> </html> ``` 这个程序会在页面上显示一个 6 位随机验证码,并在用户输入验证码后判断输入是否正确。当用户点击“提交”按钮后,会调用 checkCaptcha() 函数,该函数会获取用户输入的验证码并与页面上显示的验证码进行比较,如果相同则显示提示信息“验证码正确!”;如果不同则显示提示信息“验证码错误,请重试。”并重新生成一个新的验证码。 为了生成随机验证码,我们编写了一个 generateCaptcha() 函数,它接受一个参数 length,表示生成验证码的位数。在函数中,我们定义了一个包含数字字母字符串 chars,然后利用 Math.random() 和字符串的 charAt() 方法随机生成一个 length 位的验证码。 在页面载完成后,我们会先生成一个验证码并将它保存在 img 标签的 alt 属性中,然后调用 showCaptcha() 函数将验证码显示在页面上。这里我们用了一个占位图代替真正的验证码图片,因为我们并没有实际的验证码图片资源。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值