這篇文章給大家分享的是有關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框架中優化驗證碼機制的示例分析”這篇文章就分享到這里了,希望以上內容可以對大家有一定的幫助,讓大家可以學到更多知識,如果覺得文章不錯,可以把它分享出去讓更多的人看到吧!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。