PHP实现算式验证码和汉字验证码实例


Posted in PHP onMarch 09, 2015

在PHP网站开发中,验证码可以有效地保护我们的表单不被恶意提交,但是如果不使用算式验证码或者汉字验证码,仅仅使用简单的字母或者数字验证码,这样的验证码方案真的安全吗?

大家知道简单数字或者字母验证码很容易被破解,但是算式验证码或者中文汉字验证码不容易被破解,所以建议大家在使用验证码的时候,尽量用算式验证码或者中文汉字验证码。

下面是我写的两种验证码代码,有用到的朋友可以参考下:

1.算式验证码:

<?php

session_start();

header("Content-type: image/png");

$num1 = mt_rand(0,9);//第一位数

$num2 = mt_rand(1,9);//第二位数

$type_str = "+-*";//方法字符串集合

$type = substr($type_str,rand(0,2),1);//随机方法

$change = mt_rand(1,3);

if($change==1){

 $code = "$num1$type$num2=?";

 $result = "$verifyCode=$num1$type$num2;";

 eval($result);

 $_SESSION['authnum_session'] = $verifyCode;  

}elseif($change==2){

 $result = "$verifyCode=$num1$type$num2;";

 eval($result);

    $code = $num1.$type."_=".$verifyCode;

 $_SESSION['authnum_session'] = $num2;  

}elseif($change==3){

 $result = "$verifyCode=$num1$type$num2;";

 eval($result);

    $code = "_".$type.$num2."=".$verifyCode;

 $_SESSION['authnum_session'] = $num1;  

}

$im = imagecreate(68,28);   

$black = imagecolorallocate($im, 0,0,0);     

$white = imagecolorallocate($im, 255,255,255);

$gray = imagecolorallocate($im, 200,200,200);

$red = imagecolorallocate($im, 255, 0, 0);

imagefill($im,0,0,$white);        

imagestring($im, 5, 10, 8, $code, $black);    

for($i=0;$i<70;$i++) {

 imagesetpixel($im, mt_rand(0, 58) , mt_rand(0, 28) , $black); 

 imagesetpixel($im, mt_rand(0, 58) , mt_rand(0, 28) , $red); 

 imagesetpixel($im, mt_rand(0, 58) , mt_rand(0, 28) , $gray); 

}

imagepng($im);

imagedestroy($im);

?>

2.中文汉字验证码:
<?php

session_start();

$ch_str="的一是在了不和有大这主中人上为们地个用工时要动国产以我到他会作来分生对于学下级就年阶义发成部民可出能方进同行面说种过命度革而多子后自社加小机也经力线本电高量长党得实家定深法表着水理化争现所二起政三好十战无农使性前等反体合斗路图把结第里正新开论之物从当两些还天资事队批如应形想制心样干都向变关点育重其思与间内去因件日利相由压员气业代全组数果期导平各基或月毛然问比展那它最及外没看治提五解系林者米群头意只明四道马认次文通但条较克又公孔领军流入接席位情运器并飞原油放立题质指建区验活众很教决特此常石强极土少已根共直团统式转别造切九你取西持总料连任志观调七么山程百报更见必真保热委手改管处己将修支识病象几先老光专什六型具示复安带每东增则完风回南广劳轮科北打积车计给节做务被整联步类集号列温装即毫知轴研单色坚据速防史拉世设达尔场织历花受求传口断况采精金界品判参层止边清至万确究书术状厂须离再目海交权且儿青才证低越际八试规斯近注办布门铁需走议县兵固除般引齿千胜细影济白格效置推空配刀叶率述今选养德话查差半敌始片施响收华觉备名红续均药标记难存测士身紧液派准斤角降维板许破述技消底床田势端感往神便贺村构照容非搞亚磨族火段算适讲按值美态黄易彪服早班麦削信排台声该击素张密害侯草何树肥继右属市严径螺检左页抗苏显苦英快称坏移约巴材省黑武培著河帝仅针怎植京助升王眼她抓含苗副杂普谈围食射源例致酸旧却充足短划剂宣环落首尺波承粉践府鱼随考刻靠够满夫失包住促枝局菌杆周护岩师举曲春元超负砂封换太模贫减阳扬江析亩木言球朝医校古呢稻宋听唯输滑站另卫字鼓刚写刘微略范供阿块某功套友限项余倒卷创律雨让骨远帮初皮播优占死毒圈伟季训控激找叫云互跟裂粮粒母练塞钢顶策双留误础吸阻故寸盾晚丝女散焊功株亲院冷彻弹错散商视艺灭版烈零室轻血倍缺厘泵察绝富城冲喷壤简否柱李望盘磁雄似困巩益洲脱投送奴侧润盖挥距触星松送获兴独官混纪依未突架宽冬章湿偏纹吃执阀矿寨责熟稳夺硬价努翻奇甲预职评读背协损棉侵灰虽矛厚罗泥辟告卵箱掌氧恩爱停曾溶营终纲孟钱待尽俄缩沙退陈讨奋械载胞幼哪剥迫旋征槽倒握担仍呀鲜吧卡粗介钻逐弱脚怕盐末阴丰编印蜂急拿扩伤飞露核缘游振操央伍域甚迅辉异序免纸夜乡久隶缸夹念兰映沟乙吗儒杀汽磷艰晶插埃燃欢铁补咱芽永瓦倾阵碳演威附牙芽永瓦斜灌欧献顺猪洋腐请透司危括脉宜笑若尾束壮暴企菜穗楚汉愈绿拖牛份染既秋遍锻玉夏疗尖殖井费州访吹荣铜沿替滚客召旱悟刺脑措贯藏敢令隙炉壳硫煤迎铸粘探临薄旬善福纵择礼愿伏残雷延烟句纯渐耕跑泽慢栽鲁赤繁境潮横掉锥希池败船假亮谓托伙哲怀割摆贡呈劲财仪沉炼麻罪祖息车穿货销齐鼠抽画饲龙库守筑房歌寒喜哥洗蚀废纳腹乎录镜妇恶脂庄擦险赞钟摇典柄辩竹谷卖乱虚桥奥伯赶垂途额壁网截野遗静谋弄挂课镇妄盛耐援扎虑键归符庆聚绕摩忙舞遇索顾胶羊湖钉仁音迹碎伸灯避泛亡答勇频皇柳哈揭甘诺概宪浓岛袭谁洪谢炮浇斑讯懂灵蛋闭孩释乳巨徒私银伊景坦累匀霉杜乐勒隔弯绩招绍胡呼痛峰零柴簧午跳居尚丁秦稍追梁折耗碱殊岗挖氏刃剧堆赫荷胸衡勤膜篇登驻案刊秧缓凸役剪川雪链渔啦脸户洛孢勃盟买杨宗焦赛旗滤硅炭股坐蒸凝竟陷枪黎救冒暗洞犯筒您宋弧爆谬涂味津臂障褐陆啊健尊豆拔莫抵桑坡缝警挑污冰柬嘴啥饭塑寄赵喊垫康遵牧遭幅园腔订香肉弟屋敏恢忘衣孙龄岭骗休借丹渡耳刨虎笔稀昆浪萨茶滴浅拥穴覆伦娘吨浸袖珠雌妈紫戏塔锤震岁貌洁剖牢锋疑霸闪埔猛诉刷狠忽灾闹乔唐漏闻沈熔氯荒茎男凡抢像浆旁玻亦忠唱蒙予纷捕锁尤乘乌智淡允叛畜俘摸锈扫毕璃宝芯爷鉴秘净蒋钙肩腾枯抛轨堂拌爸循诱祝励肯酒绳穷塘燥泡袋朗喂铝软渠颗惯贸粪综墙趋彼届墨碍启逆卸航雾冠丙街莱贝辐肠付吉渗瑞惊顿挤秒悬姆烂森糖圣凹陶词迟蚕亿矩";

$len = mb_strlen($ch_str,"utf-8");//汉字长度

$str = array();

for($i=0;$i<4;$i++){

   $pos = mt_rand(0,$len-5);//开始位置

   $str[] = mb_substr($ch_str,$pos,1,"utf-8");

}

$authnum_session = implode("",$str);

$_SESSION['authnum_session'] = $authnum_session;   //记录到session

Header("Content-type: image/PNG");

//图片的长和高

$image_x=100;

$image_y=50;

$im = imagecreate($image_x,$image_y);

//这里取图片底色为白色

$bkg = ImageColorAllocate($im,255,255,255);

//显示的字体样式,这个要把文件放到对应的目录中,如果你没有文件就去window的字体文件中找一个吧。

$fnt = "simhei.ttf";

//为图像分配一些颜色

$white=ImageColorAllocate($im,234,185,95);

//在图片上画椭圆弧,指定下坐标点

imagearc($im, 150, 8, 20, 20, 75, 170, $white);

imagearc($im, 180, 7,50, 30, 75, 175, $white);

//在图片上画一条线段,指定下坐标点

imageline($im,20,20,180,30,$white);

imageline($im,20,18,170,50,$white);

imageline($im,25,50,80,50,$white);

//乱点的数量

$noise_num=3000;

$line_num=50;

//各种混乱字符的颜色

$rectangle_color=imagecolorallocate($im,0xAA,0xAA,0xAA);

$noise_color=imagecolorallocate($im,0x00,0x00,0x00);

$font_color=imagecolorallocate($im,0x00,0x00,0x00);

for($i=0;$i<$noise_num;$i++)

{

    //在一个坐标点上画一个单一像素,这个点上面定义了,是黑色的。

    //imagesetpixel($im,mt_rand(0,$image_x),mt_rand(0,$image_y),$noise_color);

}

for($i=0;$i<$line_num;$i++)

{

    $line_color=imagecolorallocate($im,mt_rand(0,255),mt_rand(0,255),mt_rand(0,255));

    //在两个坐标点间画一条线,颜色在上面定义

    imageline($im,mt_rand(0,$image_x),mt_rand(0,$image_y),mt_rand(0,$image_x),mt_rand(0,$image_y),$line_color);    

}

for ($i=0;$i<4;$i++)

{

    ImageTTFText($im, rand(18,20), rand(0,20), rand(($image_x/4)*$i+$image_x/100,($image_x/4)*$i+$image_x/8), rand($image_y/2+$image_y/10,$image_y/2+$image_y/5), $font_color, $fnt, $str[$i]);
}

ImagePNG($im);

ImageDestroy($im);

?>

字体文件:simhei.rar点击此处本站下载。

注意:

中文汉字验证码单独执行,然后获取session会发现验证码和session内容不一致。但是在img 标签中src属性中引用这个中文汉字验证码文件时,然后获取session,这时两者内容时一致的。

感兴趣的朋友可以对此进一步加以完善。

PHP 相关文章推荐
一棵php的类树(支持无限分类)
Oct 09 PHP
消息持续发送的完整例子
Oct 09 PHP
PHP 采集程序中常用的函数
Dec 09 PHP
PHP中数组的三种排序方法分享
May 07 PHP
PHP+jquery实时显示网站在线人数的方法
Jan 04 PHP
PHP两种快速排序算法实例
Feb 15 PHP
PHP准确取得服务器IP地址的方法
Jun 02 PHP
PHP模拟asp.net的StringBuilder类实现方法
Aug 08 PHP
PHP socket 模拟POST 请求实例代码
Jul 18 PHP
yii的入口文件index.php中为什么会有这两句
Aug 04 PHP
PHP中number_format()函数的用法讲解
Apr 08 PHP
ThinkPHP类似AOP思想的参数验证的实现方法
Dec 18 PHP
PHP实现指定字段的多维数组排序函数分享
Mar 09 #PHP
PHP多线程之内部多线程实例分析
Mar 09 #PHP
php中删除数组的第一个元素和最后一个元素的函数
Mar 07 #PHP
php建立Ftp连接的方法
Mar 07 #PHP
Thinkphp调用Image类生成缩略图的方法
Mar 07 #PHP
PHP实现懒加载的方法
Mar 07 #PHP
php根据某字段对多维数组进行排序的方法
Mar 07 #PHP
You might like
Session的工作机制详解和安全性问题(PHP实例讲解)
2014/04/10 PHP
thinkPHP中配置的读取与C方法详解
2016/12/05 PHP
PHP使用zlib扩展实现GZIP压缩输出的方法详解
2018/04/09 PHP
(转载)JavaScript中匿名函数,函数直接量和闭包
2007/05/08 Javascript
javascript显示隐藏层比较不错的方法分析
2008/09/30 Javascript
JavaScript中yield实用简洁实现方式
2010/06/12 Javascript
javascript一个无懈可击的实例化XMLHttpRequest的方法
2010/10/13 Javascript
JS记录用户登录次数实现代码
2014/01/15 Javascript
javaScript 页面自动加载事件详解
2014/02/10 Javascript
jQuery实现宽屏图片轮播实例教程
2015/11/24 Javascript
JavaScript prototype属性详解
2016/10/25 Javascript
浅谈Angular2 ng-content 指令在组件中嵌入内容
2017/08/18 Javascript
AngularJS实现的获取焦点及失去焦点时的表单验证功能示例
2017/10/25 Javascript
用vue-cli开发vue时的代理设置方法
2018/09/20 Javascript
如何为你的JS项目添加智能提示与类型检查详解
2019/03/12 Javascript
vue.js中使用echarts实现数据动态刷新功能
2019/04/16 Javascript
[01:10]DOTA2次级职业联赛 - Fly战队宣传片
2014/12/01 DOTA
在Django中限制已登录用户的访问的方法
2015/07/23 Python
浅谈numpy中linspace的用法 (等差数列创建函数)
2017/06/07 Python
spyder常用快捷键(分享)
2017/07/19 Python
详解使用 pyenv 管理多个版本 python 环境
2017/10/19 Python
tensorflow创建变量以及根据名称查找变量
2018/03/10 Python
python中实现词云图的示例
2020/12/19 Python
is_file和file_exists效率比较
2021/03/14 PHP
html5应用缓存_动力节点Java学院整理
2017/07/13 HTML / CSS
几道PHP的面试题
2012/05/19 面试题
党员民主生活会对照检查材料思想汇报
2014/09/28 职场文书
廉政文化进校园广播稿
2014/10/20 职场文书
2014村书记党建工作汇报材料
2014/11/02 职场文书
安全生产先进个人总结
2015/02/15 职场文书
公司新员工欢迎词
2015/09/30 职场文书
初中数学教学反思范文
2016/02/17 职场文书
演讲稿之感恩老师(三篇范文)
2019/09/06 职场文书
浅谈移动端中的视口(viewport)的具体使用
2021/04/13 HTML / CSS
Oracle中日期的使用方法实例
2022/07/07 Oracle