高分急求:验证码图片中如何实现扭曲、变形、错位等干扰方案。 google一下,有人写了个雪花干扰的图案,看看你用得上吧? 解决方案 » 免费领取超大流量手机卡,每月29元包185G流量+100分钟通话, 中国电信官方发货 效果:http://mail.htjs.net/yanzhengma/test.php<? session_start();?> <FORM METHOD=POST ACTION=""> <input type=text name=number maxlength=4><img src="YanZhengMa.php?act=init"> <INPUT TYPE="submit" name="sub"> </FORM> <? //检验校验码 if(isset($HTTP_POST_VARS["sub"])): if($HTTP_POST_VARS["number"] != $HTTP_SESSION_VARS[login_check_number] || empty($HTTP_POST_VARS["number"])){ echo "校验码不正确!" ; }else{ echo"验证码通过!"; } endif; show_source('test.php'); //以上本页的源码 //以下是生成验证码的源码 show_source('YanZhengMa.php'); ?> <?php session_start(); session_register("login_check_number"); //昨晚看到了chianren上的验证码效果,就考虑了一下,用PHP的GD库完成了类似功能 //先成生背景,再把生成的验证码放上去 $img_height=120; //先定义图片的长、宽 $img_width=40; if($HTTP_GET_VARS["act"]== "init"){ //srand(microtime() * 100000);//PHP420后,srand不是必须的 for($Tmpa=0;$Tmpa<4;$Tmpa++){ $nmsg.=dechex(rand(0,15)); }//by sports98 $HTTP_SESSION_VARS[login_check_number] = $nmsg; //$HTTP_SESSION_VARS[login_check_number] = strval(mt_rand("1111","9999")); //生成4位的随机数,放入session中 //谁能做下补充,可以同时生成字母和数字啊??----由sports98完成了 $aimg = imageCreate($img_height,$img_width); //生成图片 ImageColorAllocate($aimg, 255,255,255); //图片底色,ImageColorAllocate第1次定义颜色PHP就认为是底色了 $black = ImageColorAllocate($aimg, 0,0,0); //定义需要的黑色 ImageRectangle($aimg,0,0,$img_height-1,$img_width-1,$black);//先成一黑色的矩形把图片包围 //下面该生成雪花背景了,其实就是在图片上生成一些符号 for ($i=1; $i<=100; $i++) { //先用100个做测试 imageString($aimg,1,mt_rand(1,$img_height),mt_rand(1,$img_width),"*",imageColorAllocate($aimg,mt_rand(200,255),mt_rand(200,255),mt_rand(200,255))); //哈,看到了吧,其实也不是雪花,就是生成*号而已。为了使它们看起来"杂乱无章、5颜6色",就得在1个1个生成它们的时候,让它们的位置、颜色,甚至大小都用随机数,rand()或mt_rand都可以完成。 } //上面生成了背景,现在就该把已经生成的随机数放上来了。道理和上面差不多,随机数1个1个地放,同时让他们的位置、大小、颜色都用成随机数~~ //为了区别于背景,这里的颜色不超过200,上面的不小于200 for ($i=0;$i<strlen($HTTP_SESSION_VARS[login_check_number]);$i++){ imageString($aimg, mt_rand(3,5),$i*$img_height/4+mt_rand(1,10),mt_rand(1,$img_width/2), $HTTP_SESSION_VARS[login_check_number][$i],imageColorAllocate($aimg,mt_rand(0,100),mt_rand(0,150),mt_rand(0,200))); } Header("Content-type: image/png"); //告诉浏览器,下面的数据是图片,而不要按文字显示 ImagePng($aimg); //生成png格式嘿嘿效果蛮像回事的嘛 ImageDestroy($aimg); } ?> 我的也是在google上搜的,不知道还有没有更好的关注 谢谢楼上的,这个我已经实现了,不知道有没有谁会作扭曲、变形的干扰,就像yahoo上的那个一样。 暂时还没有看到用PHP做的扭曲、变形的干扰,一般改变位置也就差不多了。 我用gdImageResized对区域进行放大,可是效果很差,图案变形的太厉害了。我现在只有自己编几套变形的字体了。 看看hotmail的验证码,简直有些变态了瞪着大眼你就敲不对的 哈哈,我觉得看来我的还是小儿科,不算太变态。刚做出来的。哪位能用OCR软件帮忙测试下能否识别这些的图片。http://bbs.chinaunix.net/forum/uploadfile/a7dg3sfjm9.jpghttp://bbs.chinaunix.net/forum/uploadfile/a7dg3sfjm9_2.jpghttp://bbs.chinaunix.net/forum/uploadfile/a7dg3sfjm9_3.jpghttp://bbs.chinaunix.net/forum/uploadfile/t7b5rq4dwx.jpghttp://bbs.chinaunix.net/forum/uploadfile/t7b5rq4dwx_2.jpghttp://bbs.chinaunix.net/forum/uploadfile/t7b5rq4dwx_3.jpg lanxk(蓝) 说的是啊,呵呵,现在好多验证码我怎么认也认不出来,只能再刷新到我能认出来的为止,呵呵 对PHP5的反射有了解的请指点迷津 [求助]怎样在网页中把tif 图象显示出来啊 关于行的输出 急刹我也! 再问php邮件发送验证问题 有些晕。。。 关于array_diff函数的问题 下单优化问题 Windows+Apache+PHP+MySQL的学习思路是什么?有好的框架吗? PHP运行空白,输出有错误 找遍了资料,也没有找到答案,求救中。。。。。 如何用javascript改变输入框的属性???
<? session_start();?>
<FORM METHOD=POST ACTION="">
<input type=text name=number maxlength=4><img src="YanZhengMa.php?act=init">
<INPUT TYPE="submit" name="sub">
</FORM>
<?
//检验校验码
if(isset($HTTP_POST_VARS["sub"])):
if($HTTP_POST_VARS["number"] != $HTTP_SESSION_VARS[login_check_number] || empty($HTTP_POST_VARS["number"])){
echo "校验码不正确!" ;
}else{
echo"验证码通过!";
}
endif;
show_source('test.php');
//以上本页的源码
//以下是生成验证码的源码
show_source('YanZhengMa.php');
?>
<?php
session_start();
session_register("login_check_number");
//昨晚看到了chianren上的验证码效果,就考虑了一下,用PHP的GD库完成了类似功能
//先成生背景,再把生成的验证码放上去
$img_height=120; //先定义图片的长、宽
$img_width=40;
if($HTTP_GET_VARS["act"]== "init"){
//srand(microtime() * 100000);//PHP420后,srand不是必须的
for($Tmpa=0;$Tmpa<4;$Tmpa++){
$nmsg.=dechex(rand(0,15));
}//by sports98
$HTTP_SESSION_VARS[login_check_number] = $nmsg; //$HTTP_SESSION_VARS[login_check_number] = strval(mt_rand("1111","9999")); //生成4位的随机数,放入session中
//谁能做下补充,可以同时生成字母和数字啊??----由sports98完成了 $aimg = imageCreate($img_height,$img_width); //生成图片
ImageColorAllocate($aimg, 255,255,255); //图片底色,ImageColorAllocate第1次定义颜色PHP就认为是底色了
$black = ImageColorAllocate($aimg, 0,0,0); //定义需要的黑色
ImageRectangle($aimg,0,0,$img_height-1,$img_width-1,$black);//先成一黑色的矩形把图片包围 //下面该生成雪花背景了,其实就是在图片上生成一些符号
for ($i=1; $i<=100; $i++) { //先用100个做测试
imageString($aimg,1,mt_rand(1,$img_height),mt_rand(1,$img_width),"*",imageColorAllocate($aimg,mt_rand(200,255),mt_rand(200,255),mt_rand(200,255)));
//哈,看到了吧,其实也不是雪花,就是生成*号而已。为了使它们看起来"杂乱无章、5颜6色",就得在1个1个生成它们的时候,让它们的位置、颜色,甚至大小都用随机数,rand()或mt_rand都可以完成。
} //上面生成了背景,现在就该把已经生成的随机数放上来了。道理和上面差不多,随机数1个1个地放,同时让他们的位置、大小、颜色都用成随机数~~
//为了区别于背景,这里的颜色不超过200,上面的不小于200
for ($i=0;$i<strlen($HTTP_SESSION_VARS[login_check_number]);$i++){
imageString($aimg, mt_rand(3,5),$i*$img_height/4+mt_rand(1,10),mt_rand(1,$img_width/2), $HTTP_SESSION_VARS[login_check_number][$i],imageColorAllocate($aimg,mt_rand(0,100),mt_rand(0,150),mt_rand(0,200)));
}
Header("Content-type: image/png"); //告诉浏览器,下面的数据是图片,而不要按文字显示
ImagePng($aimg); //生成png格式嘿嘿效果蛮像回事的嘛
ImageDestroy($aimg);
} ?>
关注
不知道有没有谁会作扭曲、变形的干扰,就像yahoo上的那个一样。
我现在只有自己编几套变形的字体了。
瞪着大眼你就敲不对的
刚做出来的。
哪位能用OCR软件帮忙测试下能否识别这些的图片。
http://bbs.chinaunix.net/forum/uploadfile/a7dg3sfjm9.jpg
http://bbs.chinaunix.net/forum/uploadfile/a7dg3sfjm9_2.jpg
http://bbs.chinaunix.net/forum/uploadfile/a7dg3sfjm9_3.jpg
http://bbs.chinaunix.net/forum/uploadfile/t7b5rq4dwx.jpg
http://bbs.chinaunix.net/forum/uploadfile/t7b5rq4dwx_2.jpg
http://bbs.chinaunix.net/forum/uploadfile/t7b5rq4dwx_3.jpg