在這個網路安全漫天飛的年代,驗證碼功能起碼能算是一個值得信賴的好衛兵了。 本篇我們就來講下如何在ThinkPHP中使用驗證碼功能。
獲取擴展類庫
ThinkPHP的擴展中由影像處理類Image以及用於生成隨機驗證碼的字元處理類String共同完成驗證碼功能,可以在在HTTP://www.thinkphp.cn/extend/225. html下載影像處理類以及HTTP://www.thinkphp.cn/extend/266.html下載字元處理類,或者下載官方的完整擴展包(HTTP://www.thinkphp.cn/down/253. html)裡面也已經包含以上擴展類了。 如果是單獨下載的擴展類庫,把解壓後的Image.class.php和String.class.php 一起放入ThinkPHP/Extend/Library/ORG/Util/(如果沒有請手動創建)目錄下面。 由於驗證碼顯示採用了GD庫支援,所以需要環境支援GD庫。
生成驗證碼
生成驗證碼其實很簡單,只需要在你的Action中添加操作方法,一般為了避免受許可權控制的影響,我們通常把這個方法放到公共Action或者無需授權就能訪問的控制器(例如PublicAction)中, 下面我們以放到PublicAction控制器類中為例,代碼如下:
class PublicAction extends Action{ Public function verify(){ import('ORG. Util.Image'); Image::buildImageVerify(); } }
定義後,我們可以在任何需要驗證碼的模組中調用Public模組的verify方法來顯示驗證碼,需要做的僅僅是在需要的範本中添加如下調用代碼:
<img src='__APP__/Public/verify/' />
這樣,我們訪問該頁面後就能看到預設的驗證碼圖像顯示,如下所示:
如果你的驗證碼不能正常顯示,請檢查:
是否已經安裝GD庫支援並正常開啟;
Image類庫以及String類庫是否在正確的位置以及是否正確導入;
驗證碼輸出之前是否有任何的其他輸出(尤其是UTF8的BOM頭資訊輸出);
很多開發人員驗證碼無法顯示的情況多數是由於檔中有輸出或者BOM頭的情況,關於UTF8的BOM頭檢測有工具可以檢測,很多編輯器也支援去掉BOM保存(這個不清楚的話可以百度下)。 這裡要另外強調下很多開發人員在書寫代碼的時候不夠規範,例如經常會有下面的情形發生:
在檔的開頭有空行
在檔的尾部有空行
以上兩種情況都會導致頁面的其他輸出,從而導致驗證碼出錯。