2.可設定要生成的密碼個數,批量生成。
3.可以指定密碼的規則,字母,數字,特殊字符等。二、用 " /> 欧美一区二区二区,黄大片在线观看,成年人免费网

一区二区久久-一区二区三区www-一区二区三区久久-一区二区三区久久精品-麻豆国产一区二区在线观看-麻豆国产视频

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#程序設計有一定的借鑒價值。

php技術php密碼生成類實例,轉載需保留來源!

鄭重聲明:本文版權歸原作者所有,轉載文章僅為傳播更多信息之目的,如作者信息標記有誤,請第一時間聯系我們修改或刪除,多謝。

主站蜘蛛池模板: 中文字幕一视频97色伦 | 视频免费1区二区三区 | 免费视频色 | 一区二区三区在线免费看 | 亚洲视频一二 | 日本 3344www高清在线 | 天天天干| 国内精品亚洲 | 伊人久久免费视频 | 亚洲肥熟| 狠狠色伊人亚洲综合网站l 狠狠色伊人亚洲综合网站色 | 六月丁香婷婷综合 | 美女毛片免费 | 国产精品美女在线观看 | 草草精品视频 | 久久久久久久久女黄9999 | 伊人久久综合网亚洲 | 亚洲一二四区性毛片1在线 亚洲一级黄色毛片 | 2019天天操天天干天天透 | 91亚洲视频在线 | 国产区亚洲区 | 午夜免费小视频 | 欧美一级久久久久久久大片 | 一本色道久久综合亚洲精品高清 | 极品美女国产精品免费一区 | 成人永久免费视频网站在线观看 | 欧美三级免费看 | 久久久99精品免费观看 | 久艾草国产成人综合在线视频 | 第一区免费在线观看 | 国内精品久久影院 | 91免费永久国产在线观看 | 超级成人97碰碰碰免费 | 一区二区三区久久 | 免费污视频在线观看 | 99视频在线观看视频一区 | 韩国一大片a毛片 | 国产图片综合 | 黄美女网站 | 亚洲第一成网站 | 乱子伦免费视频中文字幕 |