本文實例講述了thinkPHP中驗證碼的簡單實現方法。分享給大家供大家參考,具體如下:
運行效果圖如下:

1.php端生成驗證碼函數
public function verify(){
// 驗證碼
import("@.Util.Image");
Image::buildImageVerify(4,1,'png',40,20,'verify');
}
/**
* 生成圖像驗證碼
* @static
* @access public
* @param string $length 位數
* @param string $mode 類型
* @param string $type 圖像格式
* @param string $width 寬度
* @param string $height 高度
* @return string
*/
static function buildImageVerify($length=4, $mode=1, $type='png', $width=48, $height=22, $verifyName='verify') {
import('ORG.Util.String');
$randval = String::randString($length, $mode);
session($verifyName, md5($randval));
$width = ($length * 10 + 10) > $width ? $length * 10 + 10 : $width;
if ($type != 'gif' && function_exists('imagecreatetruecolor')) {
$im = imagecreatetruecolor($width, $height);
} else {
$im = imagecreate($width, $height);
}
$r = Array(225, 255, 255, 223);
$g = Array(225, 236, 237, 255);
$b = Array(225, 236, 166, 125);
$key = mt_rand(0, 3);
$backColor = imagecolorallocate($im, $r[$key], $g[$key], $b[$key]); //背景色(隨機)
$borderColor = imagecolorallocate($im, 100, 100, 100); //邊框色
imagefilledrectangle($im, 0, 0, $width - 1, $height - 1, $backColor);
imagerectangle($im, 0, 0, $width - 1, $height - 1, $borderColor);
$stringColor = imagecolorallocate($im, mt_rand(0, 200), mt_rand(0, 120), mt_rand(0, 120));
// 干擾
for ($i = 0; $i < 10; $i++) {
imagearc($im, mt_rand(-10, $width), mt_rand(-10, $height), mt_rand(30, 300), mt_rand(20, 200), 55, 44, $stringColor);
}
for ($i = 0; $i < 25; $i++) {
imagesetpixel($im, mt_rand(0, $width), mt_rand(0, $height), $stringColor);
}
for ($i = 0; $i < $length; $i++) {
imagestring($im, 5, $i * 10 + 5, mt_rand(1, 8), $randval{$i}, $stringColor);
}
Image::output($im, $type);
}
生成圖片的同時,傳入到session中。
2.頁面端
<img id="verifyImg" src="{sh::U('Agent/Login/verify')}" onClick="changeVerify()" title="點擊刷新驗證碼" /></div>
直接src中調用。
點擊觸發改變。
function changeVerify(){
verifyURL = "{sh::U('Agent/Login/verify')}";
$("#verifyImg").attr("src",verifyURL);
return false;
}
3.後台驗證,對比post字段與session中的驗證碼是否一致。
if($_SESSION['verify'] != md5($_POST['verify'])) {
$this->error('驗證碼錯誤!');
}
更多關於thinkPHP相關內容感興趣的讀者可查看本站專題:《ThinkPHP入門教程》、《thinkPHP模板操作技巧總結》、《ThinkPHP常用方法總結》、《codeigniter入門教程》、《CI(CodeIgniter)框架進階教程》、《Zend FrameWork框架入門教程》、《smarty模板入門基礎教程》及《PHP模板技術總結》。
希望本文所述對大家基於ThinkPHP框架的PHP程序設計有所幫助。