Home > Backend Development > PHP Tutorial > How to verify the verification code?

How to verify the verification code?

WBOY
Release: 2016-07-06 13:53:52
Original
1497 people have browsed it

I made a short-answer verification code. At first, there was only an input box for the verification code and a verification code image. After submission, you can print out whether the verification code you entered is correct or wrong. Later, I added a text box. I want to make a simple verification submission with a few SQL statements, but I don’t know how to verify it. In practice, it must not just prompt an error or correct it. If there is an error, how should I prevent the form from being submitted? Another problem that needs to be solved first is that the verification code itself does not need to be inserted into the database, but there is a name in the form of the verification code. If the SQL statement is not processed and click submit, an error will be reported. What should I do? Invalid parameter number: number of bound variables does not match number of tokens in D:wampwwwyzm1.php on line 28

<code><!DOCTYPE html>
<html>
<head>
    <meta charset="utf-8">
    <title></title>
</head>
<body>
<form method="post">
    <input type="text" name="num"><br />
    <input type="text" style="display: inline-block;width: 50px;" name="yzm">
    <img id="checkpic" onclick="javascript:this.src='yzm2.php?tm='+Math.random();" src='yzm2.php' />
    <button type="submit">提交</button>
</form>
<?php
    if(trim(@$_POST['num'])){
        session_start();
        if(isset($_POST['yzm'])){
            if($_SESSION["str"]==$_POST['yzm']){
              echo "right";
            }else{
              echo "wrong";
          }
        }
        
        $pdo=new PDO("mysql:host=localhost;dbname=t1","root","");
        $stmt=$pdo->prepare("insert into test(num)values(:num)");
        $stmt->execute($_POST);
    }
    
?>
</body>
</html>
</code>
Copy after login
Copy after login

Reply content:

I made a short-answer verification code. At first, there was only an input box for the verification code and a verification code image. After submission, you can print out whether the verification code you entered is correct or wrong. Later, I added a text box. I want to make a simple verification submission with a few SQL statements, but I don’t know how to verify it. In practice, it must not just prompt an error or correct it. If there is an error, how should I prevent the form from being submitted? Another problem that needs to be solved first is that the verification code itself does not need to be inserted into the database, but there is a name in the form of the verification code. If the SQL statement is not processed and click submit, an error will be reported. What should I do? Invalid parameter number: number of bound variables does not match number of tokens in D:wampwwwyzm1.php on line 28

<code><!DOCTYPE html>
<html>
<head>
    <meta charset="utf-8">
    <title></title>
</head>
<body>
<form method="post">
    <input type="text" name="num"><br />
    <input type="text" style="display: inline-block;width: 50px;" name="yzm">
    <img id="checkpic" onclick="javascript:this.src='yzm2.php?tm='+Math.random();" src='yzm2.php' />
    <button type="submit">提交</button>
</form>
<?php
    if(trim(@$_POST['num'])){
        session_start();
        if(isset($_POST['yzm'])){
            if($_SESSION["str"]==$_POST['yzm']){
              echo "right";
            }else{
              echo "wrong";
          }
        }
        
        $pdo=new PDO("mysql:host=localhost;dbname=t1","root","");
        $stmt=$pdo->prepare("insert into test(num)values(:num)");
        $stmt->execute($_POST);
    }
    
?>
</body>
</html>
</code>
Copy after login
Copy after login

<code><?php
    if(trim(@$_POST['num'])){
        session_start();
        if(isset($_POST['yzm'])){
            if($_SESSION["str"]==$_POST['yzm']){
                echo "right";
                $pdo=new PDO("mysql:host=localhost;dbname=t1","root","");
                $stmt=$pdo->prepare("insert into test(num)values(:num)");
                $stmt->execute(array(':num'=>$_POST['num']);
            }else{
                echo "wrong";
          }
        }
    }
?>
</code>
Copy after login

Just write like this

Related labels:
php
source:php.cn
Statement of this Website
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn
Popular Tutorials
More>
Latest Downloads
More>
Web Effects
Website Source Code
Website Materials
Front End Template