本文为大家分享了php图片验证码的实现代码,分享给大家供大家参考,具体内容如下
1.验证码图片生成
captcha.php
//1.生成100*30大小的图片,默认为黑色 $image = imagecreatetruecolor(100,30); //创建白色底图 $bgcolor = imagecolorallocate($image,255,255,255); //用白色填充黑色 imagefill ($image,0,0,$bgcolor); //2.随机显示数字或字母 $captch_code = ""; for($i=0;$i<4;$i++){ $fontsize=6; $fontcolor=imagecolorallocate($image,rand(0,120),rand(0,120),rand(0,120)); $data = "abcdefghijkmnpqrstuvwxy3456789"; $fontcontent =substr($data,rand(0,strlen($data)),1); $captch_code .=$fontcontent; $x = ($i*100/4)+rand(5,10); $y = rand(5,10); imagestring($image, $fontsize, $x, $y, $fontcontent,$fontcolor); } $_SESSION["authcode"] = $captch_code; //3.增加干扰 //干扰点 for($i=0;$i<100;$i++){ $pointcolor=imagecolorallocate($image,rand(50,200),rand(50,200),rand(50,200)); imagesetpixel($image,rand(1,99),rand(1,29),$pointcolor); } //干扰线 for($i=0;$i<2;$i++){ $linecolor=imagecolorallocate($image,rand(80,220),rand(80,220),rand(80,220)); imageline($image,rand(1,99),rand(1,29),rand(1,99),rand(1,29),$linecolor); } header("content-type:image/png"); imagepng($image);
2.页面实现验证码功能
form.php
<?php if(isset($_POST["authcode"])){ session_start(); if(strtolower($_POST["authcode"])==$_SESSION["authcode"]){ echo "OK"; }else{ echo "NO"; } } ?> <!doctype html> <html lang="en"> <head> <meta charset="UTF-8"> <title>Document</title> </head> <body> <form action="form.php" method="post"> <p>验证码图片: <img id="img" border="1" src="captcha.php?r=<?php echo rand()?>" alt=""> <a href="javascript:void(0)" onclick="document.getElementById('img').src='captcha.php?r'+Math.random() ">换一个</a> </p> <p><input type="text" name="authcode"></p> <p><input type="submit" value="提交"></p> </form> </body> </html>
以上就是本文的全部内容,帮助大家轻松实现php图片验证码。
本文向大家介绍Bootstrap每天必学之表单,包括了Bootstrap每天必学之表单的使用技巧和注意事项,需要的朋友参考一下 本文主要讲解的是表单,这个其实对于做过网站的人来说,并不陌生,而且可以说是最为常用的提交数据的Form表单。本文主要来讲解一下内容: 1.基本案例 2.内联表单 3.水平排列的表单 4.被支持的控件 5.静态控件 6.控件状态 7.控件尺寸 8.帮助文本 基本案例 单独
本文向大家介绍Bootstrap每天必学之折叠,包括了Bootstrap每天必学之折叠的使用技巧和注意事项,需要的朋友参考一下 本文主要来学习一下JavaScript插件--折叠。 1、过渡效果 关于过渡效果 对于简单的过渡效果,只需将transition.js和其它JS文件一起引入即可。如果你使用的是编译(或压缩)好的bootstrap.js文件,就无需再单独将其引入了。 What's insi
本文向大家介绍Bootstrap每天必学之按钮(一),包括了Bootstrap每天必学之按钮(一)的使用技巧和注意事项,需要的朋友参考一下 本文主要讲解的是按钮的样式。 1.选项 2.尺寸 3.活动状态 4.禁用状态 5.可做按钮使用的Html标签 选项 使用上面列出的class可以快速创建一个带有样式的按钮。 尺寸 需要让按钮具有不同尺寸吗?使用.btn-lg、.btn-sm、.btn-xs
本文向大家介绍Bootstrap每天必学之js插件,包括了Bootstrap每天必学之js插件的使用技巧和注意事项,需要的朋友参考一下 1、Bootstrap 插件概览 在前面 布局组件 章节中所讨论到的组件仅仅是个开始。Bootstrap 自带 12 种 jQuery 插件,扩展了功能,可以给站点添加更多的互动。即使您不是一名高级的 JavaScript 开发人员,您也可以着手学习 Bootst
本文向大家介绍Bootstrap每天必学之下拉菜单,包括了Bootstrap每天必学之下拉菜单的使用技巧和注意事项,需要的朋友参考一下 一、下拉菜单(基本用法) 小伙伴们注意,在Bootstrap框架中的下拉菜单组件是一个独立的组件,根据不同的版本,它对应的文件: ☑ LESS版本:对应的源码文件为 dropdowns.less ☑ Sass版本:对应的源码文件为 _dropdowns.sass
本文向大家介绍JavaScript每天必学之基础知识,包括了JavaScript每天必学之基础知识的使用技巧和注意事项,需要的朋友参考一下 基本概念 javascript是一门解释型的语言,浏览器充当解释器。js执行时,在同一个作用域内是先解释再执行。解释的时候会编译function和var这两个关键词定义的变量,编译完成后从上往下执行并向变量赋值。 区分大小写 ECMASCript中的一切