PHP에서 임의의 문자열을 생성하는 세 가지 방법

墨辰丷
풀어 주다: 2023-03-30 11:54:01
원래의
9467명이 탐색했습니다.

이 글은 주로 PHP에서 임의의 문자열을 생성하는 세 가지 방법을 소개합니다. 관심 있는 친구들이 참고하면 도움이 될 것입니다.

방법 1

1 33~126 사이의 임의의 정수(예: 35)를 생성합니다.

2. 35를 해당 ASCII 코드 문자로 변환합니다(예: #에 해당하는 35).

3. 위의 1단계와 2단계를 n번 반복하여 n자리 비밀번호로 연결합니다.

이 알고리즘은 주로 두 가지 함수를 사용합니다. mt_rand(int $min, int $max) 함수는 임의의 정수를 생성하는 데 사용됩니다. 여기서 $min – $max는 ASCII 코드의 범위입니다. 예를 들어 ASCII 코드 표의 97~122비트는 영문자 a~z에 해당합니다. 자세한 내용은 chr(int $ascii) 함수를 참조하세요. 해당 정수 $ascii를 해당 문자로 변환합니다.

function create_password($pw_length =  
{ 
$randpwd = ”; 
for ($i = 0; $i < $pw_length; $i++) 
{ 
$randpwd .= chr(mt_rand(33, 126)); 
} 
return $randpwd; 
} 
// 调用该函数,传递长度参数$pw_length = 6 
echo create_password(6);
로그인 후 복사

방법 2

1. a – z, A – Z, 0 – 9 및 일부 특수 문자를 포함하는 문자열 $chars를 사전 설정합니다.

2. $chars 문자열에서 임의의 문자를 선택하세요.

3. 길이가 n인 비밀번호를 얻으려면 두 번째 단계를 n번 반복하세요.

function generate_password( $length = 8 ) { 
// 密码字符集,可任意添加你需要的字符 
$chars = ‘abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789!@#$%^&*()-_ []{}<>~`+=,.;:/?|&#39;; 
$password = ”; 
for ( $i = 0; $i < $length; $i++ ) 
{ 
// 这里提供两种字符获取方式 
// 第一种是使用 substr 截取$chars中的任意一位字符; 
// 第二种是取字符数组 $chars 的任意元素 
// $password .= substr($chars, mt_rand(0, strlen($chars) – 1), 1); 
$password .= $chars[ mt_rand(0, strlen($chars) - 1) ]; 
} 
return $password; 
}
로그인 후 복사

방법 3

1. a – z, A – Z, 0 – 9 및 일부 특수 문자를 포함하는 문자 배열 $chars를 사전 설정합니다.

2. array_rand()를 사용하여 $chars 배열에서 $length 요소를 무작위로 선택합니다.

3. 획득한 키 이름 배열 $keys에 따라 $chars 배열에서 문자를 추출하고 문자열을 연결합니다. 이 방법의 단점은 동일한 문자를 반복해서 검색할 수 없다는 것입니다.

function make_password( $length = 8 ) 
{ 
 
// 密码字符集,可任意添加你需要的字符 
$chars = array(‘a&#39;, ‘b&#39;, ‘c&#39;, ‘d&#39;, ‘e&#39;, ‘f&#39;, ‘g&#39;, ‘h&#39;, 
‘i&#39;, ‘j&#39;, ‘k&#39;, ‘l&#39;,&#39;m&#39;, ‘n&#39;, ‘o&#39;, ‘p&#39;, ‘q&#39;, ‘r&#39;, &#39;s&#39;, 
‘t&#39;, ‘u&#39;, ‘v&#39;, ‘w&#39;, ‘x&#39;, ‘y&#39;,&#39;z&#39;, ‘A&#39;, ‘B&#39;, ‘C&#39;, ‘D&#39;, 
‘E&#39;, ‘F&#39;, ‘G&#39;, ‘H&#39;, ‘I&#39;, ‘J&#39;, ‘K&#39;, ‘L&#39;,&#39;M&#39;, ‘N&#39;, ‘O&#39;, 
‘P&#39;, ‘Q&#39;, ‘R&#39;, ‘S&#39;, ‘T&#39;, ‘U&#39;, ‘V&#39;, ‘W&#39;, ‘X&#39;, ‘Y&#39;,&#39;Z&#39;, 
‘0′, ‘1′, ‘2′, ‘3′, ‘4′, ‘5′, ‘6′, ‘7′, ‘8′, ‘9′, ‘!&#39;, 
‘@&#39;,&#39;#&#39;, ‘$&#39;, ‘%&#39;, ‘^&#39;, ‘&&#39;, ‘*&#39;, ‘(‘, ‘)&#39;, ‘-&#39;, ‘_&#39;, 
‘[&#39;, &#39;]‘, ‘{‘, ‘}&#39;, ‘<&#39;, ‘>&#39;, ‘~&#39;, ‘`&#39;, ‘+&#39;, ‘=&#39;, ‘,&#39;, 
‘.&#39;, ‘;&#39;, ‘:&#39;, ‘/&#39;, ‘?&#39;, ‘|&#39;); 
 
// 在 $chars 中随机取 $length 个数组元素键名 
$keys = ($chars, $length); 
$password = ”; 
for($i = 0; $i < $length; $i++) 
{ 
// 将 $length 个数组元素连接成字符串 
$password .= $chars[$keys[$i]]; 
} 
return $password; 
}
로그인 후 복사

시간 효율성 비교

다음 PHP 코드를 사용하여 위의 세 가지 임의 비밀번호 생성 기능의 실행 시간을 계산하여 6자리 비밀번호를 생성한 후, 시간 효율성을 간단하게 비교합니다. 최종 결과는 다음과 같습니다.

방법 1: 9.8943710327148E-5초
방법 2: 9.6797943115234E-5초
방법 3: 0.00017499923706055초
방법 1과 방법 2의 실행 시간은 다음과 같은 것을 알 수 있습니다. 유사하고, 두 번째 방법의 실행 시간은 거의 동일합니다. 세 번째 방법의 실행 시간은 약간 더 깁니다.

요약: 위 내용은 이 글의 전체 내용입니다. 모든 분들의 공부에 도움이 되었으면 좋겠습니다.

관련 권장 사항:

PHP는 로그인 인증 코드 기능을 구현합니다.

무료 메시지 알림 기능, PHP에서 Telegram 인터페이스를 사용하여 작성하는 방법은 무엇입니까?

PHP 개발 WeChat 환불 사례

위 내용은 PHP에서 임의의 문자열을 생성하는 세 가지 방법의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
최신 이슈
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿
회사 소개 부인 성명 Sitemap
PHP 중국어 웹사이트:공공복지 온라인 PHP 교육,PHP 학습자의 빠른 성장을 도와주세요!