javascript - 注册验证

标签 javascript php mysqli verification

每次我第一次留下任何未填充的文本框时,它都会被注册到数据库,就像我将所有文本框留空一样,但是当你第二次这样做时(两次中的任何一个),那就是警报框弹出的时间...我不知道该怎么办。 请帮帮我。 这是我的代码:

<?php

ini_set('display_errors', 0);
$email= $_POST['email'];
$user= $_POST['user'];
$password= $_POST['password'];
$image =($_FILES['image']['name']);
$submit= $_POST['submit'];

if (empty($email) || empty($password) || empty($user) ) 
{
    echo "<script type='text/javascript'>
    alert('You did not complete all of the required fields');
    window.location='blah2.php';
    </script>";  
}


if(isset($submit))
{   
    $con = mysqli_connect("localhost", "root", "", "top")
        or die('error in connection'.mysqli_connect_error());

        $q = "SELECT username , email FROM registries WHERE username = ? OR email = ?";     
        $stmt = mysqli_prepare ($con, $q);
            mysqli_stmt_bind_param($stmt, 'ss', $user, $email);
            mysqli_stmt_execute($stmt);
            mysqli_stmt_bind_result($stmt, $user , $email);
            mysqli_stmt_store_result($stmt);
            $result = mysqli_stmt_num_rows($stmt);

    if($result > 0) 
    { 
        echo "<script type='text/javascript'>
              alert('Email address or Username is already taken. Please pick another one.');
              window.location='blah2.php';
              </script>";       
    }   
    else
    {

        $q="INSERT INTO registries VALUES (?,?,?,?)";
        $stmt = mysqli_prepare($con, $q);
                move_uploaded_file($_FILES["image"]["tmp_name"],"uploads/" . $_FILES["image"]["name"]);
                mysqli_stmt_bind_param($stmt, 'ssss', $email, $user, $password, $image);
                mysqli_stmt_execute($stmt);
                mysqli_stmt_store_result($stmt);

                mysqli_stmt_close($stmt);

                header('Location: blah.php');


    }   

}

最佳答案

有了这个

$submit= $_POST['submit']; 

$submit 始终设置

也许你可以尝试一下

if (isset($_POST['Submit']))

出于调试目的,您可以尝试 var_dump $email$password$user 并检查它们是否真的为空您发布表单一次或两次

关于javascript - 注册验证,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/19276722/

相关文章:

php - 如何在使用撇号的输入中转义撇号

php - 为什么 mysqli 给出 "Commands out of sync"错误?

php - MySQL/SQL/PHP 语法错误

php - Goutte - 从 $crawler->filter() 获取内部值

php - Laravel - 在多对多关系中渴望加载单个项目

php - mysqli_query() 需要至少 2 个参数,其中 1 个给定

javascript - Node.js |如何通过串口向设备发送和接收一个字节?

javascript - 对多个事件使用一次 e.preventDefault()

javascript - Google 图表在 Bootstrap 模态中显示时显示对齐错误

javascript - Selenium page_source 不返回修改后的 DOM 树