本篇内容主要讲解“PHP怎么生成各种验证码和Ajax验证”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“PHP怎么生成各种验证码和Ajax验证”吧!
PHP生成验证码图片
PHP生成验证码的原理:使用PHP的GD库,生成一张带验证码的图片,并将验证码保存在会话中。PHP生成验证码的大致流程有:
1,产生一张png的图片;
2,为图片设置背景色;
3,设置字体颜色和样式;
4,产生4位数的随机的验证码;
5,把产生的每个字符调整旋转角度和位置画到png图片上;
6,加入噪点和干扰线防止注册机器分析原图片来恶意破解验证码;
7、输出图片;
8日释放图片所占内存。
应某位同学的要求,下面我们以xuebuyuan.com的文章评论所用的验证码为例,讲解验证码的生成过程,直接上代码。
<=癙HP代码类> session_start (); getCode(4, 60岁,20); 函数getCode (num, w美元,美元h) { 代码=懊涝? ($ i=0;美元我& lt;num美元;$我+ +){ 代码。美元=兰德(0,9); }//4位验证码也可以用兰德(1000、9999)直接生成//将生成的验证码写入会话,备验证时用 $ _SESSION (“helloweba_num")=$代码;//创建图片,定义颜色值 头(“内容类型:图像/PNG"); $我=imagecreate (w h美元); (黑=imagecolorallocate美元im, 0, 0, 0); (灰色=imagecolorallocate美元即时通讯,200,200,200); 我们美元=imagecolorallocate (im美元,255、255、255);//填充背景 美元imagefill (im, 0, 0,灰色);//画边框 imagerectangle (im, 0, 0, w1美元,美元的h,黑色美元);//随机绘制两条虚线,起干扰作用 风格美元=数组(黑色,黑色的美元,美元黑色,黑色的美元,美元的黑色, 灰色的,灰色的,美元美元灰色,灰色,灰色的美元 ); imagesetstyle (im,风格美元); 美元日元=兰德(0 h美元); 美元y2=兰德(0 h美元); 美元日元=兰德(0 h美元); 美元y4=兰德(0 h美元); imageline (im美元0美元日元w美元,美元y3, IMG_COLOR_STYLED); imageline (im美元0美元y2, w美元,日元美元,IMG_COLOR_STYLED);//在画布上随机生成大量黑点,起干扰作用; ($ i=0;美元我& lt;80;$我+ +){ imagesetpixel (im,兰德(0 w美元),兰德(0,h)美元,美元黑); }//将数字随机显示在画布上,字符的水平间距和位置都按一定波动范围随机生成 $ strx=兰德(3 8); ($ i=0;美元我& lt;num美元;$我+ +){ 美元=兰德大小写敏感(1,6); imagestring (im美元5 strx美元,美元大小写敏感,substr(代码,我美元,1),黑色美元); 12美元strx +=兰特(8日); } imagepng (im)美元;//输出图片 imagedestroy (im)美元;//释放图片所占内存 }代码>
代码中,自定义函数getCode()诠释了验证码的生成过程。运用PHP GD库自带的图像处理函数,能轻松生成各种想要的图片效果。
<强> imagecreate() 强>:创建一个新图像
<强> imagecolorallocate() 强>:为图像分配颜色
<强> imagefill() 强>:填充图像
<强> imagerectangle() 强>:画一个矩形(边框)
<强> imagesetstyle() 强>:设置画线风格
<强> imageline() 强>:画一条线段
<强> imagesetpixel() 强>:画点像素
<强> imagepng() 强>:以PNG格式将图像输出到浏览器或文件
<强> imagedestroy() 强>:释放图片所占内存
将上述代码保存为code_num.php,以便调用。
Ajax刷新和验证
验证码生成后,我们要在实际的项目中应用,通常我们使用Ajax可以实现点击验证码时刷新生成新的验证码(有时生成的验证码肉眼很难识别),即“看不清换一张”。填写验证码后,还需要验证所填验证码是否正确,验证的过程是要后台程序来完成,但是我们也可以通过Ajax来实现无刷新验证。
我们建立一个前端页面指数。html,载入jquery,同时在身体中加入验证码表单元素:
<代码类=癶tml”> & lt; p>验证码:& lt;输入类型=皌ext"类=癷nput"id=癱ode_num"name=癱ode_num"最大长度=?”;/比; & lt; img src=https://www.yisu.com/zixun/code_num.php " id=" getcode_num " title=翱床磺?点击换一张”=癮bsmiddle”>
对齐代码>
html代码中,& lt; img src=https://www.yisu.com/zixun/癱ode_num.php”即调用了生成的验证码,当点击验证码时,刷新生成新的验证码:
<代码类=" js "> $(函数(){//数字验证 $ (“# getcode_num") .click(函数(){ (美元).attr (“src" & # 39; code_num.php ? & # 39;+ math . random ()); }); … });