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 相关文章推荐
初学者入门:细述PHP4的核心Zend
Sep 05 PHP
php列出一个目录下的所有文件的代码
Oct 09 PHP
关于file_get_contents返回为空或函数不可用的解决方案
Jun 24 PHP
PHP递归删除目录几个代码实例
Apr 21 PHP
几个实用的PHP内置函数使用指南
Nov 27 PHP
用php代码限制国内IP访问我们网站
Sep 26 PHP
php实现Session存储到Redis
Nov 11 PHP
php session 写入数据库
Feb 13 PHP
php使用number_format函数截取小数的方法分析
May 27 PHP
PHP使用PHPExcel删除Excel单元格指定列的方法
Jul 06 PHP
Laravel解决nesting level错误和隐藏index.php的问题
Oct 12 PHP
Laravel框架Eloquent ORM修改数据操作示例
Dec 03 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
php在线生成ico文件的代码
2007/10/09 PHP
php 远程图片保存到本地的函数类
2008/12/08 PHP
CI框架自动加载session出现报错的解决办法
2014/06/17 PHP
laravel 5.5 关闭token的3种实现方式
2019/10/24 PHP
一个不错的用JavaScript实现的UBB编码函数
2007/03/09 Javascript
[原创]用javascript实现检测指定目录是否存在的方法
2008/01/12 Javascript
动态创建的表格单元格中的事件实现代码
2008/12/30 Javascript
用jQuery打造TabPanel效果代码
2010/05/22 Javascript
JavaScript中的console.log()函数详细介绍
2014/12/29 Javascript
jquery实现左右滑动菜单效果代码
2015/08/27 Javascript
JS/jQuery判断DOM节点是否存在的简单方法
2016/11/24 Javascript
jQuery插件echarts实现的去掉X轴、Y轴和网格线效果示例【附demo源码下载】
2017/03/04 Javascript
js移动端事件基础及常用事件库详解
2017/08/15 Javascript
微信小程序获取手机系统信息的方法【附源码下载】
2017/12/07 Javascript
jQuery length 和 size()区别总结
2018/04/26 jQuery
详解vue路由篇(动态路由、路由嵌套)
2019/01/27 Javascript
浅析vue插槽和作用域插槽的理解
2019/04/22 Javascript
axios实现简单文件上传功能
2019/09/25 Javascript
JS面向对象编程——ES6 中class的继承用法详解
2020/03/03 Javascript
vue路由分文件拆分管理详解
2020/08/13 Javascript
详解Typescript里的This的使用方法
2021/01/08 Javascript
[56:13]DOTA2-DPC中国联赛定级赛 LBZS vs Phoenix BO3第一场 1月10日
2021/03/11 DOTA
跟老齐学Python之字典,你还记得吗?
2014/09/20 Python
Python中判断输入是否为数字的实现代码
2018/05/26 Python
pyspark 读取csv文件创建DataFrame的两种方法
2018/06/07 Python
PyCharm设置SSH远程调试的方法
2018/07/17 Python
Python图像处理库PIL的ImageDraw模块介绍详解
2020/02/26 Python
CSS3 实用技巧:实现黑白图像效果示例代码
2013/07/11 HTML / CSS
使用css3制作登录表单的步骤
2014/04/07 HTML / CSS
拥有超过850家商店的美国在线派对商店:Party City
2018/10/21 全球购物
水产养殖学应届生求职信
2013/09/29 职场文书
临时用工协议书范本
2014/10/29 职场文书
六一活动主持词
2015/06/30 职场文书
Python中requests做接口测试的方法
2021/05/30 Python
Python游戏开发实例之graphics实现AI五子棋
2021/11/01 Python
python​格式化字符串
2022/04/20 Python