어떻게 PHP 에서 무 작위 수 를 생 성 합 니까?

6498 단어 PHP난수생 성
첫 번 째 방법 은 mtrand()

function GetRandStr($length){
$str='abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789';
$len=strlen($str)-1;
$randstr='';
for($i=0;$i<$length;$i++){
$num=mt_rand(0,$len);
$randstr .= $str[$num];
}
return $randstr;
}
$number=GetRandStr(6);
echo $number;
두 번 째 방법(가장 빠 른)

function make_password( $length = 8 )
{
 //      ,           
 $chars = array('a', 'b', 'c', 'd', 'e', 'f', 'g', 'h', 
 'i', 'j', 'k', 'l','m', 'n', 'o', 'p', 'q', 'r', 's', 
 't', 'u', 'v', 'w', 'x', 'y','z', 'A', 'B', 'C', 'D', 
 'E', 'F', 'G', 'H', 'I', 'J', 'K', 'L','M', 'N', 'O', 
 'P', 'Q', 'R', 'S', 'T', 'U', 'V', 'W', 'X', 'Y','Z', 
 '0', '1', '2', '3', '4', '5', '6', '7', '8', '9', '!', 
 '@','#', '$', '%', '^', '&', '*', '(', ')', '-', '_', 
 '[', ']', '{', '}', '<', '>', '~', '`', '+', '=', ',', 
 '.', ';', ':', '/', '?', '|');
 //   $chars      $length        
 $keys = array_rand($chars, $length); 
 $password = '';
 for($i = 0; $i < $length; $i++)
 {
 //   $length            
 $password .= $chars[$keys[$i]];
 }
 return $password;
}
세 번 째 는 당시 타임 스탬프 를 가 져 옵 니 다.

function get_password( $length = 8 ) 
{
 $str = substr(md5(time()), 0, $length);//md5  ,time()     
 return $str;
}
네 번 째 문자열 흐 트 러 짐

function getrandstr(){
$str='ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz1234567890';
$randStr = str_shuffle($str);//     
$rands= substr($randStr,0,6);//substr(string,start,length);         
return $rands;
}
다섯 번 째 인증 코드 를 만 들 기 시작 합 니 다.

$code = rand(10000, 99999);
php mt_rand 생 성 0~1 랜 덤 소수 효과 비교
lcg_value 설명
float lcg_value ( void )lcg_value() 반환 범 위 는(0,1)의 위조 난수 이다.이 함 수 는 주기 가 2^31-85 와 2^31-249 인 두 개의 동 여 발생 기 를 조합 하 였 습 니 다.이 함수 의 주 기 는 이 두 소수 의 곱셈 과 같다.
반환:범위(0,1)의 위조 난수 입 니 다.

<?php
for($i=0; $i<5; $i++){
 echo lcg_value().PHP_EOL;
}
?>
출력:
0.11516515851995
0.064684551575297
0.68275174031189
0.55730746529099
0.70215008878091
두 가지 생 성 0~1 랜 덤 소수 방법 비교
1.실행 시간 비교
10 만 회 실행 mt_rand()mt_getrandmax() 알고리즘 을 기반 으로 한 운행 시간

<?php
/**
 *   0~1    
 * @param Int $min
 * @param Int $max
 * @return Float
 */
function randFloat($min=0, $max=1){
 return $min + mt_rand()/mt_getrandmax() * ($max-$min);
}
 
//   microtime
function get_microtime(){
 list($usec, $sec) = explode(' ', microtime());
 return (float)$usec + (float)$sec;
}
 
//       
$starttime = get_microtime();
 
//   10        
for($i=0; $i<100000; $i++){
 randFloat();
}
 
//       
$endtime = get_microtime();
 
//       
printf("run time %f ms\r
", ($endtime-$starttime)*1000); ?>
출력:
run time 266.893148 ms
10 만 회 실행 lcg_value() 의 운행 시간

<?php
//   microtime
function get_microtime(){
 list($usec, $sec) = explode(' ', microtime());
 return (float)$usec + (float)$sec;
}
 
 
//       
$starttime = get_microtime();
 
 
//   10        
for($i=0; $i<100000; $i++){
 lcg_value();
}
 
 
//       
$endtime = get_microtime();
 
 
//       
printf("run time %f ms\r
", ($endtime-$starttime)*1000); ?>
출력:
run time 86.178064 ms
집행 시간 에 비해 lcg_value() 은 phop 원생 방법 이 고 mt_rand()mt_getrandmax() 은 두 가지 방법 을 호출 하고 계산 해 야 하기 때문에 lcg_value() 의 집행 시간 은 약 3 배 빠르다.
2.랜 덤 효과 비교mt_rand()mt_getrandmax() 알고리즘 에 따 른 랜 덤 효과

<?php
/**
 *   0~1    
 * @param Int $min
 * @param Int $max
 * @return Float
 */
function randFloat($min=0, $max=1){
 return $min + mt_rand()/mt_getrandmax() * ($max-$min);
}
 
 
header('content-type: image/png');
$im = imagecreatetruecolor(512, 512);
$color1 = imagecolorallocate($im, 255, 255, 255);
$color2 = imagecolorallocate($im, 0, 0, 0);
for($y=0; $y<512; $y++){
 for($x=0; $x<512; $x++){
 $rand = randFloat();
 if(round($rand,2)>=0.5){
  imagesetpixel($im, $x, $y, $color1);
 }else{
  imagesetpixel($im, $x, $y, $color2);
 }
 }
}
imagepng($im);
imagedestroy($im);
?>
lcg_value() 의 랜 덤 효과

<?php
header('content-type: image/png');
$im = imagecreatetruecolor(512, 512);
$color1 = imagecolorallocate($im, 255, 255, 255);
$color2 = imagecolorallocate($im, 0, 0, 0);
for($y=0; $y<512; $y++){
 for($x=0; $x<512; $x++){
 $rand = lcg_value();
 if(round($rand,2)>=0.5){
  imagesetpixel($im, $x, $y, $color1);
 }else{
  imagesetpixel($im, $x, $y, $color2);
 }
 }
}
imagepng($im);
imagedestroy($im);
?>
3.랜 덤 읽 기 추천
+phop 소스 코드 암호 화 방법 요약:https://www.jb51.net/article/134506.html
이상 은 어떻게 PHP 에서 랜 덤 수 를 생 성 하 는 지 에 대한 상세 한 내용 입 니 다.더 많은 PHP 랜 덤 수 에 관 한 자 료 는 우리 의 다른 관련 글 을 주목 하 세 요!

좋은 웹페이지 즐겨찾기