国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > PHP > 正文

php實現的click captcha點擊驗證碼類實例

2020-03-22 19:29:14
字體:
來源:轉載
供稿:網友
本文實例講述了php實現的click captcha點擊驗證碼類及其用法,是非常實用的功能。分享給大家供大家參考之用。具體如下:一、需求:現在常用的表單驗證碼大部分都是要用戶輸入為主,但這樣對手機用戶會不方便。
如果手機用戶訪問,可以不用輸入,而是click某一位置便可確認驗證碼,這樣就會方便很多。二、原理:1.使用PHP imagecreate創建PNG圖象,在圖中畫N個圓弧,其中一個是完整的圓(驗證用),將圓心坐標及半徑記錄入session。2.在瀏覽器,當用戶在驗證碼圖片上點擊時,記錄點擊的位置。3.將用戶點擊的坐標與session記錄的圓心坐標、半徑比較,判斷是否在圓中,如是則驗證通過。程序運行效果如下圖所示:三、實現方法:ClickCaptcha.html' target='_blank'>class.php類文件如下: php /** Click Captcha 驗證碼類 * Date: 2013-05-04 * Author: fdipzone * Ver: 1.0 class ClickCaptcha { // class start public $sess_name = 'm_captcha'; public $width = 500; public $height = 200; public $icon = 5; public $iconColor = array(255, 255, 0); public $backgroundColor = array(0, 0, 0); public $iconSize = 56; private $_img_res = null; public function __construct($sess_name=''){ if(session_id() == ''){ session_start(); if($sess_name!=''){ $this- sess_name = $sess_name; // 設置session name /** 創建驗證碼 */ public function create(){ // 創建圖象 $this- _img_res = imagecreate($this- width, $this- height); // 填充背景 ImageColorAllocate($this- _img_res, $this- backgroundColor[0], $this- backgroundColor[1], $this- backgroundColor[2]); // 分配顏色 $col_ellipse = imagecolorallocate($this- _img_res, $this- iconColor[0], $this- iconColor[1], $this- iconColor[2]); $minArea = $this- iconSize/2+3; // 混淆用圖象,不完整的圓 for($i=0; $i $this- icon; $i++){ $x = mt_rand($minArea, $this- width-$minArea); $y = mt_rand($minArea, $this- height-$minArea); $s = mt_rand(0, 360); $e = $s + 330; imagearc($this- _img_res, $x, $y, $this- iconSize, $this- iconSize, $s, $e, $col_ellipse); // 驗證用圖象,完整的圓 $x = mt_rand($minArea, $this- width-$minArea); $y = mt_rand($minArea, $this- height-$minArea); $r = $this- iconSize/2; imagearc($this- _img_res, $x, $y, $this- iconSize, $this- iconSize, 0, 360, $col_ellipse); // 記錄圓心坐標及半徑 $this- captcha_session($this- sess_name, array($x, $y, $r)); // 生成圖象 Header("Content-type: image/PNG"); ImagePNG($this- _img_res); ImageDestroy($this- _img_res); exit(); /** 檢查驗證碼 * @param String $captcha 驗證碼 * @param int $flag 驗證成功后 0:不清除session 1:清除session * @return boolean public function check($captcha, $flag=1){ if(trim($captcha)==''){ return false; if(!is_array($this- captcha_session($this- sess_name))){ return false; list($px, $py) = explode(',', $captcha); list($cx, $cy, $cr) = $this- captcha_session($this- sess_name); if(isset($px) && is_numeric($px) && isset($py) && is_numeric($py) && isset($cx) && is_numeric($cx) && isset($cy) && is_numeric($cy) && isset($cr) && is_numeric($cr)){ if($this- pointInArea($px,$py,$cx,$cy,$cr)){ if($flag==1){ $this- captcha_session($this- sess_name,''); return true; return false; /** 判斷點是否在圓中 * @param int $px 點x * @param int $py 點y * @param int $cx 圓心x * @param int $cy 圓心y * @param int $cr 圓半徑 * sqrt(x^2+y^2) r private function pointInArea($px, $py, $cx, $cy, $cr){ $x = $cx-$px; $y = $cy-$py; return round(sqrt($x*$x + $y*$y)) /** 驗證碼session處理方法 * @param String $name captcha session name * @param String $value * @return String private function captcha_session($name,$value=null){ if(isset($value)){ if($value!==''){ $_SESSION[$name] = $value; }else{ unset($_SESSION[$name]); }else{ return isset($_SESSION[$name]) $_SESSION[$name] : ''; } // class end
if(isset($_POST['send']) && $_POST['send']=='true'){ // submit $name = isset($_POST['name']) trim($_POST['name']) : ''; $captcha = isset($_POST['captcha']) trim($_POST['captcha']) : ''; $obj = new ClickCaptcha(); if($obj- check($captcha)){ echo 'your name is:'.$name; }else{ echo 'captcha not match'; echo ' a href="demo.php" back /a }else{ // html !DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd" html head meta http-equiv="content-type" content="text/html; charset=utf-8" title Click Captcha Demo /title script type="text/javascript" src="jquery-1.6.2.min.js" /script script type="text/javascript" $(function(){ $('#captcha_img').click(function(e){ var x = e.pageX - $(this).offset().left; var y = e.pageY - $(this).offset().top; $('#captcha').val(x+','+y); $('#btn').click(function(e){ if($.trim($('#name').val())==''){ alert('Please input name!'); return false; if($.trim($('#captcha').val())==''){ alert('Please click captcha!'); return false; $('#form1')[0].submit(); /script /head body form name="form1" id="form1" method="post" action="demo.php" onsubmit="return false" p name: input type="text" name="name" id="name" /p p Captcha:Please click full circle br img id="captcha_img" src="demo.php get_captcha=1 =time() " /p p input type="submit" id="btn" value="submit" /p input type="hidden" name="send" value="true" input type="hidden" name="captcha" id="captcha" /form /body /html php } 本文完整源碼點擊此處本站下載。希望本文所述對大家的PHP程序設計有所幫助。PHP教程

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

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 资阳市| 怀化市| 南康市| 齐齐哈尔市| 济南市| 保靖县| 乐至县| 靖州| 滕州市| 泾川县| 姜堰市| 广安市| 阿尔山市| 桃园县| 大安市| 界首市| 祁阳县| 秭归县| 芜湖县| 东乡县| 玉屏| 米林县| 揭东县| 泗阳县| 信丰县| 德昌县| 忻州市| 肥西县| 阜新市| 连平县| 宜川县| 大港区| 沿河| 隆德县| 九龙城区| 斗六市| 广元市| 康平县| 陇川县| 乌兰察布市| 彰化市|