您好,登录后才能下订单哦!
PHP 图像处理与SESSION制作?针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。
验证码的实现
首先我们要清楚,无论是做什么东西,在做之前一定要有思路,譬如这个验证码里他有些什么,为了实现它我们该做些什么,怎么样去做。
这里我例举出几个点。
1.验证码肯定要有内容。
2.验证码里肯定要有干扰信息,就譬如,线条干扰和点点干扰。
那么为了实现他们我们该如何做呢?
第一步,创建一个名为captcha.php的文件
在里面输入
<?php session_start();//开启会话 header("Content-type:image/png");//定义为图片 $im = imagecreatetruecolor(100,30);//创建一个画布的大小 $color = imagecolorallocate($im, 255, 255, 255);//填充背景颜色 imagefill($im,0,0,$color);//填充$color颜色于$im画板区域从左上角0,0开始 $content = "abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ1234567890";//验证码内容 $fontsize = "6";//字体大小 $ragcha = "";//声明一个空变量,接受验证码内容并保存
这个时候,验证码的一些基本东西我们都完成了,定义了验证码的宽高,背景色验证码内容,验证码字体大小,和一个接受验证码的变量,就该做第二步了。
第二步,获取验证码内容
for ($i=0; $i < 4; $i++) { //截取字符串 $char = substr($content,rand(0,strlen($content)-1),1); //把得到的内容输入到ragcha里 $ragcha = $ragcha.$char; //设置x轴与y轴的坐标 $x = $i*(100/4) + rand(5,15); $y = rand(5,10); //设置验证码内容颜色 $fontcolor = imagecolorallocate($im,rand(0,120),rand(0,120),rand(0,120)); //输出 imagestring($im, $fontsize, $x, $y, $char, $fontcolor); } //保证验证码内容不丢失 $_SESSION["ragcha"] = $ragcha;
在这里我们设置了$i的变量不能大于四,然后用他乘以(100/4),保证他的的值不会大过100,再加上rand函数里随机抽取5-15里的数值,使其的x轴坐标范围保证在(5-90)之间,y轴的坐标保证在(5-10)之间,使其大概率的保证了内容显示的范围居中
第三步,设置干扰因素
我们要明白,在验证码里有什么干扰因素,再想办法把它呈现出来。如下
//设置干扰因素 //1.画线条 for ($g=0; $g < 3; $g++) { //设置线条颜色 $line = imagecolorallocate($im, rand(50,100), rand(50,100), rand(50,100)); //输出线条 imageline($im,rand(0,99),rand(0,19),rand(0,99),rand(0,19), $line); } //2.给背景加点点 for ($r=0; $r < 300; $r++) { //设置点点颜色 $point = imagecolorallocate($im, rand(20,180), rand(20,180), rand(20,180)); //输出点点 imagesetpixel($im, rand(0,100), rand(0,30), $point); } imagepng($im);//输出整个图片
关于PHP 图像处理与SESSION制作问题的解答就分享到这里了,希望以上内容可以对大家有一定的帮助,如果你还有很多疑惑没有解开,可以关注亿速云行业资讯频道了解更多相关知识。
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。