首頁 > 後端開發 > php教程 > 关于验证码坐标的取值解决办法

关于验证码坐标的取值解决办法

WBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWB
發布: 2016-06-13 13:37:08
原創
1127 人瀏覽過

关于验证码坐标的取值
-----------------------------------------------code-----------------------------------------------------
$image_width=70; //设置图像宽度
$image_height=18; //设置图像高度

$new_number=1234;
$num_image=imagecreate($image_width,$image_height); //创建一个画布
imagecolorallocate($num_image,255,255,255); //设置画布的颜色

for($i=0;$i   $font=mt_rand(3,5); //设置随机的字体
  $x=mt_rand(1,8)+$image_width*$i/4; //设置随机字符所在位置的X坐标
  $y=mt_rand(1,$image_height/4); //设置随机字符所在位置的Y坐标
  $color=imagecolorallocate($num_image,mt_rand(0,100),mt_rand(0,150),mt_rand(0,200)); //设置字符的颜色
  imagestring($num_image,$font,$x,$y,$new_number[$i],$color); //水平输出字符
}

imagepng($num_image); //生成PNG格式的图像
imagedestroy($num_image); //释放图像资源
----------------------------------------------code------------------------

 $x=mt_rand(1,8)+$image_width*$i/4; //设置随机字符所在位置的X坐标
 $y=mt_rand(1,$image_height/4); //设置随机字符所在位置的Y坐标

$x,$y 为什么是这么取值的?是随便取的 还是有规律的?有规律的就请解释下




------解决方案--------------------
这个位置可以随便取
但理论上我们认为验证码的字符不能超过边线,不然就会无法识别
一般情况下验证码出现的位置应该是随机的,而且是在不超过边线的前提下随机范围最大化
这样可以减小被机器脚本破解的几率

相關標籤:
來源:php.cn
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
最新問題
android - image 設定border-radius
來自於 1970-01-01 08:00:00
0
0
0
thinkphp中Controller裡面使用Request::File('image');
來自於 1970-01-01 08:00:00
0
0
0
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板