php验证码实现代码(3种),php验证码代码3种_PHP教程

php中文网
发布: 2016-07-13 16:54:00
原创
1285人浏览过

php验证码实现代码(3种),php验证码代码3种

验证码在表单实现越来越多了,但是用js的写的验证码,总觉得不方便,所以学习了下php实现的验证码。

好吧,其实是没有事情干,但是又不想浪费时间,所以学习了下php实现验证码。正所谓,技多不压身。而且,也可以封装成一个函数,以后使用的时候也是很方便的,当然现在未封装。
现在来说说简单的纯数字验证码吧。
如果是初学者,建议按照我代码的注释 //数字  一步步来。最简单的方法,还是把整个代码复制走了。
新建一个captcha.php:

<&#63;php
 //10>设置session,必须处于脚本最顶部
 session_start();

 $image = imagecreatetruecolor(100, 30);  //1>设置验证码图片大小的函数
 //5>设置验证码颜色 imagecolorallocate(int im, int red, int green, int blue);
 $bgcolor = imagecolorallocate($image,255,255,255); //#ffffff
 //6>区域填充 int imagefill(int im, int x, int y, int col) (x,y) 所在的区域着色,col 表示欲涂上的颜色
 imagefill($image, 0, 0, $bgcolor);
 //10>设置变量
 $captcha_code = "";
 //7>生成随机数字
 for($i=0;$i<4;$i++){
  //设置字体大小
  $fontsize = 6;  
  //设置字体颜色,随机颜色
  $fontcolor = imagecolorallocate($image, rand(0,120),rand(0,120), rand(0,120));   //0-120深颜色
  //设置数字
  $fontcontent = rand(0,9);
  //10>.=连续定义变量
  $captcha_code .= $fontcontent; 
  //设置坐标
  $x = ($i*100/4)+rand(5,10);
  $y = rand(5,10);

  imagestring($image,$fontsize,$x,$y,$fontcontent,$fontcolor);
 }
 //10>存到session
 $_SESSION['authcode'] = $captcha_code;
 //8>增加干扰元素,设置雪花点
 for($i=0;$i<200;$i++){
  //设置点的颜色,50-200颜色比数字浅,不干扰阅读
  $pointcolor = imagecolorallocate($image,rand(50,200), rand(50,200), rand(50,200));  
  //imagesetpixel — 画一个单一像素
  imagesetpixel($image, rand(1,99), rand(1,29), $pointcolor);
 }
 //9>增加干扰元素,设置横线
 for($i=0;$i<4;$i++){
  //设置线的颜色
  $linecolor = imagecolorallocate($image,rand(80,220), rand(80,220),rand(80,220));
  //设置线,两点一线
  imageline($image,rand(1,99), rand(1,29),rand(1,99), rand(1,29),$linecolor);
 }

 //2>设置头部,image/png
 header('Content-Type: image/png');
 //3>imagepng() 建立png图形函数
 imagepng($image);
 //4>imagedestroy() 结束图形函数 销毁$image
 imagedestroy($image);
登录后复制

接着就是静态页的代码了:index.html

<!doctype html>
<html>
 <head>
  <meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
  <title>确认验证码</title>
 </head>
 <body>
  <form method="post" action="./form.php">
   <p>验证码: @@##@@' style="width:100px; height:30px" />
    <a href="javascript:void(0)" onclick="document.getElementById('captcha_img').src='./captcha.php&#63;r='+Math.random()">换一个&#63;</a>
   </p>
   <P>请输入验证码:<input type="text" name='authcode' value=''/></p>
   <p><input type='submit' value='提交' style='padding:6px 5px;'/></p>
                    <div class="aritcle_card">
                        <a class="aritcle_card_img" href="/ai/735">
                            <img src="https://img.php.cn/upload/ai_manual/001/246/273/68b6cdbf48df2598.png" alt="代码小浣熊">
                        </a>
                        <div class="aritcle_card_info">
                            <a href="/ai/735">代码小浣熊</a>
                            <p>代码小浣熊是基于商汤大语言模型的软件智能研发助手,覆盖软件需求分析、架构设计、代码编写、软件测试等环节</p>
                            <div class="">
                                <img src="/static/images/card_xiazai.png" alt="代码小浣熊">
                                <span>51</span>
                            </div>
                        </div>
                        <a href="/ai/735" class="aritcle_card_btn">
                            <span>查看详情</span>
                            <img src="/static/images/cardxiayige-3.png" alt="代码小浣熊">
                        </a>
                    </div>
                 
 </body>
</html>
登录后复制

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

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

显示页面如下:

立即学习PHP免费学习笔记(深入)”;

<&#63;php
 //10>设置session,必须处于脚本最顶部
 session_start();

 $image = imagecreatetruecolor(100, 30);  //1>设置验证码图片大小的函数
 //5>设置验证码颜色 imagecolorallocate(int im, int red, int green, int blue);
 $bgcolor = imagecolorallocate($image,255,255,255); //#ffffff
 //6>区域填充 int imagefill(int im, int x, int y, int col) (x,y) 所在的区域着色,col 表示欲涂上的颜色
 imagefill($image, 0, 0, $bgcolor);
 //10>设置变量
 $captcha_code = "";
 //7>生成随机的字母和数字
 for($i=0;$i<4;$i++){
  //设置字体大小
  $fontsize = 8;  
  //设置字体颜色,随机颜色
  $fontcolor = imagecolorallocate($image, rand(0,120),rand(0,120), rand(0,120));   //0-120深颜色
  //设置需要随机取的值,去掉容易出错的值如0和o
  $data ='abcdefghigkmnpqrstuvwxy3456789';
  //取出值,字符串截取方法 strlen获取字符串长度
  $fontcontent = substr($data, rand(0,strlen($data)),1);
  //10>.=连续定义变量
  $captcha_code .= $fontcontent;  
  //设置坐标
  $x = ($i*100/4)+rand(5,10);
  $y = rand(5,10);

  imagestring($image,$fontsize,$x,$y,$fontcontent,$fontcolor);
 }
 //10>存到session
 $_SESSION['authcode'] = $captcha_code;
 //8>增加干扰元素,设置雪花点
 for($i=0;$i<200;$i++){
  //设置点的颜色,50-200颜色比数字浅,不干扰阅读
  $pointcolor = imagecolorallocate($image,rand(50,200), rand(50,200), rand(50,200));  
  //imagesetpixel — 画一个单一像素
  imagesetpixel($image, rand(1,99), rand(1,29), $pointcolor);
 }
 //9>增加干扰元素,设置横线
 for($i=0;$i<4;$i++){
  //设置线的颜色
  $linecolor = imagecolorallocate($image,rand(80,220), rand(80,220),rand(80,220));
  //设置线,两点一线
  imageline($image,rand(1,99), rand(1,29),rand(1,99), rand(1,29),$linecolor);
 }

 //2>设置头部,image/png
 header('Content-Type: image/png');
 //3>imagepng() 建立png图形函数
 imagepng($image);
 //4>imagedestroy() 结束图形函数 销毁$image
 imagedestroy($image);
登录后复制
%0A%0A

%E5%85%B6%E4%BB%96%E7%9A%84%E4%B8%A4%E4%B8%AA%E9%A1%B5%E9%9D%A2%EF%BC%8C%E4%B8%8D%E8%AE%B8%E8%A6%81%E4%BF%AE%E6%94%B9%E3%80%82

%0A

%0A

%E4%B8%80%E8%88%AC%E8%80%8C%E8%A8%80%EF%BC%8C%E7%8E%B0%E5%9C%A8%E5%B0%B1%E5%B7%B2%E7%BB%8F%E5%A4%9F%E7%94%A8%E4%BA%86%E3%80%82%E4%BD%86%E6%98%AF%E5%B0%B1%E5%83%8F%E5%8A%A8%E6%BC%AB%E4%B8%80%E6%A0%B7%EF%BC%8C%E6%80%BB%E4%BC%9A%E6%9C%89%E7%95%AA%E5%A4%96%E3%80%82%0A%E9%82%A3%E4%B9%88%EF%BC%8C%E6%88%91%E4%BB%AC%E6%9D%A5%E4%B8%AA%E6%B1%89%E5%AD%97%E7%9A%84%E7%95%AA%E5%A4%96%E5%90%A7%E3%80%82%E5%85%B6%E5%AE%9E%E6%88%91%E4%B9%9F%E5%87%86%E5%A4%87%E5%B0%86%E6%B1%89%E5%AD%97%E7%9A%84%E9%AA%8C%E8%AF%81%E7%A0%81%E6%94%BE%E5%88%B0%E6%88%91%E7%9A%84%E6%AF%95%E4%B8%9A%E8%AE%BE%E8%AE%A1%E9%87%8C%E9%9D%A2%EF%BC%8C%E8%99%BD%E7%84%B6%E7%8E%B0%E5%9C%A8%E5%BE%88%E6%B5%81%E8%A1%8C%E6%BB%91%E5%8A%A8%E9%AA%8C%E8%AF%81%E7%A0%81%EF%BC%8C%E4%BD%86%E6%98%AF%E6%9C%AC%E4%BA%BA%E6%AF%95%E7%AB%9F%E4%B8%8D%E6%98%AF%E4%B8%93%E9%97%A8%E5%AD%A6%E4%B9%A0js%E7%9A%84%E3%80%82%0A

%0A%0A
<&#63;php
 //11>设置session,必须处于脚本最顶部
 session_start();

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

 //2>设置头部,image/png
 header('Content-Type: image/png');
 //3>imagepng() 建立png图形函数
 imagepng($image);
 //4>imagedestroy() 结束图形函数 销毁$image
 imagedestroy($image);
登录后复制
%0A%0A

%E5%85%B6%E4%BB%96%E7%9A%84%E9%A1%B5%E9%9D%A2%E4%B9%9F%E6%98%AF%E4%B8%8D%E9%9C%80%E8%A6%81%E4%BF%AE%E6%94%B9%E7%9A%84%E3%80%82

%0A

%E6%95%88%E6%9E%9C%E5%9B%BE%E5%A6%82%E4%B8%8B%EF%BC%9A

%0A

%0A

%E4%BB%A5%E4%B8%8A%E5%B0%B1%E6%98%AFphp%E5%AE%9E%E7%8E%B0%E7%9A%84%E4%B8%89%E7%A7%8D%E9%AA%8C%E8%AF%81%E7%A0%81%EF%BC%9A%E7%BA%AF%E6%95%B0%E5%AD%97%E9%AA%8C%E8%AF%81%E7%A0%81%EF%BC%8C%E6%95%B0%E5%AD%97%E5%8A%A0%E8%8B%B1%E6%96%87%E9%AA%8C%E8%AF%81%E7%A0%81%EF%BC%8C%E8%BF%98%E6%9C%89%E4%B8%80%E7%A7%8D%E6%B1%89%E5%AD%97%E9%AA%8C%E8%AF%81%E7%A0%81%EF%BC%8C%E5%B8%8C%E6%9C%9B%E5%AF%B9%E5%A4%A7%E5%AE%B6%E7%86%9F%E7%BB%83%E6%8E%8C%E6%8F%A1php%E9%AA%8C%E8%AF%81%E7%A0%81%E6%9C%89%E6%89%80%E5%B8%AE%E5%8A%A9%E3%80%82

%0Ahttp://www.bkjia.com/PHPjc/1052064.htmlwww.bkjia.comtruehttp://www.bkjia.com/PHPjc/1052064.htmlTechArticlephp%E9%AA%8C%E8%AF%81%E7%A0%81%E5%AE%9E%E7%8E%B0%E4%BB%A3%E7%A0%81%EF%BC%883%E7%A7%8D%EF%BC%89%EF%BC%8Cphp%E9%AA%8C%E8%AF%81%E7%A0%81%E4%BB%A3%E7%A0%813%E7%A7%8D%20%E9%AA%8C%E8%AF%81%E7%A0%81%E5%9C%A8%E8%A1%A8%E5%8D%95%E5%AE%9E%E7%8E%B0%E8%B6%8A%E6%9D%A5%E8%B6%8A%E5%A4%9A%E4%BA%86%EF%BC%8C%E4%BD%86%E6%98%AF%E7%94%A8js%E7%9A%84%E5%86%99%E7%9A%84%E9%AA%8C%E8%AF%81%E7%A0%81%EF%BC%8C%E6%80%BB%E8%A7%89%E5%BE%97%E4%B8%8D%E6%96%B9%E4%BE%BF%EF%BC%8C%E6%89%80%E4%BB%A5%E5%AD%A6%E4%B9%A0%E4%BA%86%E4%B8%8Bphp%E5%AE%9E%E7%8E%B0...

%0A
%0A">

相关标签:
php
PHP速学教程(入门到精通)
PHP速学教程(入门到精通)

PHP怎么学习?PHP怎么入门?PHP在哪学?PHP怎么学才快?不用担心,这里为大家提供了PHP速学教程(入门到精通),有需要的小伙伴保存下载就能学习啦!

下载
来源:php中文网
收藏 点赞
上一篇:PHP Web木马扫描器代码分享,phpweb木马扫描器_PHP教程 下一篇:php实现验证码,php验证码_PHP教程
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
最新问题
相关专题
更多>
热门推荐
开源免费商场系统广告
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新 English
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号