使用PHP生成1000個隨機注冊碼_PHP教程

      編輯Tag賺U幣
      教程Tag:暫無Tag,歡迎添加,賺取U幣!

      推薦:新手通過實例學習動態網頁PHP的語法
      以下為引用的內容: <?php echo "Hello, World!"; ?> 運行結果: Hello, World! 變量標記為“

      一般程序中都需要用到注冊碼,為了防止盜版,如果把生成的注冊碼保存到數據庫里,并且通過軟件在客戶端訪問服務器來匹配客戶端輸入的驗證碼是否正確,這是一種好的解決盜版的方案。

      下面描述的代碼就是使用PHP生成數字驗證碼,類似于:152-562-986-230 這樣的,為了保證驗證碼不被猜中,我們采用比較復雜的12位數字,那么可能性就有:999999999999 這么多,那么重復的幾率就很小。

      我們下面的的程序就演示了身成1000個隨機的注冊碼的例子。包括兩個程序,一個程序用來生成從 100到999的序列數字并且保存到文件里,第二個程序是從文件中提取隨機數對應行的數字生成驗證碼串,然后身成1000個隨機串,最后保存在文件里。

      程序一:生成序列數字

      以下為引用的內容:

      <?php
      /**
      * File: 生成4位的數字
      * Author: heiyeluren
      * Create: 2005-9-5 22:26
      */

      /* 配置 */
      $start_num = 100;
      $end_num = 999;
      $save_file = "./number.txt";

      //生成從1000到9999的數字序列
      for ($i=$start_num; $i<=$end_num; $i )
      {
      $nums[] = $i;
      }

      //把上面生成的數字序列寫入文件
      $fp = fopen($save_file, "w") or die("Open $save_file failed");
      fwrite($fp, implode("\r\n", $nums)) or die("Write $save_file failed");
      unset($nums);
      fclose($fp);

      echo "Create $save_file succeed!";

      ?>

      執行上面的代碼,就會在當前程序目錄生成一個 number.txt文件,里面保存了類似下面的數字:

      以下為引用的內容:
      100
      101
      102
      103
      104
      105
      106...

      程序二:生成驗證碼


      以下為引用的內容:
      <?php
      /**
      * File: 生成CD-Key程序
      * Author: heiyeluren
      * Create: 2005-9-5 22:26
      */

      /* 配置 */
      $key_sum = 1500; //CD-Key最大數量,防止重復值
      $key_total = 1000; //最終需要的CD-Key數量
      $limiter = "-"; //CD-Key每組數字之間的連接符
      $save_file = "./cd_key.txt"; //保存CD-Key文件
      $num_file = "./number.txt"; //序列數字文件
      $file = file($num_file); //打開序列數文件
      $start_num = 0; //最小隨機數
      $end_num = count($file); //最大隨機數

      /* 生成隨機數字串 */
      $cdkey = array();
      for ($i=0; $i<$key_sum; $i )
      {
      $key_str = $file[rand_num($start_num, $end_num)].$limiter.
      $file[rand_num($start_num, $end_num)].$limiter.
      $file[rand_num($start_num, $end_num)].$limiter.
      $file[rand_num($start_num, $end_num)];
      $cdkey[] = str_replace("\r\n", "", $key_str);
      }

      /* 過濾重復串并且提取最終需要的CD-Key數量 */
      $cdkey = array_unique($cdkey);
      $key_result = array();
      for ($i=0; $i<$key_total; $i )
      {
      $key_result[] = $cdkey[$i];
      }

      /* 把最終的CD-Key寫入文件 */
      $fp = fopen($save_file, "w ") or die("Open $save_file failed");
      fwrite($fp, implode("\r\n", $key_result)) or die("Write $save_file failed");
      unset($cdkey);
      unset($$key_result);
      fclose($fp);

      echo "Create $key_total key succeed!";

      /* 隨機函數 */
      function rand_num($start, $end)
      {
      return mt_rand($start, $end);
      }

      ?>

      執行上面的程序就會生成cd_key.txt文件,里面包含了類似下面的驗證碼:

      以下為引用的內容:
      573-225-374-118
      691-553-280-280
      969-594-607-211
      251-575-776-563
      280-289-739-533...

      這樣,就完整的達到了我們的目的,你也可以把以上隨機串保存到數據庫里,方便調用。靈活設置以上變量,你能夠生成16位、20位的驗證碼。如果你有興趣,也可以寫類似 XDF8F-ADE89-D0J5C-4RTFG之類的驗證碼,呵呵發揮下想象力。

      分享:黑客隱藏PHP文件后門的技巧
      最近很多朋友都在問我是否能把我那一句話木馬隱藏到HTML或圖片里,其實把一句話木馬插入到PHP文件中就已經很隱蔽了,如果說硬是要放到HTML文件或圖片里,就接著往下看的這篇測試報告吧。 要

      來源:模板無憂//所屬分類:PHP教程/更新時間:2008-08-22
      相關PHP教程