PHP 함수 코드는 임의로 생성 실현되는

양식 코드에 더 많은을 달성하기 위해,하지만 작성 검증 코드 JS는 항상 PHP는 아래에 구현 된 코드 학습, 불편 느낄
PHP 함수 코드는 임의로 생성 실현되는
형태로 점점 더 달성하기 위해 코드를하지만, JS 작성 확인 코드, 항상 불편, 그래서 구현에서 PHP 코드를 학습. 물론, 또한 미래의 시간의 함수로 패키지 할 수 있습니다 또한 사용이 매우 편리하지만 지금은 비포장이다. 또한 조언을 얻을 수 있도록 노력하겠습니다 오빠, 오빠를 뿌리지 마십시오 신인이다

이제 간단한 디지털 검증에 대해 이야기

당신은, 코드 의견에 따라 단계별로 작은 세미콜론없이 적은을 변경하는 것이 좋습니다.
새 파일 cap_sz.php을 만듭니다

<?php
session_start(); //设置session,一定要在顶部

$width = 150; //设置图片宽为300像素
$height = 40; //设置图片高为40像素

$image = imagecreatetruecolor($width, $height); //设置验证码大小的函数
$bgcolor = imagecolorallocate($image, 255, 255, 255); //验证码颜色RGB为(255,255,255)#ffffff
imagefill($image, 0, 0, $bgcolor); //区域填充

$cap_code = "";
for($i=0;$i<4;$i++){
    $fontsize = 7; //设置字体大小
    $fontcolor = imagecolorallocate($image, rand(0,120), rand(0,120), rand(0,120));
    //数字越大,颜色越浅,这里是深颜色0-120
    $fontcontent = rand(0,9);
    $cap_code.=$fontcontent; //.=连续定义变量

    $x = ($i*150/4)+rand(5,10);
    $y = rand(5,10);
    //设置坐标

    imagestring($image, $fontsize, $x, $y, $fontcontent, $fontcolor);
}

$_SESSION['code'] = $cap_code; //存到session

//设置干扰元素,设置雪花点
for($i=0;$i<300;$i++){
    $inputcolor = imagecolorallocate($image, rand(50,200), rand(20,200), rand(50,200));
    //设置颜色,20-200颜色比数字浅,不干扰阅读
    imagesetpixel($image, rand(1,149), rand(1,39), $inputcolor);
    //画一个单一像素的元素
}

//增加干扰元素,设置横线(先设置线的颜色,在设置横线)
for ($i=0;$i<4;$i++) { 
    $linecolor = imagecolorallocate($image, rand(20,220), rand(20,220),rand(20,220));
    //设置线的颜色

    imageline($image, rand(1,149), rand(1,39), rand(1,299), rand(1,149), $linecolor);   

}

//因为有些浏览器,访问的content-type会是文本型(乱码),所以我们需要设置成图片的格式类型
header('Content-Type:image/png');

imagepng($image); //建立png函数
imagedestroy($image); //结束图形函数,消除$image

그런 다음 새가 index.php를 확인

<?php
header("Content-Type: text/html;charset=utf-8");
if (isset($_REQUEST['code'])){
    session_start();

    if ($_REQUEST['code'] == $_SESSION['code']){
        echo "输入正确";
    }else{
        echo "输入错误,请重新输入";
    }

    exit();
}

?>

<!DOCTYPE html>
<html>
<head>
    <meta http-equiv="Content-Type" content="text/html; charset=utf-8" /> //这里不能少,不然乱码
    <title>验证码测试</title>
</head>
<body>
<form>
<p>验证码:<img src="cap_sz.php" onClick="this.src='cap_sz.php?nocache='+Math.random()" style="cursor:hand" alt="点击换一张"/>点击图片可更换验证码</p>
<p>请输入图片中的内容:<input type="text" name="code" value=""/></p>
<p><input type="submit" width="20px" height=19px value="提交"></input></p>

</form>
</body>
</html>

디지털 테스트 :

올바르게 입력 :
PHP 함수 코드는 임의로 생성 실현되는
PHP 함수 코드는 임의로 생성 실현되는
오류 유형 :
PHP 함수 코드는 임의로 생성 실현되는
PHP 함수 코드는 임의로 생성 실현되는

그리고 우리는 다음과 같은 경우 번호 플러스 영어를 확인할 실현

새 파일 (위에서 사본)를 만들 Cap_zy.php
PHP 함수 코드는 임의로 생성 실현되는

<?php

session_start(); //设置session

$width = 150; //设置图片宽为300像素
$height = 40; //设置图片高为40像素

$image = imagecreatetruecolor($width, $height); //设置验证码大小的函数
$bgcolor = imagecolorallocate($image, 255, 255, 255); //验证码颜色RGB为(255,255,255)#ffffff
imagefill($image, 0, 0, $bgcolor); //区域填充

$cap_code = "";
for($i=0;$i<4;$i++){
    $fontsize = 8; //设置字体大小
    $fontcolor = imagecolorallocate($image, rand(0,120), rand(0,120), rand(0,120));
    //数字越大,颜色越浅,这里是深颜色0-120
    $data = 'qwertyuiopasdfghjklzxcvbnmQWERTYUIOPASDFGHJKLZXCVBNM123456789'; //添加字符串
    $fontcontent = substr($data, rand(0,strlen($data)),1); //去除值,字符串截取方法
    $cap_code.=$fontcontent; //.=连续定义变量

    $x = ($i*150/4)+rand(5,10);
    $y = rand(5,10);
    //设置坐标

    imagestring($image, $fontsize, $x, $y, $fontcontent, $fontcolor);
}

$_SESSION['code'] = $cap_code; //存到session

//设置干扰元素,设置雪花点
for($i=0;$i<300;$i++){
    $inputcolor = imagecolorallocate($image, rand(50,200), rand(20,200), rand(50,200));
    //设置颜色,20-200颜色比数字浅,不干扰阅读
    imagesetpixel($image, rand(1,149), rand(1,39), $inputcolor);
    //画一个单一像素的元素
}

//增加干扰元素,设置横线(先设置线的颜色,在设置横线)
for ($i=0;$i<4;$i++) { 
    $linecolor = imagecolorallocate($image, rand(20,220), rand(20,220),rand(20,220));
    //设置线的颜色

    imageline($image, rand(1,149), rand(1,39), rand(1,299), rand(1,149), $linecolor);   

}

//因为有些浏览器,访问的content-type会是文本型,所以我们需要设置成图片的格式类型
header('Content-Type:image/png');

imagepng($image); //建立png函数
imagedestroy($image);

그런 다음 확인하기 위해 위의 index.php 파일을 수정
PHP 함수 코드는 임의로 생성 실현되는

<?php
header("Content-Type: text/html;charset=utf-8");
if (isset($_REQUEST['code'])){
    session_start();

    if ($_REQUEST['code'] == $_SESSION['code']){
        echo "输入正确";
    }else{
        echo "输入错误,请重新输入";
    }

    exit();
}

?>

<!DOCTYPE html>
<html>
<head>
    <meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
    <title>验证码测试</title>
</head>
<body>
<form>
<p>验证码:<img src="cap_zy.php" onClick="this.src='cap_zy.php?nocache='+Math.random()" style="cursor:hand" alt="点击换一张"/>点击图片可更换验证码</p>
<p>请输入图片中的内容:<input type="text" name="code" value=""/></p>
<p><input type="submit" width="20px" height=19px value="提交"></input></p>

</form>
</body>
</html>

영어 CAPTCHA :

: 올바른 입력
PHP 함수 코드는 임의로 생성 실현되는
PHP 함수 코드는 임의로 생성 실현되는
입력 오류를 :
PHP 함수 코드는 임의로 생성 실현되는
PHP 함수 코드는 임의로 생성 실현되는

이 완벽한 실현!

추천

출처blog.51cto.com/14113984/2428303