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