zoukankan      html  css  js  c++  java
  • php 图形验证码

    1、首先来一个html页面 index.html

    <!DOCTYPE html>
    <html>
    <head>
        <meta charset="UTF-8">
        <title>注册</title>
    </head>
    <body>
        <form action="./register.php" method="post">
            <img src="Verify.php"  onclick="this.src='Verify.php?'+new Date().getTime();" width="100" height="100"><br/>
            <input type="text" name="verify" placeholder="请输入图片中的验证码"><br/>
            <input type="submit" value="验证">
        </form>
    </body>
    </html>

    2、验证码 register.php

    <?php
    /**
     * 字母+数字的验证码生成
     */
    // 开启session
    session_start();
    //1.创建黑色画布
    $image = imagecreatetruecolor(100, 30);
     
    //2.为画布定义(背景)颜色
    $bgcolor = imagecolorallocate($image, 255, 255, 255);
     
    //3.填充颜色
    imagefill($image, 0, 0, $bgcolor);
     
    // 4.设置验证码内容
     
    //4.1 定义验证码的内容
    $content = "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789";
     
    //4.1 创建一个变量存储产生的验证码数据,便于用户提交核对
    $captcha = "";
    for ($i = 0; $i < 4; $i++) {
        // 字体大小
        $fontsize = 10;
        // 字体颜色
        $fontcolor = imagecolorallocate($image, mt_rand(0, 120), mt_rand(0, 120), mt_rand(0, 120));
        // 设置字体内容
        $fontcontent = substr($content, mt_rand(0, strlen($content)), 1);
        $captcha .= $fontcontent;
        // 显示的坐标
        $x = ($i * 100 / 4) + mt_rand(5, 10);
        $y = mt_rand(5, 10);
        // 填充内容到画布中
        imagestring($image, $fontsize, $x, $y, $fontcontent, $fontcolor);
    }
    $_SESSION["verifyimg"] = $captcha;
     
    //4.3 设置背景干扰元素
    for ($$i = 0; $i < 200; $i++) {
        $pointcolor = imagecolorallocate($image, mt_rand(50, 200), mt_rand(50, 200), mt_rand(50, 200));
        imagesetpixel($image, mt_rand(1, 99), mt_rand(1, 29), $pointcolor);
    }
     
    //4.4 设置干扰线
    for ($i = 0; $i < 3; $i++) {
        $linecolor = imagecolorallocate($image, mt_rand(50, 200), mt_rand(50, 200), mt_rand(50, 200));
        imageline($image, mt_rand(1, 99), mt_rand(1, 29), mt_rand(1, 99), mt_rand(1, 29), $linecolor);
    }
     
    //5.向浏览器输出图片头信息
    header('content-type:image/png');
     
    //6.输出图片到浏览器
    imagepng($image);
     
    //7.销毁图片
    imagedestroy($image);  
    ?>

    3、提交验证验证码页面register.php

    <?php
    /**
     * 接受用户登陆时提交的验证码
     */
    session_start();
    //1. 获取到用户提交的验证码
    $verify = $_POST["verify"];
    //2. 将session中的验证码和用户提交的验证码进行核对,当成功时提示验证码正确,并销毁之前的session值,不成功则重新提交
    if(strtolower($_SESSION["verifyimg"]) == strtolower($verify)){
        echo "ok";
        $_SESSION["verify"] = "";
    }else{
        echo "error";
    }
    ?>

    4、如果不需要干扰线或者背景干扰元素,直接把里面的内容注释就好了,效果就这样的

    最后来一个小问题,我再win系统上可以显示,传到服务器,图片不显示,可以超看一下是否开启了GD库,怎么操作,先自行百度,我有空再写。

  • 相关阅读:
    【leetcode-100】 简单 树相关题目
    【leetcode-101】 对称二叉树
    【2】【leetcode-105,106】 从前序与中序遍历序列构造二叉树,从中序与后序遍历序列构造二叉树
    【leetcode-102,107,103】 二叉树的层次遍历
    iOS开发
    对称加密和不对称加密原理
    uiimageview 异步加载图片
    如何让IOS中的文本实现3D效果
    SDWebImage使用,图片加载和缓存
    ios 图片处理( 1.按比例缩放 2.指定宽度按比例缩放
  • 原文地址:https://www.cnblogs.com/xbxxf/p/8926855.html
Copyright © 2011-2022 走看看