어떻게 PHP 에서 무 작위 수 를 생 성 합 니까?
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);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);
?>+phop 소스 코드 암호 화 방법 요약:https://www.jb51.net/article/134506.html
이상 은 어떻게 PHP 에서 랜 덤 수 를 생 성 하 는 지 에 대한 상세 한 내용 입 니 다.더 많은 PHP 랜 덤 수 에 관 한 자 료 는 우리 의 다른 관련 글 을 주목 하 세 요!
이 내용에 흥미가 있습니까?
현재 기사가 여러분의 문제를 해결하지 못하는 경우 AI 엔진은 머신러닝 분석(스마트 모델이 방금 만들어져 부정확한 경우가 있을 수 있음)을 통해 가장 유사한 기사를 추천합니다:
laravel에 yo에서 angularJs&coffeescript를 사용할 수 있도록 한다.먼저 yo 명령을 사용할 수 있어야하므로 아래에서 설치 global에 설치한 곳에서 laravel의 프로젝트 루트로 이동. 클라이언트 코드를 관리하는 디렉토리를 만들고 이동합니다. 클라이언트 환경 만들기 이것으로 히...
텍스트를 자유롭게 공유하거나 복사할 수 있습니다.하지만 이 문서의 URL은 참조 URL로 남겨 두십시오.
CC BY-SA 2.5, CC BY-SA 3.0 및 CC BY-SA 4.0에 따라 라이센스가 부여됩니다.