您的当前位置:首页>全部文章>文章详情

【PHP】php滑动验证码的实现原理

CrazyPanda发表于:2023-12-28 22:51:53浏览:322次TAG:

随着互联网的迅速发展,验证码成为了互联网安全保障的重要手段。其中,滑动验证码由于其简单易懂、操作方便、安全性高等特点,在实际应用中已经得到了广泛的应用。本文将介绍php滑动验证码的实现原理。

一、滑动验证码的定义与应用

滑动验证码是一种人机交互的验证码形式,它的基本原理是在界面上展示一张包含某些图片或图形的滑块,用户需要按住滑块进行拖动,直到把滑块拼接到验证码图形相应位置,以此进行验证。该类型的验证码多用于广告、登录、注册和评论等需要用户身份识别的场景。

二、php滑动验证码的实现原理

php滑动验证码的实现主要分为两个部分:前端展示与后端验证。其中前端展示主要通过HTML、CSS、JavaScript等前端技术实现,后端验证则是基于php语言,并利用session机制实现。

  1. 前端代码实现

(1)HTML代码

首先,需要编写HTML代码,实现验证码的基本结构。这里以一个简单的实例为例:

<div class="slide-verify">
    <div class="verify-img-box">
        <img src="verify.php" class="verify-img" id="verify-img">
        <div class="verify-btn-box">
            <span class="verify-btn" id="verify-btn"></span>
        </div>
    </div>
    <div class="verify-text">拖动滑块完成验证</div>
</div>

以上HTML代码中,div.slide-verify是验证码的外层容器,div.verify-img-box是验证码图片的容器,img.verify-img是验证码图片,div.verify-btn-box是滑块的容器,span.verify-btn是滑块。div.verify-text为提示文字。

在HTML中需要引入以下文件:

<script src="https://libs.baidu.com/jquery/1.9.0/jquery.js"></script>
<script src="jquery.ui.touch-punch.js"></script>
<script src="verify.js"></script>
<link rel="stylesheet" href="verify.css">

(2)CSS代码

CSS代码主要是实现验证码的样式与布局,这里只给出部分代码:

.slide-verify {
    position: relative;
    width: 300px;
    height: 100px;
}
.verify-img-box {
    position: absolute;
    top: 0; left: 0; right: 0; bottom: 0;
    margin: auto;
    width: 300px;
    height: 60px;
    border: 1px solid #ddd;
    background-color: #fafafa;
    overflow: hidden;
}
.verify-img {
    display: inline-block;
    width: 300px;
    height: 60px;
}
.verify-btn-box {
    position: absolute;
    top: 0; left: 0; right: 0; bottom: 0;
    margin: auto;
    width: 38px;
    height: 38px;
    background-color: #fff;
    border: 1px solid #ddd;
    border-radius: 50%;
    box-shadow: 0 0 3px #ddd;
    cursor: pointer;
}
.verify-btn {
    display: block;
    width: 36px;
    height: 36px;
    background-color: #34B5E5;
    border-radius: 50%;
}
.verify-text {
    position: absolute;
    bottom: 0;
    left: 50%;
    transform: translateX(-50%);
    margin-bottom: 5px;
    font-size: 12px;
}

以上CSS代码中,主要是实现了验证码的基本样式、滑块的样式、背景颜色、阴影等。

(3)JavaScript代码

JavaScript实现用户交互操作和数据提交,主要代码如下:

$(function() {
    var startX = 0, 
        distanceX = 0, 
        sliderLeft = 0, 
        sliderWidth = $('#verify-btn').width(),
        complete = false;
    $('#verify-btn').draggable({
        containment: '.verify-img-box',//滑块的移动范围
        axis: 'x',//只能在x轴方向上滑动
        drag: function(event, ui) {//滑块拖动过程
            distanceX = ui.position.left - startX;
            ui.position.left = sliderLeft + distanceX;
            //防止滑块越界
            if (ui.position.left <= 0) {
                ui.position.left = 0;
            } else if (ui.position.left >= sliderWidth) {
                ui.position.left = sliderWidth;
            }
        },
        stop: function(event, ui) {//滑块停止拖动
            startX = ui.position.left - 0;
            sliderLeft = ui.position.left - 0;
            //完成验证
            if (sliderLeft >= (sliderWidth - 2)) {//根据自己的需求设定,这里是滑动距离要大于等于(滑块宽度-2)
                complete = true;
                //提交验证
                $.ajax({
                    type: 'POST',
                    url: 'verify.php',
                    data: {
                        verify: 'true'
                    },
                    success: function(msg) {
                        alert(msg);//验证通过,执行相应操作
                    }
                });
            } else {//重置滑块位置
                complete = false;
                $('#verify-btn').animate({left: 0}, 200);
            }
        }
    });
});

以上JavaScript代码中,主要是使用jQuery UI库的拖拽功能实现滑块的拖动操作,并通过ajax提交验证结果。

  1. 后端代码实现

后端主要代码如下所示:

session_start();
define('V_CODE', '1');//验证码标识符
if (isset($_POST['verify']) && $_POST['verify'] === 'true') {//验证操作
    //判断验证码是否正确
    if ($_SESSION[V_CODE] && intval($_SESSION[V_CODE]) === 1) {
        echo '验证通过';
    } else {
        echo '验证失败';
    }
    //验证完毕,清楚验证码
    unset($_SESSION[V_CODE]);
    exit;//结束
}
header('Content-type: image/jpeg');
$im = imagecreate(58, 30);
$bg_color = imagecolorallocate($im, mt_rand(200, 255), mt_rand(200, 255), mt_rand(200, 255));//背景色
$fc_color = imagecolorallocate($im, mt_rand(50, 200), mt_rand(50, 200), mt_rand(50, 200));//字体色
imagefill($im, 0, 0, $bg_color);
$confash_code = rand(1, 9);//验证码字符
$_SESSION[V_CODE] = $confash_code;
imagestring($im, 5, 12, 6, $confash_code, $fc_color);
for ($i = 0; $i < 150; $i++) {//干扰像素
    imagesetpixel($im, mt_rand(0, 58), mt_rand(0, 30), $fc_color);
}
for ($i = 0; $i < 3; $i++) {//干扰线
    imageline($im, mt_rand(0, 58), mt_rand(0, 30), mt_rand(0, 58), mt_rand(0, 30), $fc_color);
}
imagejpeg($im);
imagedestroy($im);

以上代码中,首先通过session机制记录验证码的标识符,然后在验证码代码中,生成一个随机的验证码字符,并将其存储到$_SESSION数组中。在滑块验证代码中,通过ajax方式将验证结果提交到后台进行验证。如果验证通过,则执行相应操作,否则提示验证失败。

三、总结

本文简单介绍了php滑动验证码的实现原理,主要分为前端展示和后端验证两个部分。在前端展示中,通过HTML、CSS和JavaScript实现滑块验证码的基本功能;在后端验证中,则通过php和session实现验证码的验证操作。注意,在实际应用中,需要进一步加强安全性和人性化设计,以提供更好的用户体验。


猜你喜欢

【PHP】关于PHP8中match新语句的骚操作
PHP8新语法:match [更骚的匿名函数操作]PHP8 新出的一个语法很好用,就是 match 语句。match 语句跟原来的 switch 类似,不过比 switch 更加的严格和方便原来的 switch 语句代码如下:function&nbsp;getStr(&nbsp;$strType&nbsp;){ &nbsp;&nbsp;&nbsp;&nbsp;switch(&nbsp;$strType&nbsp;){ &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&amp;nb
发表于:2024-01-06 浏览:317 TAG:
【PHP】PHP设计模式大全与应用场景
面向对象编程的基本原则:1、单一职责:一个类,只需要做好一件事情。2、开放封闭:一个类,应该是可扩展的,而不可修改的。3、依赖倒置:一个类,不应该强依赖另外一个类。每个类对于另外一个类都是可替换的。4、配置化:尽可能的使用配置,而不是硬编码。5、面向接口编程:只需要关心接口,不需要关心实现。1、单例设计模式所谓单例模式,即在应用程序中最多只有该类的一个实例存在,一旦创建,就会一直存在于内存中!单例设计模式常应用于数据库类设计,采用单例模式,只连接一次数据库,防止打开多个数据库连接。一个单例类应具
发表于:2024-06-22 浏览:249 TAG: #php
【PHP】PHP实现打包zip并下载功能
让我来详细讲解一下如何用 PHP 实现打包 zip 并下载功能的攻略。准备工作在开始之前,需要准备几个工具和知识:一台可供测试的 PHP 环境的服务器。了解 PHP 的基础语法,并熟练掌握文件操作相关函数。需要安装和使用 ZipArchive 类,可以通过命令 sudo apt-get install php-zip 安装。实现过程1.首先,我们需要收集需要打包的文件列表。$files&nbsp;=&nbsp;[&#39;file1.txt&#39;,&nbsp;&#39;file2.txt&amp;#
发表于:2024-01-27 浏览:327 TAG:
【PHP】php单例模式的应用场景有哪些
php单例模式的应用场景有数据库连接、缓存管理、日志记录、配置管理、对象工厂和全局状态管理等。详细介绍:1、数据库连接,在一个PHP应用程序中,通常需要与数据库进行交互,为了避免频繁地创建和销毁数据库连接,可以使用单例模式来创建一个数据库连接类,并确保只有一个数据库连接实例存在,这样可以减少资源的消耗,并提高数据库操作的效率;2、缓存管理,缓存是一种常见的性能优化手段等等。本教程操作系统:windows10系统、PHP 8.1.3版本、DELL G3电脑。单例模式是一种常见的设计模式,
发表于:2023-12-06 浏览:385 TAG:
【PHP】php有哪些高效文本数据库
php高效文本数据库有SQLite、Redis和MongoDB等。详细介绍:1、SQLite是一种嵌入式的关系型数据库,它以文件形式存储数据,不需要独立的服务器进程,SQLite在PHP中有广泛的应用,它提供了高效的数据存储和检索能力,支持常见的SQL语法和事务操作,SQLite具有小巧、快速、可靠和易于集成的特点,适用于小型项目或需要单用户访问的应用程序;2、Redis等等。本教程操作系统:windows10系统、PHP 8.1.3版本、DELL G3电脑。在PHP中,有几种高效的文
发表于:2023-12-28 浏览:315 TAG:
【PHP】如何利用PHP实现RPC
一、什么是RPC什么是RPC&nbsp; &nbsp;RPC(Remote Procedure Call,远程过程调用)是一种计算机通信协议,用于使一个计算机程序可以调用另一个运行在不同计算机上的程序的过程或函数,并且无需了解底层网络细节。简而言之,RPC允许程序在不同的计算机或不同的进程之间通过网络进行通信,就好像调用本地函数一样。RPC的原理在RPC中,请求方(称为客户端)通过发送一条消息给目标方(称为服务器),请求执行某个远程过程(函数)。服务器接收到请求后,执行相应的过程,并将结果返回给
发表于:2024-08-26 浏览:252 TAG: #php #rpc
【PHP】php7弃用的函数有哪些
本教程操作系统:windows10系统、PHP 8.1.3版本、DELL G3电脑。PHP 7是PHP编程语言的一个重要版本,引入了许多新特性和改进。同时,为了提高代码的质量和安全性,PHP 7还废弃了一些旧的函数。下面是一些在PHP 7中被弃用的函数的例子:1. mysql_ 系列函数:在PHP 7中,mysql_ 系列函数(如mysql_connect、mysql_query等)被弃用。这些函数是用于与MySQL数据库进行交互的旧API,而在PHP 5.5版本中已经引入了更现代化和安全的my
发表于:2024-08-02 浏览:277 TAG: #php
【PHP】Composer创建一个library
1、首先创建一个空的项目文件夹mkdir&nbsp;mylibrary&nbsp;&amp;&nbsp;cd&nbsp;mylibrary2、执行composer命令//开始创建composer&nbsp;包 sh-4.2#&nbsp;composer&nbsp;init &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&amp;nbs
发表于:2024-08-28 浏览:232 TAG:
【PHP】什么是微服务架构
随着互联网的不断发展,越来越多的网站和应用程序应运而生。而对于开发者来说,如何快速高效地构建应用程序,是一个重要的挑战。其中,微服务架构已经成为了一个越来越受欢迎的解决方案。而php作为一种最受欢迎的web开发语言之一,也已经成为了很多开发者在构建微服务架构时的首选语言。本文将为大家介绍PHP如何应用于微服务架构,帮助大家更好地理解微服务架构以及如何使用PHP构建高效的微服务应用程序。什么是微服务架构?微服务架构(Microservices Architecture)是一种构建分布式应用程序的软
发表于:2024-05-23 浏览:289 TAG:
【PHP】php 对比2个数组是否一样
在 PHP 中,可以使用 array_diff 和 array_intersect 函数来比较两个数组是否相同。同时,还可以使用 == 或 === 运算符来比较两个数组是否相等。array_diff 函数array_diff 函数可以比较两个数组的差集,即找出在第一个数组中出现的元素,但是在第二个数组中不存在的元素。示例代码:$array1&nbsp;=&nbsp;array(1,&nbsp;2,&nbsp;3); $array2&nbsp;=&nbsp;array(1,&nbsp;3
发表于:2023-12-18 浏览:326 TAG: