首页建站经验 php随机密码生成的自定义函数

php随机密码生成的自定义函数

如果要做到安全密码与用户名都随机我有一个朋友做服务器的登录密码与用户名就是使用了phpmyadmin随机生成密码功能来做的,与其用phpmyadmin不如自己做了,下文整理了一些关于…

如果要做到安全密码与用户名都随机我有一个朋友做服务器的登录密码与用户名就是使用了phpmyadmin随机生成密码功能来做的,与其用phpmyadmin不如自己做了,下文整理了一些关于php随机密码生成的自定义函数供大家参考.

可以指定生成的字符串长度,代码如下:

function rand_str($length, $max=FALSE)

{

if (is_int($max) && $max > $length)

{

$length = mt_rand($length, $max);

}

$output = '';

for ($i=0; $i<$length; $i++)

{

$which = mt_rand(0,2);

if ($which === 0)

{

$output .= mt_rand(0,9);

}

elseif ($which === 1)

{

$output .= chr(mt_rand(65,90));

}

else

{

$output .= chr(mt_rand(97,122));

}

}

return $output;

}

调用实例:$randstr = rand_str(16);

生成随机字符串的函数,代码如下:

<?php

/**

* 产生随机字符串

*

* 产生一个指定长度的随机字符串,并返回给用户

*

* @access public

* @param int $len 产生字符串的位数

* @return string

*/

function randStr($len=6) {

$chars='ABDEFGHJKLMNPQRSTVWXYabdefghijkmnpqrstvwxy23456789#%*'; // characters to build the password from

mt_srand((double)microtime()*1000000*getmypid()); // seed the random number generater (must be done)

$password='';

while(strlen($password)<$len)

$password.=substr($chars,(mt_rand()%strlen($chars)),1);
return $password;

}

?>

创建字符池.

function randomkeys($length)

{

$pattern = '1234567890abcdefghijklmnopqrstuvwxyz
ABCDEFGHIJKLOMNOPQRSTUVWXYZ,./&l
t;>?;#:@~[]{}-_=+)(*&^%$?!'; //字符池
for($i=0; $i<$length; $i++)

{

$key .= $pattern{mt_rand(0,35)}; //生成php随机数

}

return $key;

}

echo randomkeys(8);

无需创建字符池

function randomkeys($length)

{

$output='';

for ($a = 0; $a < $length; $a++) {

$output .= chr(mt_rand(35, 126)); //生成php随机数
}

return $output;

}

echo randomkeys(8);

随机用户名和随机密码例子:

//随机生成用户名(长度6-13)

function create_password($pw_length = 4){

$randpwd = '';

for ($i = 0; $i < $pw_length; $i++){

$randpwd .= chr(mt_rand(33, 126));

}

return $randpwd;

}

function generate_username( $length = 6 ) {

// 密码字符集,可任意添加你需要的字符

$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;

}

//调用

$userId = 'user'.generate_username(6);

$pwd = create_password(9);

mt_srand生成随机种子,密码的长度可以随意定义,最长32位.

<?php

mt_srand((double) microtime() * 1000000);

function gen_random_password($password_length = 32, $generated_password = ""){

$valid_characters = "abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789";

$chars_length = strlen($valid_characters) - 1;

for($i = $password_length; $i--; ) {

//$generated_password .= $valid_characters[mt_rand(0, $chars_length)];

$generated_password .= substr($valid_characters, (mt_rand()%(strlen($valid_characters))), 1);

}

return $generated_password;

}

?>


php密码生成器

密码生成器

<?php

if (isset($_GET['password_length'])){

if(preg_match("/([0-9]{1,8})/", $_GET['password_length'])){

print("密码生成成功:

" . gen_random_password($_GET['password_length']) . "

n");

} else {

print("密码长度不正确!

n");

}

}

print <<< end
请为密码生成其指定生成密码的长度:

end;

?>

 

本文来自网络,不代表1号站长-站长学院|资讯交流平台立场。转载请注明出处: https://www.1cn.cc/jianzhan/jingyan/17104.html
上一篇php多语言截取字符串函数
下一篇 PHP判断客户端是pc或web端还是移动手机端
admin

作者: admin

这里可以再内容模板定义一些文字和说明,也可以调用对应作者的简介!或者做一些网站的描述之类的文字或者HTML!

为您推荐

评论列表()

    联系我们

    联系我们

    0898-88888888

    在线咨询: QQ交谈

    邮箱: email@wangzhan.com

    工作时间:周一至周五,9:00-17:30,节假日休息

    关注微信
    微信扫一扫关注我们

    微信扫一扫关注我们

    关注微博
    返回顶部