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上。 另外,当我输入不存在的用户名时,该帐户已成功添加,但未出现回显。
答案 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