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

基于Zend的Captcha機制的應用

如何生成驗證碼圖片?使用php的GD? ok,right。其實Zend的Captcha模塊已經封裝好了。這篇文章就說一下如何使用Zend的Captcha模塊。


環境安裝
首先Zend的Captcha需要安裝GD。查看有沒有安裝GD需要去phpinfo()中看是否有GD模塊。(注意,有可能出現php -m里面的模塊有gd但phpInfo()里面的模塊沒有gd,這個問題是說明你的php和Apache沒有安裝對。具體請去google之)

(如果在安裝gd的過程中提示Missing Dependency: libt1.so.5模塊錯誤,請看這篇文章:http://www.siutung.org/post/730/)


生成驗證碼圖片
使用Zend_Captcha_Image類
復制代碼 代碼如下:
$captcha = new Zend_Captcha_Image();
$captcha->setWordLen('4')
    ->setHeight('60')
    ->setFont(NCHANNEL_FONT_DIR . '/arial.ttf')
    ->setImgDir(NCHANNEL_CAPTCHA_DIR)
    ->setDotNoiseLevel('5')
    ->setLineNoiseLevel('5');

$id = $captcha->generate();

$code = $captcha->getWord();

1 這里有兩個變量需要說一下,$id 和 $code。

圖片文件名就是$id . ".png"; 這個id是一個隨機數。

$code是這個圖片中的文字,就是驗證碼的答案

2 setWordLen 等設置的接口是Zend_Captcha_Image暴露給外面的對驗證碼圖片的設置。其實看函數名也能知道是做什么的了。具體請參考Zend的Api手冊。

3 font字體文件必須在服務器上有,ImgDir設置的是圖片生成路徑
 

驗證驗證碼圖片
好了,生成了驗證碼圖片,現在要驗證驗證碼了。

驗證步驟就需要用到Zend_Session_Namespace這個session存儲模塊。


首先,生成驗證碼的時候有id和code兩個變量應該存下來。
好吧,回到上一步,將代碼進行下修改
復制代碼 代碼如下:
$captcha = new Zend_Captcha_Image();
$captcha->setWordLen('4')
    ->setHeight('60')
    ->setFont(NCHANNEL_FONT_DIR . '/arial.ttf')
    ->setImgDir(NCHANNEL_CAPTCHA_DIR)
    ->setDotNoiseLevel('5')
    ->setLineNoiseLevel('5');

$id = $captcha->generate();
$codeSession = new Zend_Session_Namespace('captcha_code_' . $id);

$codeSession->code = $captcha->getWord();

這里看到,我們使用$captcha_code_$id將code存儲下來。目的是等到驗證步驟的時候使用。

第二步
給頁面傳遞表單的時候把$id和驗證碼圖片傳遞過去。

讓用戶填寫驗證碼。

第三步,驗證。
驗證這步需要用戶提供兩個參數: $id 和驗證碼答案$code
復制代碼 代碼如下:
$codeSession = new Zend_Session_Namespace('captcha_code_' . $this->_params['id']);
if ($codeSession == null || strtolower($codeSession->code) != strtolower($this->_params['code'])) {
    $this->Output(ERROR);

}

這段代碼讀起來很順口吧:如果captcha_code_$id中有保存code,并且code和用戶填寫的code一致,那么就驗證成功。


這樣,驗證碼驗證過程就結束了。


深入考慮
好了,其實驗證碼沒有這么簡單。下面有幾個問題值得考慮

驗證碼圖片是不會自動刪除的,所以生成的驗證碼圖片所在文件夾體積會不斷增加。怎么辦?
Image類中是提供了方法的$captcha->setGcFreq(5) 。

具體使用方法看API吧


我希望自己設置$id,怎么辦?
答案是在Zend_Captche_Image上再封裝一層,然后重寫generate()方法


比如我重寫了一個類:
復制代碼 代碼如下:
class Test_Captcha_Image extends Zend_Captcha_Image
{
    protected $_fid = "";

    public function generate()
    {
        $word = $this->_generateWord();
        $this->_setWord($word);
        if ($this->_fid) {
            $id = $this->_fid;
        }
        $this->_generateImage($id, $this->getWord());

        if (mt_rand(1, $this->getGcFreq()) == 1) {
            $this->_gc();
        }
        return $id;
    }

    public function setId($id) {
        $this->_fid = $id;
        return $this;
    }
}

我希望我每個用戶只有一個驗證碼,這個驗證碼的圖片名稱就是userid.png
 

那么使用這個類的代碼是這樣的
復制代碼 代碼如下:
$captcha = new Test_Captcha_Image();
$captcha->setWordLen('4')
    ->setHeight('60')
    ->setFont(NCHANNEL_FONT_DIR . '/arial.ttf')
    ->setImgDir(NCHANNEL_CAPTCHA_DIR)
    ->setDotNoiseLevel('5')
    ->setLineNoiseLevel('5')
    ->setId($user_id);

$id = $captcha->generate();
$codeSession = new Zend_Session_Namespace('captcha_code_' . $user_id);
$codeSession->code = $captcha->getWord();

--------------  
// 驗證session
$codeSession = new Zend_Session_Namespace('captcha_code_' . $this->_params['user_id']);
if ($codeSession == null || strtolower($codeSession->code) != strtolower($this->_params['code'])) {
    $this->Output(ERROR);
}

附言
Zend的Captcha是封裝了基本的驗證碼動作。生成簡單的驗證碼基本是完全不需要看內部的代碼的了,但如果你需要對驗證碼進行更高級的操作,比如修改驗證碼的顯示文字等,最好就需要將Captcha的源碼看一下了。

php技術基于Zend的Captcha機制的應用,轉載需保留來源!

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

主站蜘蛛池模板: 中文字幕一区二区在线观看 | 欧美成人一级视频 | 国产美女一区二区在线观看 | 天天干天天操天天做 | 国产黄色91 | 美女一级一级毛片 | 日本高清色www | www成人国产在线观看网站 | 亚洲国产精品久久久久网站 | 特别黄的免费视频大片 | 午夜国产精品免费观看 | 99pao在线视频成精品 | 男人的天堂久久精品激情a 男人进去女人爽免费视频国产 | 国产精品欧美久久久久天天影视 | 亚洲成年 | 欧美另类精品 | 国产色手机在线观看播放 | 在线观看a网站 | 丁香婷婷久久大综合 | 在线观看国产一区二区三区 | 国产福利2021最新在线观看 | 91福利国产在线在线播放 | 亚洲香蕉久久一区二区三区四区 | 国产v2ba最新在线观看 | 91网站视频在线观看 | 黄色网页免费观看 | 五月婷婷导航 | 新97人人模人人爽人人喊 | 国产成人免费高清视频网址 | 天天做天天爱夜夜大爽完整 | 无遮挡一级毛片性视频不卡 | 国产免费一区2区3区4区 | 亚洲另类激情专区小说婷婷久 | 日韩国产一区二区 | r18在线观看| 四虎影在线永久免费观看 | 亚洲视频综合 | 激情五月在线 | www激情五月| 色噜噜国产在线91蝌蚪 | 精品国产亚洲一区二区三区 |