(查看原文请点击本文末端左下角:阅读原文)

例子:

EA070

php随机字符串生成若何应用PHP生成随机字符串 Angular

aBX32gTf

方法1:

第一种方法是最随意马虎理解的方法。
它可以实现如下:

-将所有可能的字母存储到字符串中。

-天生从0到字符串长度-1的随机索引。

-打印该索引处的字母。

-实行此步骤n次(个中n是所需字符串的长度)。

程序代码如下:

<?php

$n=10;

function getName($n) {

$characters = '0123456789abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ';

$randomString = '';

for ($i = 0; $i < $n; $i++) {

$index = rand(0, strlen($characters) - 1);

$randomString .= $characters[$index];

}

return $randomString;

}

echo getName($n);

?>

输出1:

3HDrSOvRIs

输出2:

lipHh

方法2:利用哈希函数

PHP有一些函数,如md5(),sha1()和hash(),可用于根据某些算法(如“sha1”,“sha256”,“md5”等)对字符串进行哈希处理。
所有这些函数都将一个字符串作为参数并输出一个Alpha-Numeric哈希字符串。

利用rand()函数天生随机数。

利用上述功能之一对其进行哈希处理。

程序1:

<?php

$str=rand();

$result = md5($str);

echo $result;

?>

输出1:

2e437510c181dd2ae100fc1661a445d4

输出2:

256394010059991a71ea05e5d859d2be

程序2:

<?php

$str=rand();

$result = sha1($str);

echo $result;

?>

输出1:

6eadd9b2c4389d9b109b3b869f66aab5d8f9420a

输出2:

ca2d3c0993ab87e842d0a7a01f319aca6c587a87

程序3:

<?php

$str = rand();

$result = hash(\公众sha256\"大众, $str);

echo $result;

?>

输出1:

2a41cbc8cc11f8c8d0eb54210fe524748b4def1c5b04fcf18c2d5972e24d11c2

输出2:

291144c1cbba4de0bf199d37ee265ac95cc2e44e80fd2642b22a6e8ef2f42a39

把稳:以上所有函数都是散列函数,因此天生的字符串长度将始终取决于所利用的算法,但对付算法,它将始终保持不变。
因此,如果要天生固定长度的字符串,可以根据须要截断天生的字符串或与另一个字符串连接。

方法3:

利用uniqid()函数。
PHP中的uniqid()函数是一个内置函数,用于根据当前韶光(微秒)天生唯一ID。
默认情形下,它返回一个13个字符长的唯一字符串。

程序:

<?php

$result = uniqid();

echo $result;

?>

输出1:

5bdd0b74e9a6c

输出2:

5bdd0bbc200c4

把稳:以上所有方法都是基于rand()和uniqid()函数构建的。
这些函数不是加密安全的随机天生器。
因此,建议如果随机程度影响运用程序的安全性,则应避免利用这些方法。

方法4:

利用random_bytes()函数。
(加密的安全)的random_bytes()函数天生加密安全伪随机字节,它可在往后利用被转换为十六进制格式BIN2HEX()函数。

程序:

<?php

$n = 20;

$result = bin2hex(random_bytes($n));

echo $result;

?>

输出1:

235aed08a01468f90fa726bd56319fb893967da8

输出2:

508b84494cdf31bec01566d12a924c75d4baed39

本篇文章便是关于PHP天生随机字符串的方法先容,希望对须要的朋友有所帮助!