需求
项目在用户未登录状态下,根据问题回答答案来进行修改密码。我们需要保证当前用户的身份。对用户状态进行唯一的记录,用于对用户接下来的修改密码操作进行判断。
UUID
JDK API 是这么说的:
“表示通用唯一标识符 (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]);
}
}
跑一下测试用例1000个。查重,没有。解决
网友评论