问题:
项目在用户未登录状态下,根据问题回答答案来进行修改密码。我们需要保证当前用户的身份。对用户状态进行唯一的记录,用于对用户接下来的修改密码操作进行判断。
UUID “表示通用唯一标识符 (UUID) 的类。 UUID 表示一个 128 位的值。”
1个UUID是1个16字节(128位)的数字;为了方便阅读,通常将UUID表示成如下的方式:
123e4567-e89b-12d3-a456-426655440000
1个UUID被连字符分为五段,形式为8-4-4-4-12的32个字符。
UUID由以下几部分的组合:
(1)当前日期和时间,UUID的第一个部分与时间有关,如果你在生成一个UUID之后,过几秒又生成一个UUID,则第一个部分不同,其余相同。
(2)时钟序列
(3)全局唯一的IEEE机器识别号,如果有网卡,从网卡MAC地址获得,没有网卡以其他方式获得。
代码实现
public static void main(String[] args) { UUID uuid = UUID.randomUUID(); System.out.println(uuid);}
没错其实就是这么简单的一行就生成了。
打印一下:
d57f476a-696e-416f-bbf8-48973a47c2b5
全局唯一标志码。但显得冗长,不够友好。如果在URL后面做参数,更加不够友好。还有存储一个UUID要花费更多的空间。获取的时间倒不必考虑太多。
长token
从网上找到的解决办法
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 getShortUuid() { StringBuffer stringBuffer = new StringBuffer(); String uuid = UUID.randomUUID().toString().replace("-", ""); for (int i = 0; i < 8; i++) { // 32 -> 8 String str = uuid.substring(i * 4, i * 4 + 4); // 16进制为基解析 int strInteger = Integer.parseInt(str, 16); // 0x3E -> 字典总数 62 stringBuffer.append(chars[strInteger % 0x3E]); }}
跑一下测试用例100000个,没有重复的。