zoukankan      html  css  js  c++  java
  • php随机获取验证码

    <?php
    $yzm = "";
        for($i=0;$i<5;$i++)
        {
        $a = rand(0,9); //0-9随机数
        $yzm.= $a;
        }
    echo join(array_map(function($n){return mt_rand(0, 9);},array_pad(array(),5,0)));//第一种
    //echo $yzm;第二种
    
    ?>
    

    这样就可以获取验证码了,每次刷新验证码都是不同的。 

    下面这个是带有背景图的

    <?php
       //随机生成一个4位数的数字验证码
        $num="";
        for($i=0;$i<4;$i++){
        $num .= rand(0,9);
        }
       //4位验证码也可以用rand(1000,9999)直接生成
       //将生成的验证码写入session,备验证页面使用
        session_start();
        $_SESSION["Checknum"] = $num;
       //创建图片,定义颜色值
        header("Content-type: image/PNG");
        srand((double)microtime()*1000000);
        $im = imagecreate(60,20);
        $black = ImageColorAllocate($im, 0,0,0);
        $gray = ImageColorAllocate($im, 200,200,200);
        imagefill($im,0,0,$gray);
    
        //随机绘制两条虚线,起干扰作用
        $style = array($black, $black, $black, $black, $black, $gray, $gray, $gray, $gray, $gray);
        imagesetstyle($im, $style);
        $y1=rand(0,20);
        $y2=rand(0,20);
        $y3=rand(0,20);
        $y4=rand(0,20);
        imageline($im, 0, $y1, 60, $y3, IMG_COLOR_STYLED);
        imageline($im, 0, $y2, 60, $y4, IMG_COLOR_STYLED);
    
        //在画布上随机生成大量黑点,起干扰作用;
        for($i=0;$i<80;$i++)
        {
       imagesetpixel($im, rand(0,60), rand(0,20), $black);
        }
        //将四个数字随机显示在画布上,字符的水平间距和位置都按一定波动范围随机生成
        $strx=rand(3,8);
        for($i=0;$i<4;$i++){
        $strpos=rand(1,6);
        imagestring($im,5,$strx,$strpos, substr($num,$i,1), $black);
        $strx+=rand(8,12);
        }
        ImagePNG($im);
        ImageDestroy($im);
       ?>
    

      

    使用方法:

    本程序可以直接运行,运行之后即可看到一个图形验证码,每次刷新都随机生成新码。

     在某页面中使用此程序时,可以用以下代码:

    代码如下:
    .....
     请输入验证码:
    <input type=text name=passcode>
    <img src=showimg.php>
    .....
    

     这样即可显示出验证码图片。到了验证页面,用以下代码:

    代码如下:
    ...
    $code=$_POST["passcode"];
    if( $code == $_SESSION["Checknum"]){
    验证通过
    }else{
    验证码错误
    }
    ...
    

      

     

  • 相关阅读:
    题解报告:hdu 2062 Subset sequence
    CSS3滑块菜单
    CSS3环形动画菜单
    可折叠显示的发光搜索表单
    Tab动画菜单
    侧边自定义滚动条
    css3条纹边框效果
    css3图片过滤效果
    CSS3图片悬停放大动画
    CSS3响应式侧边菜单
  • 原文地址:https://www.cnblogs.com/douchenchen/p/6902901.html
Copyright © 2011-2022 走看看