溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

CI框架中優化驗證碼機制的示例分析

發布時間:2021-06-28 09:55:42 來源:億速云 閱讀:163 作者:小新 欄目:開發技術

這篇文章給大家分享的是有關CI框架中優化驗證碼機制的示例分析的內容。小編覺得挺實用的,因此分享給大家做個參考,一起跟隨小編過來看看吧。

具體如下:

驗證碼機制在CI框架中是通過一個輔助函數captcha()進行實現的——驗證碼輔助函數文件包含了一些幫助你創建驗證碼圖片的函數。。

那么我們如何使用CI的captcha()輔助函數來完成驗證碼功能呢?下面我會先講述如何使用CI的captcha()輔助函數來完成驗證碼功能,然后在講述如何具體的對CI框架的驗證碼機制進行優化。

1、CI框架驗證碼功能的使用

a)  首先我們要先加載輔助函數

加載輔助函數一共有兩種方法:

①、自動加載

我們可以在根文件目錄下的 “application/config/autoload.php” 文件中進行設置自動加載。

//ci框架設置自動加載輔助函數
//captcha驗證碼復制函數
$autoload['helper'] = array('url','captcha');

由于我們的項目使用驗證碼的地方非常有限,故而不推薦使用自動加載這種方法,我們可以在使用到的地方加載使用就可以了。

②、在使用到的地方進行加載

這種方法我們還是比較推薦的,消耗資源較少,效率會稍微的高一點。在你使用到驗證碼的控制器中寫一個構造函數,在構造函數中進行驗證碼輔助函數加載就可以了。

//構造函數
public function __construct()
{
  //切記在控制器的構造函數中一定先繼承父類控制器的構造函數
  parent::__construct();$this->load->helper('captcha');
}

b) 然后使用驗證碼輔助函數創建驗證碼

$vals = array(
    'word'     => 'Random word',    //驗證碼上顯示的字符,可以寫成函數,例如:rand(100000,999999)
      'img_path'   => './data/captcha/',  //驗證碼保存路徑
      'img_url'    => base_url('data/captcha'),    //驗證碼圖片url
      'font_path'   => './path/to/fonts/texb.ttf',    //驗證碼上字體
      'img_width'   => '150',    //驗證碼圖片寬度
      'img_height'  => 30,      //驗證碼圖片高度
      'expiration'  => 7200,     //驗證碼圖片刪除時間
      'word_length'  => 8,      //驗證碼長度
      'font_size'   => 16,      //驗證碼字體大小
      'img_id'    => 'Imageid',
      'pool'     => '0123456789abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ',
      'colors'    => array(
              'background' => array(255, 255, 255),
            'border' => array(255, 255, 255),
            'text' => array(0, 0, 0),
            'grid' => array(255, 40, 40)
      ),
);

$cap = create_captcha($vals);
var_dump($cap);

這樣驗證碼就創建完成,img_path和img_url這倆個參數必須存在,并且,img_path所表示的路徑文件夾必須存在,不然的話創建驗證碼不會成功。由于每創建一次驗證碼就會生成一張圖片放到你設置的文件夾中,這樣是非常消耗資源的,故此我們要對CI框架的驗證碼功能進行優化。

2、CI框架驗證碼的優化

優化思路:①、我們不讓框架生成的圖片進行保存到服務器中;②、我們只保留驗證碼的的內容即可。

要想對驗證碼功能進行優化,我們就要對驗證碼輔助函數功能進行擴展。

a)  擴展驗證碼輔助函數

首先將根目錄下 “system/helpers/captcha_helper.php” 文件復制一份到根目錄下 "application/helpers" 目錄下,命名為 "MY_captcha_helper.php" ;

然后將下面代碼注釋掉(大概在96行到119行);

if ($img_path === '' OR $img_url === '' OR ! is_dir($img_path) OR ! is_really_writable($img_path) OR ! extension_loaded('gd'))
{
    return FALSE;
}

// -----------------------------------
// Remove old images
// -----------------------------------

$now = microtime(TRUE);

$current_dir = @opendir($img_path);
while ($filename = @readdir($current_dir))
{
    if (substr($filename, -4) === '.jpg' && (str_replace('.jpg', '', $filename) + $expiration) < $now)
    {
        @unlink($img_path.$filename);
    }
}

@closedir($current_dir);

此段代碼防止你沒有傳遞img_path和img_url參數以及參數所指的文件夾不存在就暫停執行函數。

再次注釋代碼(大概在318行到335行)

$img_url = rtrim($img_url, '/').'/';

if (function_exists('imagejpeg'))
{
    $img_filename = $now.'.jpg';
    imagejpeg($im, $img_path.$img_filename);
}
elseif (function_exists('imagepng'))
{
    $img_filename = $now.'.png';
    imagepng($im, $img_path.$img_filename);
}
else
{
    return FALSE;
}

$img = '<img '.($img_id === '' ? '' : 'id="'.$img_id.'"').' src="'.$img_url.$img_filename.'"  alt=" " />';

此段代碼用于創建驗證碼圖片,并且將圖片保存到你說創建的驗證碼文件夾中(image_path)。

最后,在create_captcha()函數的最后加上一個header頭,最后代碼如下:

//直接輸出
header("Content-Type:image/jpeg");   //加入圖片格式header頭
imagejpeg($im);
ImageDestroy($im);
//返回生成的驗證碼字符串,如果需要其他參數的話也可以加入返回
return $word;
//return array('word' => $word, 'time' => $now, 'image' => $img, 'filename' => $img_filename);

b) 應用擴展優化之后的驗證碼功能

首先在控制器中寫一個生成驗證碼方法;

然后在方法中進行調用驗證碼輔助函數,生成驗證碼;

最后在前臺進行調用方法,并實現點擊刷新功能。

生成驗證碼函數代碼:

//生成驗證碼
public function code()
{
    //調用函數生成驗證碼,上述的參數也可以繼續使用
    $vals = array(
        'word_length' => 6,
    );
    create_captcha($vals);
}

前臺調用餅實時刷新調用:

<td colspan="2" align="right">
  <img src="<?php echo site_url('admin/privilege/code');?>" alt="" onclick= this.src="<?php echo site_url('admin/privilege/code').'/'?>"+Math.random()  title="看不清?點擊更換另一個驗證碼。"/>
</td>

至此,CI框架的驗證碼功能機制優化我們就完成了。

感謝各位的閱讀!關于“CI框架中優化驗證碼機制的示例分析”這篇文章就分享到這里了,希望以上內容可以對大家有一定的幫助,讓大家可以學到更多知識,如果覺得文章不錯,可以把它分享出去讓更多的人看到吧!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

亚洲午夜精品一区二区_中文无码日韩欧免_久久香蕉精品视频_欧美主播一区二区三区美女