• 使用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 "正确";
        }
    }

    转载请注明出处。

    支持我,请访问作者个人网站

  • 相关阅读:
    ssh 远程命令
    POJ 2287
    POJ 2376
    hihoCoder1488
    POJ1854
    HDU 5510
    HDU 4352
    CodeForces 55D
    HDU 1517
    CodeForces 1200F
  • 原文地址:https://www.cnblogs.com/dark-master/p/6375546.html
Copyright © 2020-2023  润新知