|
马上注册,结交更多好友,享用更多功能,让你轻松玩转社区。
您需要 登录 才可以下载或查看,没有帐号?立即注册
x
熟悉了PHP和MYSQL开发的要领之后,再回头看你写的那个留言本,你也许会怀疑那真的是你写的吗?当然,如果屋里还有鬼的话,也许是它写的-_- </p> 利用PHP开辟使用法式,特别是网站法式,经常需求生成随秘密码,如用户注册生成随秘密码,用户重置暗码也需求生成一个随机的暗码。随秘密码也就是一串固定长度的字符串,这里我搜集收拾整顿了几种生成随机字符串的办法,以供人人参考。
办法一:
1、在 33 – 126 中生成一个随机整数,如 35,
2、将 35 转换成对应的ASCII码字符,如 35 对应 #
3、反复以上 1、2 步调 n 次,毗连成 n 位的暗码
该算法次要用到了两个函数,mt_rand ( int $min , int $max )函数用于生成随机整数,个中 $min – $max 为 ASCII 码的局限,这里取 33 -126 ,可以依据需求调剂局限,如ASCII码表中 97 – 122 位对应 a – z 的英文字母,详细可参考 ASCII码表; chr ( int $ascii )函数用于将对应整数 $ascii 转换成对应的字符。
function create_password($pw_length = 8)
{
$randpwd = '';
for ($i = 0; $i < $pw_length; $i++)
{
$randpwd .= chr(mt_rand(33, 126));
}
return $randpwd;
}
// 挪用该函数,传递长度参数$pw_length = 6
echo create_password(6);
办法二:
1、预置一个的字符串 $chars ,包含 a – z,A – Z,0 – 9,和一些特别字符
2、在 $chars 字符串中随机取一个字符
3、反复第二步 n 次,可得长度为 n 的暗码
function generate_password( $length = 8 ) {
// 暗码字符集,可恣意添加你需求的字符
$chars = 'abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789!@#$%^&*()-_ []{}<>~`+=,.;:/?';
$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;
}
function generate_password( $length = 8 ) {
// 暗码字符集,可恣意添加你需求的字符
$chars = 'abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789!@#$%^&*()-_ []{}<>~`+=,.;:/?';
$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;
}
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 = ($chars, $length);
$password = '';
for($i = 0; $i < $length; $i++)
{
// 将 $length 个数组元素毗连成字符串
$password .= $chars[$keys[$i]];
}
return $password;
}
工夫效力对照
咱们利用以下PHP代码,盘算下面的 3 个随秘密码生成函数生成 6 位暗码的运转工夫,进而对他们的工夫效力停止一个复杂的对照。
<?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";
?>
终究得出的了局是:
办法一:9.8943710327148E-5 秒
办法二:9.6797943115234E-5 秒
办法三:0.00017499923706055 秒
可以看出办法一和办法二的履行工夫都差不多,而办法三的运转工夫略微长了点。
原文:http://www.ludou.org/how-to-create-a-password-generator-using-php.html
在一个团队之中或者说是在一个公司的工作岗位上,需要注重团队之间的交流合作;在学习或工作上都要端正自己的态度,要以认真的态度来对每件事,这样才能让自己更快的投入、更快的学习,而不至于浪费自己的时间。 |
|