现在的位置:首页>wordpress>正文

php实现纯数字,数字加文字,纯中文验证码

2015年12月31日 ⁄ 共 8038字 评论 1 条

说到验证码,就让部落想到了12306里面购买火车票的验证,骂声一片,原因很简单,太复杂了,今天我们要实现的,就是通过php实现纯数字,数字加文字,纯中文验证码.部落之前码在wordpress防垃圾评论之不用插件添加验证说到过一部分PHP代码,当时的方法是通过两个数定相加,一起来看看今天的这几个方法.

验证码在表单实现越来越多了,但是用js的写的验证码,总觉得不方便,所以学习了下php实现的验证码。好吧,其实是没有事情干,但是又不想浪费时间,所以学习了下php实现验证码。正所谓,技多不压身。而且,也可以封装成一个函数,以后使用的时候也是很方便的,当然现在未封装。

现在来说说简单的纯数字验证码吧。

如果是初学者,建议按照我代码的注释 //数字 一步步来。最简单的方法,还是把整个代码复制走.效果如下图:

纯数字验证码

新建一个captcha.php,内容如下:

  1. php    //10>设置session,必须处于脚本最顶部   
  2.     session_start();    $image = imagecreatetruecolor(100, 30);        //1>设置验证码图片大小的函数   
  3.     //5>设置验证码颜色 imagecolorallocate(int im, int red, int green, int blue);   
  4.     $bgcolor = imagecolorallocate($image,255,255,255); //#ffffff   
  5.     //6>区域填充 int imagefill(int im, int x, int y, int col)  (x,y) 所在的区域着色,col 表示欲涂上的颜色   
  6.     imagefill($image, 0, 0, $bgcolor);    //10>设置变量   
  7.     $captcha_code = "";    //7>生成随机数字   
  8.     for($i=0;$i<4;$i++){        //设置字体大小   
  9.         $fontsize = 6;           
  10.         //设置字体颜色,随机颜色   
  11.         $fontcolor = imagecolorallocate($image, rand(0,120),rand(0,120), rand(0,120));            //0-120深颜色   
  12.         //设置数字   
  13.         $fontcontent = rand(0,9);        //10>.=连续定义变量   
  14.         $captcha_code .= $fontcontent;       
  15.         //设置坐标   
  16.         $x = ($i*100/4)+rand(5,10);        $y = rand(5,10);   
  17.     
  18.         imagestring($image,$fontsize,$x,$y,$fontcontent,$fontcolor);   
  19.     }    //10>存到session   
  20.     $_SESSION['authcode'] = $captcha_code;    //8>增加干扰元素,设置雪花点   
  21.     for($i=0;$i<200;$i++){        //设置点的颜色,50-200颜色比数字浅,不干扰阅读   
  22.         $pointcolor = imagecolorallocate($image,rand(50,200), rand(50,200), rand(50,200));           
  23.         //imagesetpixel — 画一个单一像素   
  24.         imagesetpixel($image, rand(1,99), rand(1,29), $pointcolor);   
  25.     }    //9>增加干扰元素,设置横线   
  26.     for($i=0;$i<4;$i++){        //设置线的颜色   
  27.         $linecolor = imagecolorallocate($image,rand(80,220), rand(80,220),rand(80,220));        //设置线,两点一线   
  28.         imageline($image,rand(1,99), rand(1,29),rand(1,99), rand(1,29),$linecolor);   
  29.     }    //2>设置头部,image/png   
  30.     header('Content-Type: image/png');    //3>imagepng() 建立png图形函数   
  31.     imagepng($image);    //4>imagedestroy() 结束图形函数  销毁$image   
  32.     imagedestroy($image);  

接着就是静态页的代码了:index.html,内容如下:

  1. doctype html><html>   
  2.     <head>   
  3.         <meta http-equiv="Content-Type" content="text/html; charset=UTF-8">   
  4.         <title>确认验证码title>   
  5.     head>   
  6.     <body>   
  7.         <form method="post" action="./form.php">   
  8.             <p>验证码: <img id="captcha_img" border='1' src='./captcha.php?r=echo rand(); ?>' style="width:100px; height:30px" />                <a href="javascript:void(0)" onclick="document.getElementById('captcha_img').src='./captcha.php?r='+Math.random()">换一个?a>   
  9.             p>   
  10.             <P>请输入验证码:<input type="text" name='authcode' value=''/>p>   
  11.             <p><input type='submit' value='提交' style='padding:6px 5px;'/>p>       
  12.     body>html>  

从index.html可以看到,提交的表单是到form.php的,所以还要有一个判断的form.php代码:

  1. php    header("Content-Type:text/html;charset=utf8");            //设置头部信息   
  2.     //isset()检测变量是否设置   
  3.     if(isset($_REQUEST['authcode'])){        session_start();        //strtolower()小写函数   
  4.         if(strtolower($_REQUEST['authcode'])== $_SESSION['authcode']){            //跳转页面   
  5.             echo "<script language=\"javascript\">";            echo "document.location=\"./form.php\"";            echo "</script>";   
  6.         }else{            //提示以及跳转页面   
  7.             echo "<script language=\"javascript\">";            echo "alert('输入错误!');";            echo "document.location=\"./form.php\"";            echo "</script>";   
  8.         }        exit();   
  9.     }  

2.那么,纯数字的实现了,数字加英文的也应该不难了。要修改的代码 只是在 captcha.php 将 //7>生成随机数字 修改成 //7>生成随机的字母和数字,如果你真的很可爱的就修改这几个字就认为可以实现的话,那么祝贺你,你永远保持快乐。脑残儿童欢乐多。

废话不多说了,拉代码吧。

  1. php    //10>设置session,必须处于脚本最顶部   
  2.     session_start();    $image = imagecreatetruecolor(100, 30);        //1>设置验证码图片大小的函数   
  3.     //5>设置验证码颜色 imagecolorallocate(int im, int red, int green, int blue);   
  4.     $bgcolor = imagecolorallocate($image,255,255,255); //#ffffff   
  5.     //6>区域填充 int imagefill(int im, int x, int y, int col)  (x,y) 所在的区域着色,col 表示欲涂上的颜色   
  6.     imagefill($image, 0, 0, $bgcolor);    //10>设置变量   
  7.     $captcha_code = "";    //7>生成随机的字母和数字   
  8.     for($i=0;$i<4;$i++){        //设置字体大小   
  9.         $fontsize = 8;           
  10.         //设置字体颜色,随机颜色   
  11.         $fontcolor = imagecolorallocate($image, rand(0,120),rand(0,120), rand(0,120));            //0-120深颜色   
  12.         //设置需要随机取的值,去掉容易出错的值如0和o   
  13.         $data ='abcdefghigkmnpqrstuvwxy3456789';        //取出值,字符串截取方法   strlen获取字符串长度   
  14.         $fontcontent = substr($data, rand(0,strlen($data)),1);        //10>.=连续定义变量   
  15.         $captcha_code .= $fontcontent;           
  16.         //设置坐标   
  17.         $x = ($i*100/4)+rand(5,10);        $y = rand(5,10);   
  18.     
  19.         imagestring($image,$fontsize,$x,$y,$fontcontent,$fontcolor);   
  20.     }    //10>存到session   
  21.     $_SESSION['authcode'] = $captcha_code;    //8>增加干扰元素,设置雪花点   
  22.     for($i=0;$i<200;$i++){        //设置点的颜色,50-200颜色比数字浅,不干扰阅读   
  23.         $pointcolor = imagecolorallocate($image,rand(50,200), rand(50,200), rand(50,200));           
  24.         //imagesetpixel — 画一个单一像素   
  25.         imagesetpixel($image, rand(1,99), rand(1,29), $pointcolor);   
  26.     }    //9>增加干扰元素,设置横线   
  27.     for($i=0;$i<4;$i++){        //设置线的颜色   
  28.         $linecolor = imagecolorallocate($image,rand(80,220), rand(80,220),rand(80,220));        //设置线,两点一线   
  29.         imageline($image,rand(1,99), rand(1,29),rand(1,99), rand(1,29),$linecolor);   
  30.     }    //2>设置头部,image/png   
  31.     header('Content-Type: image/png');    //3>imagepng() 建立png图形函数   
  32.     imagepng($image);    //4>imagedestroy() 结束图形函数  销毁$image   
  33.     imagedestroy($image);  

其他的两个页面,不需要修改,效果如下图所示:

中英文验证码

一般而言,现在就已经够用了。但是就像动漫一样,总会有番外。

那么,我们来个汉字的番外吧。其实我也准备将汉字的验证码放到我的毕业设计里面,虽然现在很流行滑动验证码,但是本人毕竟不是专门学习js的。

而且,还可以和答辩的老师说,我们验证码不需要素材,连图片也是生成的,用自己的知识装13,也没有设么的。

  1. php    //11>设置session,必须处于脚本最顶部   
  2.     session_start();    //1>设置验证码图片大小的函数   
  3.     $image = imagecreatetruecolor(200, 60);           
  4.     //5>设置验证码颜色 imagecolorallocate(int im, int red, int green, int blue);   
  5.     $bgcolor = imagecolorallocate($image,255,255,255); //#ffffff   
  6.     //6>区域填充 int imagefill(int im, int x, int y, int col)  (x,y) 所在的区域着色,col 表示欲涂上的颜色   
  7.     imagefill($image, 0, 0, $bgcolor);    //7>设置ttf字体   
  8.     $fontface = 'FZYTK.TTF';    //7>设置字库,实现简单的数字储备   
  9.     $str='天地不仁以万物为刍狗圣人不仁以百姓为刍狗这句经常出现在控诉暴君暴政上地残暴不仁把万物都当成低贱的猪狗来看待而那些高高在上的所谓圣人们也没两样还不是把我们老百姓也当成猪狗不如的东西但实在正取的解读是地不情感用事对万物一视同仁圣人不情感用事对百姓一视同仁执子之手与子偕老当男女主人公含情脉脉看着对方说了句执子之手与子偕老女方泪眼朦胧含羞地回一句讨厌啦这样的情节我们是不是见过很多但是我们来看看这句的原句死生契阔与子成说执子之手与子偕老于嗟阔兮不我活兮于嗟洵兮不我信兮意思是说战士之间的约定说要一起死现在和我约定的人都走了我怎么活啊赤裸裸的兄弟江湖战友友谊啊形容好基友的基情比男女之间的爱情要合适很多吧';    //str_split()切割字符串为一个数组,一个中文在utf_8为3个字符   
  10.     $strdb = str_split($str,3);       
  11.     //>11   
  12.     $captcha_code = '';    //8>生成随机的汉子   
  13.     for($i=0;$i<4;$i++){        //设置字体颜色,随机颜色   
  14.         $fontcolor = imagecolorallocate($image, rand(0,120),rand(0,120), rand(0,120));            //0-120深颜色   
  15.         //随机选取中文   
  16.         $in = rand(0,count($strdb));        $cn = $strdb[$in];        //将中文记录到将保存到session的字符串中   
  17.         $captcha_code .= $cn;        /*imagettftext (resource $image ,float $size ,float $angle ,int $x ,int $y,int $color,  
  18.         string $fontfile ,string $text ) 幕布 ,尺寸,角度,坐标,颜色,字体路径,文本字符串  
  19.         mt_rand()生成更好的随机数,比rand()快四倍*/  
  20.         imagettftext($image, mt_rand(20,24),mt_rand(-60,60),(40*$i+20),mt_rand(30,35),$fontcolor,$fontface,$cn);   
  21.     }    //11>存到session   
  22.     $_SESSION['authcode'] = $captcha_code;    //9>增加干扰元素,设置点   
  23.     for($i=0;$i<200;$i++){        //设置点的颜色,50-200颜色比数字浅,不干扰阅读   
  24.         $pointcolor = imagecolorallocate($image,rand(50,200), rand(50,200), rand(50,200));           
  25.         //imagesetpixel — 画一个单一像素   
  26.         imagesetpixel($image, rand(1,199), rand(1,59), $pointcolor);   
  27.     }    //10>增加干扰元素,设置线   
  28.     for($i=0;$i<4;$i++){        //设置线的颜色   
  29.         $linecolor = imagecolorallocate($image,rand(80,220), rand(80,220),rand(80,220));        //设置线,两点一线   
  30.         imageline($image,rand(1,199), rand(1,59),rand(1,199), rand(1,59),$linecolor);   
  31.     }    //2>设置头部,image/png   
  32.     header('Content-Type: image/png');    //3>imagepng() 建立png图形函数   
  33.     imagepng($image);    //4>imagedestroy() 结束图形函数  销毁$image   
  34.     imagedestroy($image);  

其他的页面也是不需要修改的。效果图如下:

纯中文验证码

小结

文章部分内容来源自网络,由免费部落整理发布.

至于其它型式的PHP验证码,可以自行拓展.

评论 1 条 评论内容很精采,有内幕,而且绝对有干货

  1. 日本最高級高品質ロレックス 2018年10月11日 23:52  @回复  Δ-49楼 回复

    スーパーコピー財布
    当店は信頼できる楽天スーパーコピーブランド代引きの激安通販店です。
    スーパーコピーブランド,ブランド激安,楽天コピーブランド,スーパーコピーブランド代引きなどの商
    品が低価格でお客様に 提供します
    日本で最高品質のスーパーコピー時計、ブランド時計コピー、ロレックス時計、カルティエ時計、 オ
    メガ時計、ウブロ時計,IWC等一流ブランド時計
    送料は無料です(日本全国)!
    みんなのご光臨を歓迎します。
    ブランド激安ルイヴィトンコピー 、シャネルコピー、グッチコピー 、
    エルメスコピー、ロレックスコピー、グッチ偽物 、
    エルメス偽物バッグコピー、財布コピー、腕時計コピー
    スタイルが多い、品質がよい、価格が低い、実物写真!
    ルイヴィトン バッグ コピー等の2018最新作は豊富に取り
    揃えおりますので、ご希望の新作商品をネットで簡単購入できます。
    ★全ての商品は独特だけでなく、流行な先端に行っています。
    外観にも中身にも、本物が同じです!必ずご満足頂ける品質のシャネルスーパーコピー商品のみ販売しております.
    ★信用第一、良い品質、激安価格。
    全て激安特価でご提供.
    ルイヴィトン財布,ルイヴィトン財布 コピー,ルイヴィトンスーパーコピー,スーパーコピー

给我留言