来源:藏色散人 发布时间:2019-02-23 15:20:37 阅读量:1242
使用PHP生成随机,唯一,字母数字字符串。
例子:
1 2 |
|
方法1:
第一种方法是最容易理解的方法。它可以实现如下:
-将所有可能的字母存储到字符串中。
-生成从0到字符串长度-1的随机索引。
-打印该索引处的字母。
-执行此步骤n次(其中n是所需字符串的长度)。
程序代码如下:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 |
|
输出1:
1 |
|
输出2:
1 |
|
方法2:使用哈希函数
PHP有一些函数,如md5(),sha1()和hash(),可用于根据某些算法(如“sha1”,“sha256”,“md5”等)对字符串进行哈希处理。所有这些函数都将一个字符串作为参数并输出一个Alpha-Numeric哈希字符串。
使用rand()函数生成随机数。
使用上述功能之一对其进行哈希处理。
程序1:
1 2 3 4 5 |
|
输出1:
1 |
|
输出2:
1 |
|
程序2:
1 2 3 4 5 |
|
输出1:
1 |
|
输出2:
1 |
|
程序3:
1 2 3 4 5 |
|
输出1:
1 |
|
输出2:
1 |
|
注意:以上所有函数都是散列函数,因此生成的字符串长度将始终取决于所使用的算法,但对于算法,它将始终保持不变。因此,如果要生成固定长度的字符串,可以根据需要截断生成的字符串或与另一个字符串连接。
方法3:
使用uniqid()函数。PHP中的uniqid()函数是一个内置函数,用于根据当前时间(微秒)生成唯一ID。默认情况下,它返回一个13个字符长的唯一字符串。
程序:
1 2 3 4 |
|
输出1:
1 |
|
输出2:
1 |
|
注意:以上所有方法都是基于rand()和uniqid()函数构建的。这些函数不是加密安全的随机生成器。因此,建议如果随机程度影响应用程序的安全性,则应避免使用这些方法。
方法4:
使用random_bytes()函数。(加密的安全)的random_bytes()函数生成加密安全伪随机字节,它可在以后使用被转换为十六进制格式BIN2HEX()函数。
程序:
1 2 3 4 5 |
|
输出1:
1 |
|
输出2:
1 |
|