-
php随机密码生成的自定义函数
如果要做到安全密码与用户名都随机我有一个朋友做服务器的登录密码与用户名就是使用了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='';//开源软件:phpfensi.com
- 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;
- }
- ?>
- <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
- <html>
- <head>
- <title>php密码生成器</title>
- <style type="text/css">
- body {
- font-family: Arial;
- font-size: 10pt;
- }
- </style>
- </head>
- <body>
- <span style="font-weight: bold; font-size: 15pt;">密码生成器</span><br /><br />
- <?php
- if (isset($_GET['password_length'])){
- if(preg_match("/([0-9]{1,8})/", $_GET['password_length'])){
- print("密码生成成功:<br />
- <span style="font-weight: bold">" . gen_random_password($_GET['password_length']) . "</span><br /><br />n");
- } else {
- print("密码长度不正确!<br /><br />n");
- } //开源软件:phpfensi.com
- }
- print <<< end
- 请为密码生成其指定生成密码的长度:<br /><br />
- <form action="{$_SERVER['PHP_SELF']}" method="get">
- <input type="text" name="password_length">
- <input type="submit" value="生成">
- </form>
- end;
- ?>
- </body>
- </html>
出处:http://www.phpfensi.com/php/20150413/9217.html
栏目列表
最新更新
nodejs爬虫
Python正则表达式完全指南
爬取豆瓣Top250图书数据
shp 地图文件批量添加字段
爬虫小试牛刀(爬取学校通知公告)
【python基础】函数-初识函数
【python基础】函数-返回值
HTTP请求:requests模块基础使用必知必会
Python初学者友好丨详解参数传递类型
如何有效管理爬虫流量?
SQL SERVER中递归
2个场景实例讲解GaussDB(DWS)基表统计信息估
常用的 SQL Server 关键字及其含义
动手分析SQL Server中的事务中使用的锁
openGauss内核分析:SQL by pass & 经典执行
一招教你如何高效批量导入与更新数据
天天写SQL,这些神奇的特性你知道吗?
openGauss内核分析:执行计划生成
[IM002]Navicat ODBC驱动器管理器 未发现数据
初入Sql Server 之 存储过程的简单使用
这是目前我见过最好的跨域解决方案!
减少回流与重绘
减少回流与重绘
如何使用KrpanoToolJS在浏览器切图
performance.now() 与 Date.now() 对比
一款纯 JS 实现的轻量化图片编辑器
关于开发 VS Code 插件遇到的 workbench.scm.
前端设计模式——观察者模式
前端设计模式——中介者模式
创建型-原型模式