>  기사  >  백엔드 개발  >  帮我看一下哪里错了,怎么输都是显示输入错误

帮我看一下哪里错了,怎么输都是显示输入错误

WBOY
WBOY원래의
2016-06-20 12:26:381036검색

nbsp;html>


    
    



    验证码:
        require('03.php');
    ?>

    提交
    
    if(isset($_POST['submit']))
    {
        session_start();
        $checkstr=$_SESSION['yzm']; //使用$_SESSION变量获取EX4_14_image.php页面上的验证码
        $str=$_POST['check']; //用户输入的字符串
        if(strcasecmp($str,$checkstr)==0) //不区分大小写进行比较
            echo "<script>alert('验证码输入正确!');</script>";
        else
            echo "<script>alert('输入错误!');</script>";
    }
    ?>





03.php
session_start();
function a($type, $length ,$clear){
    $nums=range(0,9);
    $xxzm=range('a','z');
    $dxzm=range('A','Z');
    $igorne=array('0','o','1','l');
    $chars=array();
    if($type==1)
        $chars=$nums;
    if($type==2)
        $chars=array_merge($nums,$xxzm);
    if($type==3)
        $chars=array_merge($nums,$xxzm,$dxzm);
    if($clear==true)
        $chars=array_diff($chars,$igorne);
    $keys=array_rand($chars,$length);
    $code="";
    foreach($keys as $key)
        $code=$code.$chars[$key];
    return $code;

}

$yzm=a(3,5,true);
$_SESSION['yzm']=$yzm;
echo $yzm;
?>


回复讨论(解决方案)

你在程序文件的开始处 和 接收提交的代码段中打印出  $_SESSION['yzm'] 和 $_POST['check'] 就会知道问题的所在了

require('03.php'); //产生验证码,并保存于 $_SESSION
而 $checkstr=$_SESSION['yzm']; //使用$_SESSION变量获取EX4_14_image.php页面上的验证码
总是在其后运行,显然获得的只是最新设置的内容

要怎么改呢?

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