random_int

(PHP 7)

random_intGenerates cryptographically secure pseudo-random integers

Описание

int random_int ( int $min , int $max )

Generates cryptographic random integers that are suitable for use where unbiased results are critical, such as when shuffling a deck of cards for a poker game.

The sources of randomness used for this function are as follows:

  • On Windows, » CryptGenRandom() will always be used.
  • On Linux, the » getrandom(2) syscall will be used if available.
  • On other platforms, /dev/urandom will be used.
  • If none of the aforementioned sources are available, then an Exception will be thrown.

Замечание: Although this function was added to PHP in PHP 7.0, a » userland implementation is available for PHP 5.2 to 5.6, inclusive.

Список параметров

min

The lowest value to be returned, which must be PHP_INT_MIN or higher.

max

The highest value to be returned, which must be less than or equal to PHP_INT_MAX.

Возвращаемые значения

Returns a cryptographically secure random integer in the range min to max, inclusive.

Ошибки

  • If an appropriate source of randomness cannot be found, an Exception will be thrown.
  • If invalid parameters are given, a TypeError will be thrown.
  • If max is less than min, an Error will be thrown.

Примеры

Пример #1 random_int() example

<?php
var_dump
(random_int(100999));
var_dump(random_int(-10000));
?>

Результатом выполнения данного примера будет что-то подобное:

int(248)
int(-898)

Смотрите также

  • random_bytes() - Generates cryptographically secure pseudo-random bytes

Коментарии

Here is a simple backporting function, it works for PHP >= 5.1

<?php
if (!function_exists('random_int')) {
    function 
random_int($min$max) {
        if (!
function_exists('mcrypt_create_iv')) {
           
trigger_error(
               
'mcrypt must be loaded for random_int to work'
               
E_USER_WARNING
           
);
            return 
null;
        }
       
        if (!
is_int($min) || !is_int($max)) {
           
trigger_error('$min and $max must be integer values'E_USER_NOTICE);
           
$min = (int)$min;
           
$max = (int)$max;
        }
       
        if (
$min $max) {
           
trigger_error('$max can\'t be lesser than $min'E_USER_WARNING);
            return 
null;
        }
       
       
$range $counter $max $min;
       
$bits 1;
       
        while (
$counter >>= 1) {
            ++
$bits;
        }
       
       
$bytes = (int)max(ceil($bits/8), 1);
       
$bitmask pow(2$bits) - 1;
 
        if (
$bitmask >= PHP_INT_MAX) {
           
$bitmask PHP_INT_MAX;
        }
 
        do {
           
$result hexdec(
               
bin2hex(
                   
mcrypt_create_iv($bytesMCRYPT_DEV_URANDOM)
                )
            ) & 
$bitmask;
        } while (
$result $range);
 
        return 
$result $min;
    }
}
?>

Randomness test

<?php
$max 
100// number of random values
$test 1000000;

$array array_fill(0$max0);

for (
$i 0$i $test; ++$i) {
    ++
$array[random_int(0$max-1)];
}

function 
arrayFormatResult(&$item) {
    global 
$test$max// try to avoid this nowdays ;)
   
   
$perc = ($item/($test/$max))-1;
   
$item .= ' 'number_format($perc4'.''') .'%';
}

array_walk($array'arrayFormatResult');

print_r($array);
?>
2016-07-30 16:11:23
http://php5.kiev.ua/manual/ru/function.random-int.html
<?php 
   
// PHP >= 7
   
function str_rand(int $length 16){
       
$x '';
        for(
$i 1$i <= $length$i++){
           
$x .= dechex(random_int(0,255));
        }
        return 
substr($x0$length);
    }
   
var_dump(str_rand());
?>
2019-07-04 06:02:13
http://php5.kiev.ua/manual/ru/function.random-int.html
On my system (5th gen i7) random_int() takes about 14x longer to do the same number of calculations than rand(). 

for ($i=0; $i<10000000; $i++)
        $x = rand(1, PHP_INT_MAX);

Takes 0.86 seconds for rand(), 12.29 seconds for random_int(). So use random_int() somewhat sparingly. 

If it's not really important to be truly random, use rand() instead, especially in a tight loop.
2020-09-05 19:21:45
http://php5.kiev.ua/manual/ru/function.random-int.html
Автор:
A small function for generating version 4 GUIDs.

<?php
function v4uuid()
{
   
$a str_pad(dechex(random_int(0x0000_00000xffff_ffff)), '0'STR_PAD_LEFT);
   
$b str_pad(dechex(random_int(0x00000xffff)), '0'STR_PAD_LEFT);
   
$c dechex(random_int(0x40000x4fff));
   
$d dechex(random_int(0x80000xbfff));
   
$e str_pad(dechex(random_int(0x0000_0000_00000xffff_ffff_ffff)), '0'STR_PAD_LEFT);
    return 
"$a-$b-$c-$d-$e";
}
?>
2023-09-02 15:51:07
http://php5.kiev.ua/manual/ru/function.random-int.html

    Поддержать сайт на родительском проекте КГБ