一区二区久久-一区二区三区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先生在线| 婷婷国产在线 | 热re99久久国产精品 | 国产91精品高清一区二区三区 | 亚洲综合激情小说 | 视频国产免费 | 亚洲精品一级片 | 欧美xxxx在线视频 | 国产91精品系列在线观看 | 1024cc香蕉视频 | 日本激情视频网站w | 狂野欧美性猛交xxxx免费 | 色视频免费看 | 欧美精品福利 | 激情欧美一区二区三区中文字幕 | 久久婷婷综合中文字幕 | 永久免费精品影视网站 | 亚洲第一免费视频 | 国产色婷婷免费视频 | 国产 麻豆 | 台湾佬自偷自拍情侣在线 | 久久久精品国产四虎影视 | 一本伊人| 日韩视频免费 | 中文字幕免费在线视频 | 日韩在线一区高清在线 | 一二三四视频在线社区7 | 午夜丁香婷婷 | 国产精品自在线拍国产 | 色多多网站入口 |