CSPRNG(Cryptographically Secure Pseudo-Random Number Generator,伪随机数产生器)。
PHP 7 通过引入几个 CSPRNG 函数提供一种简单的机制来生成密码学上强壮的随机数。
-
random_bytes() - 加密生存被保护的伪随机字符串。
-
random_int() - 加密生存被保护的伪随机整数。
andom_bytes()
语法格式
string random_bytes ( int $length )
参数
-
length - 随机字符串返回的字节数。
返回值
-
返回一个字符串,接受一个int型入参代表返回结果的字节数。
实例
实例
<?php$bytes = random_bytes(5);
print(bin2hex($bytes));
?>
以上程序执行输出结果为:
6f36d48a29
random_int()
语法格式
int random_int ( int $min , int $max )
参数
-
min - 返回的最小值,必须是大于或等于 PHP_INT_MIN 。
-
max - 返回的最大值,必须是小于或等于 PHP_INT_MAX 。
返回值
-
返回一个指定范围内的int型数字。
实例
实例
<?phpprint(random_int(100, 999));
print(PHP_EOL);
print(random_int(-1000, 0));
?>
以上程序执行输出结果为:
723 -64
// PHP 7 之前版本需要使用多次 use
use some\namespace\ClassA;
use some\namespace\ClassB;
use some\namespace\ClassC as C;
use function some\namespace\fn_a;
use function some\namespace\fn_b;
use function some\namespace\fn_c;
use const some\namespace\ConstA;
use const some\namespace\ConstB;
use const some\namespace\ConstC;
// PHP 7+ 之后版本可以使用一个 use 导入同一个 namespace 的类
use some\namespace\{ClassA, ClassB, ClassC as C};
use function some\namespace\{fn_a, fn_b, fn_c};
use const some\namespace\{ConstA, ConstB, ConstC};
PHP 7 新增加了 intdiv() 函数,接收两个参数,返回值为第一个参数除于第二个参数的值并取整。
实例
实例
<?phpecho intdiv(9,3),PHP_EOL;
echo intdiv(10,3),PHP_EOL;
echo intdiv(5,10),PHP_EOL;
?>
以上程序执行输出结果为:
3 3 0