一区二区久久-一区二区三区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機制的應用,轉載需保留來源!

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

主站蜘蛛池模板: 国产精品每日更新 | 一区二区在线观看高清 | 伊人久久成人成综合网222 | 欧美另类videosbestsex久久 | 狠狠色香婷婷久久亚洲精品 | 韩国一级做a爰片性色毛片 韩国一区二区三区 | 成人五月网 | 国产美女在线精品亚洲二区 | 99午夜高清在线视频在观看 | 久久穴| se视频在线观看 | 国产精品第5页 | 一级一级女人18毛片 | 最新国产在线观看福利 | 国产99视频精品免费视频7 | 国内自拍一二三四2021 | 久久久网久久久久合久久久久 | 九色91精品国产网站 | 色哟哟网站入口 | 亚洲视频二 | 视频一区 国产 | 亚洲激情综合 | 欧美成人亚洲综合精品欧美激情 | 狠狠做五月深爱婷婷天天综合 | 2020国产精品永久在线观看 | 国产四虎免费精品视频 | 久久亚洲视频 | 国产美女免费国产 | 婷婷伊人| 激情综合色综合久久综合 | 天天成人 | 成人精品一区二区久久 | 顶级欧美色妇xxxxx | 久久永久免费视频 | 亚洲图片另类小说 | 亚洲一区二区影视 | 黄色网址在线播放 | 久久国产偷 | www欧美视频 | 亚洲国产精久久小蝌蚪 | 国内精品福利视频 |