UUID用习惯了?NanoID 了解一下?

UUID?

通用唯一识别码(英语:Universally Unique Identifier,缩写:UUID)是用于计算机体系中以识别信息的一个128位标识符。

根据标准方法生成,不依赖中央机构的注册和分配,UUID具有唯一性,这与其他大多数编号方案不同。重复UUID码概率接近零,可以忽略不计。

UUID VS NanoID

NanoID 使用强大的加密 API,与不安全的 Math.Random() 相比,它更安全。

NanoID 仅使用21 个符号而不是 36 个符号,所以只有 108 个字节那么大。

NanoID 使用比 UUID 更大的字母表,需要超过 1 万亿年,才能有 1% 的概率至少发生一次碰撞,因此较短的 ID 可以用于与较长的 UUID 相同的目的。可以在Nano ID Collision Calculator来测试碰撞所需时间和概率。

NanoID 不依赖任何类型的第三方依赖项,这意味着它最终变得更加稳定,这有助于随着时间的推移最大限度地扩大包范围,并使其更不容易受到随之而来的问题的影响有依赖关系。

NanoID 允许设计者使用个性化的字母表。这是 Nano ID 的另一个附加功能。可以更改 id 的文字或维度。

NanoID 支持 14 种不同的编程语言 C#, C++, Clojure and ClojureScript, Crystal, Dart & Flutter, Deno, Go, Elixir, Haskell, Janet, Java, Nim, Perl, PHP, Python with dictionaries, Ruby , Rust, Swift

了解 NanoID 及其用法

Java实现

import java.security.SecureRandom;
import java.util.Random;

public final class NanoIdUtils {

    private NanoIdUtils() {
        //Do Nothing
    }

    public static final SecureRandom DEFAULT_NUMBER_GENERATOR = new SecureRandom();

    public static final char[] DEFAULT_ALPHABET = "_-0123456789abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ".toCharArray();

    public static final int DEFAULT_SIZE = 21;

    public static String randomNanoId() {
        return randomNanoId(DEFAULT_NUMBER_GENERATOR, DEFAULT_ALPHABET, DEFAULT_SIZE);
    }

    public static String randomNanoId(final Random random, final char[] alphabet, final int size) {

        if (random == null) {
            throw new IllegalArgumentException("random cannot be null.");
        }

        if (alphabet == null) {
            throw new IllegalArgumentException("alphabet cannot be null.");
        }

        if (alphabet.length == 0 || alphabet.length >= 256) {
            throw new IllegalArgumentException("alphabet must contain between 1 and 255 symbols.");
        }

        if (size <= 0) {
            throw new IllegalArgumentException("size must be greater than zero.");
        }

        final int mask = (2 << (int) Math.floor(Math.log(alphabet.length - 1) / Math.log(2))) - 1;
        final int step = (int) Math.ceil(1.6 * mask * size / alphabet.length);

        final StringBuilder idBuilder = new StringBuilder();

        while (true) {

            final byte[] bytes = new byte[step];
            random.nextBytes(bytes);

            for (int i = 0; i < step; i++) {

                final int alphabetIndex = bytes[i] & mask;

                if (alphabetIndex < alphabet.length) {
                    idBuilder.append(alphabet[alphabetIndex]);
                    if (idBuilder.length() == size) {
                        return idBuilder.toString();
                    }
                }
            }
        }
    }
}

参考

UUID WIKI
NanoId Git for Java

你可能感兴趣的:(UUID用习惯了?NanoID 了解一下?)