>백엔드 개발 >PHP 문제 >PHP 슬라이딩 인증코드 구현 원리에 대해 이야기해보겠습니다.

PHP 슬라이딩 인증코드 구현 원리에 대해 이야기해보겠습니다.

PHPz
PHPz원래의
2023-03-23 11:12:062963검색

인터넷의 급속한 발전과 함께 인증코드는 인터넷 보안의 중요한 수단이 되었습니다. 그 중 슬라이딩 인증코드는 단순성, 쉬운 조작, 높은 보안성으로 인해 실제 응용 분야에서 널리 사용되고 있습니다. 이번 글에서는 PHP 슬라이딩 인증코드의 구현원리를 소개하겠습니다.

1. 슬라이딩 인증코드의 정의 및 적용

슬라이딩 인증코드는 사용자가 인터페이스에 특정 그림이나 그래픽이 포함된 슬라이더를 표시하는 것이 기본 원칙입니다. 슬라이더를 누른 상태에서 슬라이더가 인증 코드 그래픽의 해당 위치에 연결될 때까지 드래그하여 확인하세요. 이러한 유형의 인증코드는 광고, 로그인, 회원가입, 댓글 등 사용자 식별이 필요한 시나리오에서 주로 사용됩니다.

2. PHP 슬라이딩 인증코드 구현 원리

PHP 슬라이딩 인증코드 구현은 크게 프론트엔드 디스플레이와 백엔드 인증 두 부분으로 나뉜다. 프런트엔드 디스플레이는 주로 HTML, CSS, JavaScript 등 프런트엔드 기술을 통해 구현되는 반면, 백엔드 검증은 PHP 언어를 기반으로 하며 세션 메커니즘을 사용하여 구현됩니다.

  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);

위 코드에서는 세션 메커니즘을 통해 인증 코드의 식별자가 먼저 기록된 후 임의의 인증 코드 문자가 생성됩니다. 확인 코드 code 에 $_SESSION 배열에 저장합니다. 슬라이더 인증 코드에서는 Ajax를 통한 인증을 위해 인증 결과를 백그라운드로 제출합니다. 확인이 통과되면 해당 작업을 수행하고, 그렇지 않으면 확인이 실패했다는 메시지가 표시됩니다.

3. 요약

본 글에서는 PHP 슬라이딩 인증코드의 구현 원리를 간략하게 소개하고 있으며, 크게 프론트엔드 디스플레이와 백엔드 인증 두 부분으로 나누어집니다. 프론트 엔드 디스플레이에서 슬라이더 검증 코드의 기본 기능은 HTML, CSS 및 JavaScript를 통해 구현되며 백엔드 검증에서는 검증 코드의 검증 작업이 PHP 및 세션을 통해 구현됩니다. 실제 적용에서는 더 나은 사용자 경험을 제공하기 위해 보안과 인간화된 디자인을 더욱 강화해야 합니다.

위 내용은 PHP 슬라이딩 인증코드 구현 원리에 대해 이야기해보겠습니다.의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.