php密码生成类实例

本文实例讲述了php实现的密码生成类及其应用方法,分享给大家供大家参考。具体分析如下:

一、php密码生成类功能:

1.可设定密码长度。
2.可设定要生成的密码个数,批量生成。
3.可以指定密码的规则,字母,数字,特殊字符等。

二、用法:

GeneratePassword.class.php类文件如下:

<?php
/** Generate Password class,根据指定规则生成password
*  Date:  2013-12-23
*  Author: fdipzone
*  Ver:  1.0
*
*  Func:
*  public batchGenerate 批量生成密码
*  private generate   生成单个密码
*  private getLetter   获取字母
*  private getNumber   获取数字
*  private getSpecial  获取特殊字符
*/ 

class GeneratePassword{ // class start 

  // 密码的规则 default
  private $_rule = array(
   'letter' => 1,
   'number' => 1,
   'special' => 1
  );

  private $_length = 8;         // 密码长度
  private $_num = 1;          // 密码数量
  private $_special = '!@#$%^&*()_+=-'; //允许的特殊字符 

  /** 初始化
  * @param int  $length 密码长度
  * @param int  $num   密码数量
  * @param Array $rule  密码规则
  * @param String $special 允许的特殊字符
  */
  public function __construct($length=8, $num=1, $rule=array(), $special=''){ 

    if(isset($length) && is_numeric($length) && $length>=4 && $length<=50){ // 长度
      $this->_length = $length;
    } 

    if(isset($num) && is_numeric($num) && $num>0 && $num<=100){ // 数量
      $this->_num = $num;
    } 

    if(isset($special) && is_string($special) && $special!=''){ // 特殊字符
      $this->_special = $special;
    } 

    if($rule){ // 规则 

      $t_rule = array(); 

      if(isset($rule['letter']) && in_array($rule['letter'], array(1,2,3,4,5))){ // 1:可选用 2:必须 3:必须小写 4:必须大写 5:大小写都必须
        $t_rule['letter'] = $rule['letter'];
      } 

      if(isset($rule['number']) && in_array($rule['number'], array(1,2))){ // 1:可选用 2:必须
        $t_rule['number'] = $rule['number'];
      } 

      if(isset($rule['special']) && in_array($rule['special'], array(1,2))){ // 1:可选用 2:必须
        $t_rule['special'] = $rule['special'];
      } 

      if($t_rule){
        $this->_rule = $t_rule;
      }
    }
  } 

  /** 批量生成密码
  * @return Array
  */
  public function batchGenerate(){
    $passwords = array();
    for($i=0; $i<$this->_num; $i++){
      array_push($passwords, $this->generate());
    }
    return $passwords;
  } 

  /** 生成单个密码
  * @return String
  */
  private function generate(){ 

    $password = '';
    $pool = '';
    $force_pool = ''; 

    if(isset($this->_rule['letter'])){ 

      $letter = $this->getLetter(); 

      switch($this->_rule['letter']){
        case 2:
          $force_pool .= substr($letter, mt_rand(0,strlen($letter)-1), 1);
          break; 

        case 3:
          $force_pool .= strtolower(substr($letter, mt_rand(0,strlen($letter)-1), 1));
          $letter = strtolower($letter);
          break; 

        case 4:
          $force_pool .= strtoupper(substr($letter, mt_rand(0,strlen($letter)-1), 1));
          $letter = strtoupper($letter);
          break; 

        case 5:
          $force_pool .= strtolower(substr($letter, mt_rand(0,strlen($letter)-1), 1));
          $force_pool .= strtoupper(substr($letter, mt_rand(0,strlen($letter)-1), 1));
          break;
      } 

      $pool .= $letter;
    }
    if(isset($this->_rule['number'])){ 

      $number = $this->getNumber(); 

      switch($this->_rule['number']){
        case 2:
          $force_pool .= substr($number, mt_rand(0,strlen($number)-1), 1);
          break;
      } 

      $pool .= $number;
    } 

    if(isset($this->_rule['special'])){ 

      $special = $this->getSpecial(); 

      switch($this->_rule['special']){
        case 2:
          $force_pool .= substr($special, mt_rand(0,strlen($special)-1), 1);
          break;
      }
      $pool .= $special;
    } 

    $pool = str_shuffle($pool); // 随机打乱 

    $password = str_shuffle($force_pool. substr($pool, 0, $this->_length-strlen($force_pool))); // 再次随机打乱 

    return $password;
  } 

  /** 字母 */
  private function getLetter(){
    $letter = 'AaBbCcDdEeFfGgHhIiJjKkLlMmNnOoPpQqRrSsTtUuVvWwXxYyZz';
    return $letter;
  } 

  /** 数字 */
  private function getNumber(){
    $number = '1234567890';
    return $number;
  } 

  /** 特殊字符 */
  private function getSpecial(){
    $special = $this->_special;
    return $special;
  }
} // class end 

?>

demo示例程序如下:

<?php
require 'GeneratePassword.class.php'; 

$rule = array(
  'letter' => 5, // 必须含有大小写字母
  'number' => 2, // 必须含有数字
  'special' => 2 // 必须含有特殊字符
); 

$special = '!@#$%_-'; 

$obj = new GeneratePassword(8, 10, $rule, $special);
$passwords = $obj->batchGenerate(); 

echo implode('<br>', $passwords);
?>

本文完整源码可点击此处本站下载。

相信本文所述对大家的C#程序设计有一定的借鉴价值。

(0)

相关推荐

  • php实现随机生成易于记忆的密码

    本文实例讲述了php实现随机生成易于记忆的密码.分享给大家供大家参考.具体实现方法如下: 这里通过预定义一些单词,让php随机从这些单词中选择进行组合生成密码 function random_readable_pwd($length=10){ // the wordlist from which the password gets generated // (change them as you like) $words = 'dog,cat,sheep,sun,sky,red,ball,hap

  • PHP判断密码强度的方法详解

    本文实例讲述了PHP判断密码强度的方法.分享给大家供大家参考,具体如下: 一.php页面 $score = 0; if(!empty($_GET['value'])){ //接收的值 $str = $_GET['value']; } else{ $str = ''; } if(preg_match("/[0-9]+/",$str)) { $score ++; } if(preg_match("/[0-9]{3,}/",$str)) { $score ++; } if

  • PHP生成随机用户名和密码的实现代码

    有时候我们需要在应用程序中使用随机生成用户名和密码,这样可以大大提高应用程序的安全,在PHP中生成随机用户名和密码可以使用 mt_rand 函数或者是 rand 函数, rand 函数在验证码中的应用多一些,而生成长字符的随机码一般都需要 mt_rand 函数. 使用PHP生成随机数可以应用在许多地方,比如可以设计程序的随机密码.模拟掷骰子游戏的应用程序.石头剪子布游戏应用程序等等. 下面是PHP生成随机数的两个函数方法: 复制代码 代码如下: //自动为用户随机生成用户名(长度6-13)   

  • php编写批量生成不重复的卡号密码代码

    闲的蛋疼的时候,顺便加强下自己对PHP中数组操纵的一些技巧,就写了下面的一段小代码,可以随机生成卡号密码对应的数组,并且自动去重复,思路没有,纯粹瞎掰. <?php header('Content-Type:text/html; charset=utf-8'); function MakeCard() { set_time_limit(0); //处理缓冲区 ob_end_clean(); ob_implicit_flush(true); echo str_pad(" ", 25

  • php生成随机密码的三种方法小结

    使用PHP开发应用程序,尤其是网站程序,常常需要生成随机密码,如用户注册生成随机密码,用户重置密码也需要生成一个随机的密码.随机密码也就是一串固定长度的字符串,这里我收集整理了几种生成随机字符串的方法,以供大家参考. 方法一: 1.在 33 – 126 中生成一个随机整数,如 35, 2.将 35 转换成对应的ASCII码字符,如 35 对应 # 3.重复以上 1.2 步骤 n 次,连接成 n 位的密码 该算法主要用到了两个函数,mt_rand ( int $min , int $max )函数

  • PHP中快速生成随机密码的几种方式

    思路是这样的,密码通常是英文字母和数字的混合编排,我们可以借助随机函数rand函数随机的选择一个长字符串的一部分. function random_code($length = 8,$chars = null){ if(empty($chars)){ $chars = 'abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789'; } $count = strlen($chars) - 1; $code = ''; while(

  • php生成随机密码自定义函数代码(简单快速)

    实现代码,复制即用: <?phpheader("Content-type:text/html;charset=utf-8");function getRandPass($length = 6){ $password = ''; //将你想要的字符添加到下面字符串中,默认是数字0-9和26个英文字母 $chars = "0123456789abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ";  $char_

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

    代码一: 生成一个随机密码的函数,生成的密码为小写字母与数字的随机字符串,长度可自定义.相对来说,这个比较简单 复制代码 代码如下: <?php/* * php自动生成新密码自定义函数(带实例演示)      适用环境: PHP5.2.x  / mysql 5.0.x* */function genPassword($min = 5, $max = 8)  {      $validchars="abcdefghijklmnopqrstuvwxyz123456789";     

  • 纯php生成随机密码

    php生成一个随机的密码,方便快捷,可以随机生成安全可靠的密码. 分享代码如下 <?php header("Content-type:text/html;charset=utf-8"); function getRandPass($length = 6){ $password = ''; //将你想要的字符添加到下面字符串中,默认是数字0-9和26个英文字母 $chars = "0123456789abcdefghijklmnopqrstuvwxyzABCDEFGHIJ

  • php用户密码加密算法分析【Discuz加密算法】

    本文实例讲述了php用户密码加密算法.分享给大家供大家参考,具体如下: 今天在拿Discuz进行二次开发时需要在代码里验证Discuz的用户名密码,结果不小心掉进了坑里,因为Discuz的论坛有两张表来存储用户数据,一张在Discuz的数据库ultrax里面的pre_common_member里面,另一个是存储在了UCenter的数据库ucenter的uc_members表里.花了很大功夫在研究ultrax库里那张pre_common_member的数据,研究它的密码是如何生成的,结果搜了一下发

  • PHP生成随机密码方法汇总

    使用PHP开发应用程序,尤其是网站程序,常常需要生成随机密码,如用户注册生成随机密码,用户重置密码也需要生成一个随机的密码.随机密码也就是一串固定长度的字符串,这里我收集整理了几种生成随机字符串的方法,以供大家参考. 方法一: 1.在 33 – 126 中生成一个随机整数,如 35, 2.将 35 转换成对应的ASCII码字符,如 35 对应 # 3.重复以上 1.2 步骤 n 次,连接成 n 位的密码 该算法主要用到了两个函数,mt_rand ( int $min , int $max )函数

随机推荐