28 lines
1.2 KiB
TypeScript
28 lines
1.2 KiB
TypeScript
/**
|
||
* 生成指定长度的伪随机字符串,通常用作唯一标识符(非标准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);
|
||
} |