12345678910111213141516171819202122232425262728 |
- /**
- * 生成指定长度的伪随机字符串,通常用作唯一标识符(非标准GUID)
- *
- * 此函数使用Math.random()生成基于36进制(数字+小写字母)的随机字符串。当长度超过11位时,
- * 会通过递归拼接多个随机段实现。注意:该方法生成的并非标准GUID/UUID,不适合高安全性场景。
- *
- * @param {number} [len=32] - 要生成的字符串长度,默认32位
- * @returns {string} 生成的伪随机字符串,包含0-9和a-z字符
- *
- * @example
- * guid(); // 返回32位字符串,例如"3zyf6a5f3kb4ayy9jq9v1a70z0qdm0bk"
- * guid(5); // 返回5位字符串,例如"kf3a9"
- * guid(20); // 返回20位字符串,由两段随机字符串拼接而成
- *
- * @note
- * 1. 由于使用Math.random(),随机性存在安全缺陷,不适用于密码学用途
- * 2. 当长度>11时采用递归拼接,可能略微影响性能(在极端大长度情况下)
- * 3. 字符串补全时使用'0'填充,可能略微降低末尾字符的随机性
- */
- export function guid(len:number = 32):string {
- // crypto.randomUUID();
- return len <= 11
- ? Math.random()
- .toString(36)
- .substring(2, 2 + len)
- .padEnd(len, '0')
- : guid(11) + guid(len - 11);
- }
|