Home >Backend Development >PHP Tutorial >Five ways to generate random passwords in php

Five ways to generate random passwords in php

墨辰丷
墨辰丷Original
2018-06-07 14:07:235592browse

This article mainly introduces five methods of generating random passwords in PHP. Interested friends can refer to it. I hope it will be helpful to everyone.

Using PHP to develop applications, especially website programs, often requires generating random passwords. For example, when a user registers to generate a random password, the user also needs to generate a random password to reset the password. A random password is a string of fixed length. Here I have collected several methods of generating random strings for your reference.

Method 1:

1. Generate a random integer from 33 – 126, such as 35,

2. Convert 35 into the corresponding ASCII code characters, such as 35 corresponds to

# 3. Repeat the above steps 1 and 2 n times to connect into an n-digit password

This algorithm mainly uses two functions, mt_rand ( int $ min, int $max) function is used to generate random integers, where $min – $max is the range of ASCII code, here it is 33-126, the range can be adjusted as needed, for example, 97 – 122 bits in the ASCII code table correspond to a – z English letters, please refer to the ASCII code table for details; chr (int $ascii) function is used to convert the corresponding integer $ascii into the corresponding characters.

function create_password($pw_length = 8)
{
 $randpwd = '';
 for ($i = 0; $i < $pw_length; $i++) 
 {
  $randpwd .= chr(mt_rand(33, 126));
 }
 return $randpwd;
}

// Call this function and pass the length parameter $pw_length = 6

echo create_password(6);

Method 2:

1. Preset a string $chars, including a – z, A – Z, 0 – 9, and some special characters

2. Randomly pick a character in the $chars string

3. Repeat the second step n times to get a password of length n

function generate_password( $length = 8 ) {
 // 密码字符集,可任意添加你需要的字符
 $chars = &#39;abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789!@#$%^&*()-_ []{}<>~`+=,.;:/?|&#39;;

 $password = &#39;&#39;;
 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;
}

Method 3:

1. Preset a character array $chars, including a – z, A – Z, 0 – 9, and some special characters

2. Randomly select $length elements

from the array $chars through array_rand() 3. According to the Get the key name array $keys, take the characters from the array $chars and concatenate the string. The disadvantage of this method is that the same characters will not be retrieved repeatedly.

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

Method 4:

This method is a new method provided by a netizen after this article was reprinted by Blue Ideal. The algorithm is simple and the code is short, just because Because of the return value of the md5() function, the generated password only includes letters and numbers, but it is still a good method. Algorithm idea:

1. time() gets the current Unix timestamp

2. Encrypt the timestamp obtained in the first step with md5()

3. As a result of the second step of encryption, n bits are intercepted to obtain the desired password

function get_password( $length = 8 ) 
{
 $str = substr(md5(time()), 0, 6);
 return $str;
}

Time efficiency comparison

We use the following PHP code to calculate the above 4 random The running time of the password generation function to generate a 6-digit password, and then a simple comparison of their time efficiency was performed.

<?php
function getmicrotime()
{
 list($usec, $sec) = explode(" ",microtime());
 return ((float)$usec + (float)$sec);
}
// 记录开始时间
$time_start = getmicrotime();
// 这里放要执行的PHP代码,如:
// echo create_password(6);
// 记录结束时间
$time_end = getmicrotime();
$time = $time_end - $time_start;
 // 输出运行总时间 
echo "执行时间 $time seconds";
?>

Method 5:

function rand_string($len = 16, $keyword = &#39;&#39;) {
 if (strlen($keyword) > $len) {//关键字不能比总长度长
  return false;
 }
 $str = &#39;&#39;;
 $chars = &#39;abcdefghijkmnpqrstuvwxyz23456789ABCDEFGHIJKMNPQRSTUVWXYZ&#39;; //去掉1跟字母l防混淆   
 if ($len > strlen($chars)) {//位数过长重复字符串一定次数
  $chars = str_repeat($chars, ceil($len / strlen($chars)));
 }
 $chars = str_shuffle($chars); //打乱字符串
 $str = substr($chars, 0, $len);
 if (!empty($keyword)) {
  $start = $len - strlen($keyword);
  $str = substr_replace($str, $keyword, mt_rand(0, $start), strlen($keyword)); //从随机位置插入关键字
 }
 return $str;
}

echo rand_string(16,"ab"); //output example:V8bNY6SmkeywordB
?>

The final result is:

Method 1: 9.8943710327148E-5 seconds

Method two: 9.6797943115234E-5 seconds

Method three: 0.00017499923706055 seconds

Method four: 3.4093856811523E-5 seconds

You can see that method one The execution time of method 2 is similar, method 4 has the shortest running time, and method 3 has a slightly longer running time.

Summary: The above is the entire content of this article, I hope it will be helpful to everyone's study.

Related recommendations:

Detailed interpretation of PHP callback functions and anonymous functions

Usage of memcache in PHP database

PHP database redis usage and analysis

The above is the detailed content of Five ways to generate random passwords in php. For more information, please follow other related articles on the PHP Chinese website!

Statement:
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn