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

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

主站蜘蛛池模板: 免费国产午夜高清在线视频 | 久久久久久久成人午夜精品福利 | 亚洲激情图片 | 国产精品欧美亚洲韩国日本不卡 | 日韩黄色毛片 | 日本理论午夜中文字幕第一页 | 在线观看国产一区二区三区 | 午夜精品在线 | 久久国产资源 | 正在播放国产乱子伦视频 | 99在线在线视频免费视频观看 | 成人网页 | 日韩一级二级三级 | 黄色小视频在线观看免费 | 美女黄区 | 精品在线91 | 欧美激情视频在线观看一区二区三区 | 国产精品第9页 | 大色皇大久久大久久 | 米奇7777狠狠狠狠视频影院 | 欧美性猛交xx免费看 | 国产视频精品免费 | 综合色婷婷| 日韩无遮挡大尺度啪啪影片 | 91社区在线观看 | 欧美成人全部免费观看1314色 | 黄色在线观看网站 | 亚洲激情黄色 | 成人国产精品免费网站 | 国产在线视频99 | 青草悠悠视频在线观看 | 91成品视频| 色视频免费观看高清完整 | 久久永久视频 | 九九在线视频 | 免费精品美女久久久久久久久久 | adc影院在线观看成人 | 国产成人咱精品视频免费网站 | 黄色网在线免费观看 | 国产91丝袜香蕉在线播放 | 国产在线一区精品对白麻豆 |