所以我为我的页面创建了注册,点击“提交”按钮后我得到了这个错误...我创建了mysql表,我不知道为什么这个错误显示... 错误:
警告:mysqli_connect():( HY000 / 2013):与MySQL失去联系 服务器在'读取初始通信包',系统错误:95 / home / u771616840 / public_html / FreeDay / PHP中的“不支持操作” 第2行的表格2 / configdb.php
数据库错误
注册码:
<?php
session_start();
include('configdb.php');
if(isset($_POST['submit']))
{
//whether the username is blank
if($_POST['username'] == '')
{
$_SESSION['error']['username'] = "User Name is required.";
}
//whether the email is blank
if($_POST['email'] == '')
{
$_SESSION['error']['email'] = "E-mail is required.";
}
else
{
//whether the email format is correct
if(preg_match("/^([a-zA-Z0-9])+([a-zA-Z0-9._-])*@([a-zA-Z0-9_-])+([a-zA-Z0-9._-]+)+$/", $_POST['email']))
{
//if it has the correct format whether the email has already exist
$email= $_POST['email'];
$sql1 = "SELECT * FROM user WHERE email = '$email'";
$result1 = mysqli_query($mysqli,$sql1) or die(mysqli_error());
if (mysqli_num_rows($result1) > 0)
{
$_SESSION['error']['email'] = "This Email is already used.";
}
}
else
{
//this error will set if the email format is not correct
$_SESSION['error']['email'] = "Your email is not valid.";
}
}
//whether the password is blank
if($_POST['password'] == '')
{
$_SESSION['error']['password'] = "Password is required.";
}
//if the error exist, we will go to registration form
if(isset($_SESSION['error']))
{
header("Location: index.php");
exit;
}
else
{
$username = $_POST['username'];
$email = $_POST['email'];
$password = $_POST['password'];
$com_code = md5(uniqid(rand()));
$sql2 = "INSERT INTO user (username, email, password, com_code) VALUES ('$username', '$email', '$password', '$com_code')";
$result2 = mysqli_query($mysqli,$sql2) or die(mysqli_error());
if($result2)
{
$to = $email;
$subject = "Confirmation from TutsforWeb to $username";
$header = "TutsforWeb: Confirmation from TutsforWeb";
$message = "Please click the link below to verify and activate your account. rn";
$message .= "http://www.yourname.com/confirm.php?passkey=$com_code";
$sentmail = mail($to,$subject,$message,$header);
if($sentmail)
{
echo "Your Confirmation link Has Been Sent To Your Email Address.";
}
else
{
echo "Cannot send Confirmation link to your e-mail address";
}
}
}
}
?>
Configdb文件:
<?php
$mysqli=mysqli_connect('localhost','dbusername','dbpassword','databasename') or die("Database Error");
?>
Thanx求助:)
答案 0 :(得分:0)
我想分享我对这个问题的解决方案...... MySQL显示此错误,因为我有错误的表类型...在register.php中如下:
$username = $_POST['username'];
$email = $_POST['email'];
$password = $_POST['password'];
$com_code = md5(uniqid(rand()));
所以你必须为你的表创建以下内容......第一行表必须是用户名,第二行是电子邮件,然后是密码和com_code。你不能给他们其他名字,因为你已经在php文件中定义了这个表名... 如果这不会有帮助,那么请检查您是否拥有正确的数据类型...密码为 INT ,文本只有 TEXT