使用mysqli和php(PhpMyAdmin)检查用户名是否已存在

时间:2019-03-08 14:53:27

标签: php mysqli

con.php

<?php
$_HOST="localhost";
$_USER="root";
$_PASS="";
$_DBNM="test";

$con=mysqli_connect($_HOST, $_USER, $_PASS, $_DBNM);

if ($con === false)
{
    die ("Database Connection Failed");
}
echo "Database Connection Succeed <br>";
?>

register.php

<?php
include("con.php");
$username=$_POST['username'];
$password=$_POST['password'];
$level=$_POST['level'];

$sql = "select username from user where username='$username'";
$data = mysqli_query($con,$sql);

if(mysqli_num_rows($data) > 0)
{   
    echo '<script language="JavaScript">alert("Username Already Exist!");
        document.location:"register.html"</script>';
}
else
{
    $query = $con->query("INSERT INTO user (username, password, level) 
        VALUES ('$username', '$password', '$level')");
    echo '<script language="JavaScript">alert("Registration Succeed!");
    document.location:"index.php"</script>';
}

?>

因此,如果用户名已经存在,则代码可用于不插入帐户,但是它不显示回显,并且卡在了con.php上。 另外,当我输入不存在的用户名时,该帐户已成功添加,但未出现回显。

1 个答案:

答案 0 :(得分:0)

可以使用php中的标头代替使用javascript进行重定向。

请参阅示例代码。

if(mysqli_num_rows($data) > 0){   
    header("location:register.html");
    exit();
}else{
    // do query...
   header("location:index.php");
   exit();
}

您还应该考虑使用prepare语句或移至PDO
参考PDO:http://php.net/manual/en/pdo.prepare.php
引用标头:http://php.net/manual/en/function.header.php