2.可設定要生成的密碼個數,批量生成。
3.可以指定密碼的規則,字母,數字,特殊字符等。二、用 " /> 涩涩视频www在线观看入口,国产欧美另类久久久精品免费,日韩欧美精品有码在线播放免费

天天躁日日躁狠狠躁AV麻豆-天天躁人人躁人人躁狂躁-天天澡夜夜澡人人澡-天天影视香色欲综合网-国产成人女人在线视频观看-国产成人女人视频在线观看

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密碼生成類實例,轉載需保留來源!

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

主站蜘蛛池模板: 亚洲日本va中文字幕久久 | 双腿打开揉弄高潮H苏安安秦慕深 | 爱啪国产精品视频在线 | 精品网站一区二区三区网站 | 超碰在线视频97 | 富婆找黑人老外泻火在线播放 | 69国产精品人妻无码免费 | 亚洲日韩在线观看 | 亚洲一区免费观看 | 女子叉开腿让男子桶免费软件 | 国产系列在线亚洲视频 | 国产午夜精品自在自线之la | 中文字幕在线永久 | 欧美日韩国产在线一区二区 | 久久视频在线视频观品15 | 亚洲日本一区二区三区在线不卡 | 久久免费看视频 | 免费观看亚洲视频 | 久久久亚洲国产精品主播 | 老师那里好大又粗h男男 | 亚洲精品午夜aaa级久久久久 | 搞av.com| 老师洗澡让我吃她胸的视频 | 4480YY旧里番在线播放 | 国产在线精品亚洲另类 | YELLOW高清在线观看2019 | 青青草AV国产精品 | 美女扒开尿口直播 | 男女性杂交内射妇女BBWXZ | 成人中文字幕在线观看 | 无码乱人伦一区二区亚洲 | 免费在线视频一区 | 狠狠操天天操夜夜操 | 在线免费观看日本 | 国内精品久久久久影院网站 | 国产成人久视频免费 | 亚洲精品免费网站 | 超碰日韩人妻高清视频 | 做你的爱人BD日本 | 国产 有码 无码 电影 | 久久精品无码成人国产毛 |