[英]php random x digit number
我需要创建一个具有 x 位数的随机数。
所以让我们说 x 是 5,我需要一个数字,例如。 35562 如果 x 是 3,那么它会抛出类似的东西; 463
有人可以告诉我这是如何完成的吗?
这是一个没有任何循环或任何麻烦的简单解决方案,它允许您创建带有字符、数字甚至特殊符号的随机字符串。
$randomNum = substr(str_shuffle("0123456789"), 0, $x);
其中$x
可以是位数
例如。 substr(str_shuffle("0123456789"), 0, 5);
几次执行后的结果
98450
79324
23017
04317
26479
您也可以使用相同的代码来生成随机字符串,就像这样
$randomNum=substr(str_shuffle("0123456789abcdefghijklmnopqrstvwxyzABCDEFGHIJKLMNOPQRSTVWXYZ"), 0, $x);
$x = 11
结果
FgHmqpTR3Ox
O9BsNgcPJDb
1v8Aw5b6H7f
haH40dmAxZf
0EpvHL5lTKr
您可以将rand($min, $max)
用于该确切目的。
为了将值限制为 x 位的值,您可以使用以下命令:
$x = 3; // Amount of digits
$min = pow(10,$x);
$max = pow(10,$x+1)-1);
$value = rand($min, $max);
将您的号码视为数字列表,每次只附加一个随机数字:
function n_digit_random($digits) {
$temp = "";
for ($i = 0; $i < $digits; $i++) {
$temp .= rand(0, 9);
}
return (int)$temp;
}
或者纯粹的数值解:
function n_digit_random($digits)
return rand(pow(10, $digits - 1) - 1, pow(10, $digits) - 1);
}
我能想到的最简单的方法是将rand
函数与str_pad
一起str_pad
<?php
echo str_pad(rand(0,999), 5, "0", STR_PAD_LEFT);
?>
在上面的例子中,它将生成0 到 999范围内的随机数。
并且有5位数。
function random_numbers($digits) {
$min = pow(10, $digits - 1);
$max = pow(10, $digits) - 1;
return mt_rand($min, $max);
}
在这里测试。
rand(1000, 9999);
比rand(0,9);
x4 倍更快rand(0,9);
基准:
rand(1000, 9999) : 0.147 sec.
rand(0,9)x4 times : 0.547 sec.
两个函数都在 100000 次迭代中运行,以使结果更加明确
那么你可以使用简单的 php 函数 mt_rand(2000,9000) 它可以生成一个 4 位随机数
mt_rand(2000,9000)
function random_number($size = 5)
{
$random_number='';
$count=0;
while ($count < $size )
{
$random_digit = mt_rand(0, 9);
$random_number .= $random_digit;
$count++;
}
return $random_number;
}
用循环来做:
function randomWithLength($length){
$number = '';
for ($i = 0; $i < $length; $i++){
$number .= rand(0,9);
}
return (int)$number;
}
rand
或mt_rand
会做...
用法:
rand(min, max);
mt_rand(min, max);
您可以使用 mt_rand() 函数生成任何 x 位随机数。 mt_rand() 使用 rand() 函数语法要快得多: mt_rand()
或mt_rand($min , $max)
。
示例: <?php echo mt_rand(); ?>
<?php echo mt_rand(); ?>
以下是生成特定长度验证码的简单方法。 长度可以指定,默认生成4位代码。
function get_sms_token($length = 4) {
return rand(
((int) str_pad(1, $length, 0, STR_PAD_RIGHT)),
((int) str_pad(9, $length, 9, STR_PAD_RIGHT))
);
}
echo get_sms_token(6);
这个简单的脚本会做
$x = 4;//want number of digits for the random number
$sum = 0;
for($i=0;$i<$x;$i++)
{
$sum = $sum + rand(0,9)*pow(10,$i);
}
echo $sum;
这是另一个生成 N 位随机数的简单解决方案:
$number_of_digits = 10;
echo substr(number_format(time() * mt_rand(),0,'',''),0,$number_of_digits);
在这里检查: http : //codepad.org/pyVvNiof
function rand_number_available($already_mem_array,$boundary_min,$boundary_max,$digits_num)
{
$already_mem_array_dim = count($already_mem_array); // dimension of array, that contain occupied elements
// --- creating Boundaries and possible Errors
if( empty($digits_num) ){
$boundary_dim = $boundary_max - $boundary_min;
if($boundary_dim <= 0){
$error = -1; // Error that might happen. Difference between $boundary_max and $boundary_min must be positive
}else{
$error = -2; // Error that might happen. All numbers between, $boundary_min and $boundary_max , are occupied, by $already_mem_array
}
}else{
if($digits_num < 0){ // Error. If exist, $digits_num must be, 1,2,3 or higher
$error = -3;
}elseif($digits_num == 1){ // if 'one-figure' number
$error = -4; // Error that might happen. All 'one-figure' numbers are occupied, by $already_mem_array
$boundary_min = 0;
$boundary_max = 9;
$boundary_dim = $boundary_max-$boundary_min;
}elseif($digits_num == 2){ // if 'two-figure' number
$error = -5; // Error that might happen. All 'two-figure' numbers are occupied, by $already_mem_array
$boundary_min = 10;
$boundary_max = 99;
$boundary_dim = $boundary_max-$boundary_min;
}elseif($digits_num>2){ // if 'X-figure' number. X>2
$error = -6; // Error that might happen. All 'X-figure' numbers are occupied, by $already_mem_array. Unlikely to happen
$boundary_min = pow(10, $digits_num-1); // stepenovanje - graduation
$boundary_max = pow(10, $digits_num)-1;
$boundary_dim = $boundary_max-$boundary_min;
}
}
// -------------------------------------------------------------------
// --- creating response ---------------------------------------------
if( ($already_mem_array_dim <= $boundary_dim) && $boundary_dim>0 ){ // go here only if, there are AVAILABLE numbers to extract, and [difference] $boundary_dim , is positive
do{
$num = rand($boundary_min,$boundary_max);
}while( in_array($num, $already_mem_array) );
$result = $num;
}else{
$result = $error; // Limit that happened
}
return $result;
// -------------------------------------------------------------------
}
此功能完美运行,没有重复和所需的位数。
$digits = '';
function randomDigits($length){
$numbers = range(0,9);
shuffle($numbers);
for($i = 0; $i < $length; $i++){
global $digits;
$digits .= $numbers[$i];
}
return $digits;
}
您可以调用该函数并传递位数,例如:
randomDigits(4);
样本结果:
4957 8710 6730 6082 2987 2041 6721
原始脚本来自这个要点
请注意rand()
不会根据文档生成加密安全值:
http://php.net/manual/en/function.rand.php
此函数不生成加密安全值,不应用于加密目的。 如果您需要加密安全值,请考虑改用 random_int()、random_bytes() 或 openssl_random_pseudo_bytes()。
相反,最好使用 PHP 7 上提供的random_int()
(参见: http : random_int()
)。
因此,要扩展@Marcus 的答案,您应该使用:
function generateSecureRandomNumber($digits): int {
return random_int(pow(10, $digits - 1), pow(10, $digits) - 1);
}
function generateSecureRandomNumberWithPadding($digits): string {
$randomNumber = random_int(0, pow(10, $digits) - 1);
return str_pad($randomNumber, $digits, '0', STR_PAD_LEFT);
}
请注意,如果您不需要安全的随机数,则使用rand()
就可以了。
以下代码生成一个 4 位随机数:
echo sprintf( "%04d", rand(0,9999));
你们真的很喜欢把事情复杂化:)
真正的问题是 OP 可能希望将其添加到某个非常大的数字的末尾。 如果没有,我认为没有必要这样做。 因为任何数字中的左零都是左零。
因此,只需将该数字的较大部分附加为数学总和,而不是字符串。
例如
$x = "102384129" . complex_3_digit_random_string();
简单地变成
$x = 102384129000 + rand(0, 999);
完毕。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.