这里有新鲜出炉的 PHP 面向对象编程,程序狗速度看过来!
PHP(外文名: Hypertext Preprocessor,中文名:"超文本预处理器")是一种通用开源脚本语言。语法吸收了 C 语言、Java 和 Perl 的特点,入门门槛较低,易于学习,使用广泛,主要适用于 web 开发领域。PHP 的文件后缀名为 php。
本文主要介绍了使用 php 实现网站验证码功能的方法。具有很好的参考价值,下面跟着小编一起来看下吧
验证码是网站常用的一项安全措施,也是新人站长较难掌握的一项技能,这里我向大家介绍一简单有效的验证码实现方法。
开始之前
在正式开始之前我们需要打开 php 的 gd2 图形库支持(在 php.ini, 中搜索 "php_gd2.dll",找到 ";extension=php_gd2.dll" 并去掉句首的分号) 。
可以参考:如何打开 php 的 gd2 库
核心:img.php
这个页面生成一张验证码并将正确数值写入 Session
随机一个 4 位验证码
- $check=rand(1000,9999);
将生成的验证码写入 session
- Session_start();
- $_SESSION["check"] = $check;
创建一张图片
- $im = imagecreate(80,30);
由于这种图片的背景默认是黑色的所以我们要用白色填充。
- imagefill($im,0,0,ImageColorAllocate($im, 255,255,255));
使用 imageline 随机绘制两条实线
- $y1 = rand(0, 30);
- $y2 = rand(0, 30);
- $y3 = rand(0, 30);
- $y4 = rand(0, 30);
- imageline($im, 0, $y1, 70, $y3, 000);
- imageline($im, 0, $y2, 70, $y4, 000);
在随机位置绘制文字
- $strx = rand(3, 15);
- $stry = rand(2, 15);
- imagestring($img, 5, $strx, $stry, substr($check, 0, 1), ImageColorAllocate($img, 34, 87, 100));
- $strx += rand(15, 20);
- $stry = rand(2, 15);
- imagestring($img, 5, $strx, $stry, substr($check, 1, 1), ImageColorAllocate($img, 781, 117, 78));
- $strx += rand(15, 20);
- $stry = rand(2, 15);
- imagestring($img, 5, $strx, $stry, substr($check, 2, 1), ImageColorAllocate($img, 160, 40, 40));
- $strx += rand(15, 20);
- $stry = rand(2, 15);
- imagestring($img, 5, $strx, $stry, substr($check, 3, 1), ImageColorAllocate($img, 25, 55, 10));
输出图像
- Header("Content-type: image/PNG");
- ImagePNG($img);
结束,下面是完整代码
- <?php $check=rand(1000,9999);
- Session_start();
- $_SESSION["check"] = $check;
- $img = imagecreate(80,30);
- imagefill($img,0,0,ImageColorAllocate($img,255,255,255));
- $y1=rand(0,30);
- $y2=rand(0,30);
- $y3=rand(0,30);
- $y4=rand(0,30);
- imageline($img,0,$y1,70, $y3,ImageColorAllocate($img,55,255,25));
- imageline($img,0,$y2,70, $y4,ImageColorAllocate($img,55,55,255));
- $strx=rand(3,15);
- $stry=rand(2,15);
- imagestring($img,5,$strx,$stry,substr($check,0,1),ImageColorAllocate($img,34,87,100));
- $strx+=rand(15,20);
- $stry=rand(2,15);
- imagestring($img,5,$strx,$stry,substr($check,1,1),ImageColorAllocate($img,781,117,78));
- $strx+=rand(15,20);
- $stry=rand(2,15);
- imagestring($img,5,$strx,$stry,substr($check,2,1),ImageColorAllocate($img,160,40,40));
- $strx+=rand(15,20);
- $stry=rand(2,15);
- imagestring($img,5,$strx,$stry,substr($check,3,1),ImageColorAllocate($img,25,55,10));
- Header("Content-type: image/PNG");
- ImagePNG($img);
用户界面:index.php
想必大家都知道怎么做,我就直接给出代码了
- <!DOCTYPE html>
- <html>
- <body>
- <form action="action.php" method="post">
- <input type="text" name="cikle" placeholder="验证码">
- <br>
- <img id="cikle" style="-webkit-user-select: none" src="img.php"><input type="submit" value="Submit">
- </form>
- </body>
- </html>
以上的代码将用户输入的数值传递到 "action.php" 中
检查:action.php
这一步要将用户输入数值与 session 中的数值进行比对
相等,输出 "正确"
不相等,输出 "不正确"
- <?php
- Session_start();
- if ($_SERVER["REQUEST_METHOD"] == "POST") {
- if($_SESSION["check"]!=intval($_POST["cikle"])){
- echo "不正确";
- }else{
- echo "正确";
- }
- }
以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,同时也希望多多支持 PHPERZ!
来源: http://www.phperz.com/article/17/0807/340578.html