【发布时间】:2016-02-05 21:20:47
【问题描述】:
我创建了一个带有 HTML 表单的用户注册页面。我刚刚完成了将数据提交到 MySQL 数据库的 PHP 文件。
我已检查 phpMyAdmin 是否已连接到数据库并正在工作。
据我所知,MySQL 查询和 PHP 代码的其余部分似乎都很好,但是我在 PHP 代码的页面上遇到了内部错误。我已经使用include函数在HTML文件中包含了PHP文件,HTML注册页面和PHP文件在Chrome上都返回如下错误:
“网站在检索 [WEB ADDRESS] 时遇到错误。它可能因维护而关闭或配置不正确。”
我还应该注意,只有这个页面在做,网站上的其他页面都可以正常工作,所以它绝对是这个 PHP 文件。我会粘贴代码,但它很长。我以前从未遇到过使用 PHP 文件的普通 500 错误,我之前制作过类似的注册表单和代码,但从未遇到过这个问题。
任何帮助将不胜感激。
代码
<?php
error_reporting(E_ERROR);
//Errors
$password_error = "<div class='login-form-error'>Your passwords didn't match, be careful this time!</div>";
$field_error = "<div class='login-form-error'>You cannot leave any fields blank or use an invalid character.</div>";
$username_error = "<div class='login-form-error'>That username is already taken, make another one.</div>";
$characters_error = "<div class='login-form-error'>Your username cannot contain any special characters.</div>";
$email_error = "<div class='login-form-error'>Your emails didn't match, be careful next time!</div>";
$signedup = "<center><h1>Welcome to the club!</h1><span style='font-size: 24px;'>Your account is all ready, <a href='/client/sign-in' style='color: #212121; text-decoration: underline;'>Sign In</a> and set up your profile.</span></center>";
$max_length_error = "<div class='login-form-error'>Your first name or username cannot contain more than 25 characters.</div><br>";
$max_length_password_error = "<div class='login-form-error'>Your password must be between 8 and 30 characters long.</div>";
$reg =@$_POST['reg'];
//Declaring variables to prevent errors
$first_name = "";
$gender = "";
$age = "";
$username = "";
$password = "";
$password2 = "";
$email = "";
$email2 = "";
$date = "";
$u_check = "";
//registration form
$first_name = mysql_real_escape_string(strip_tags(stripslashes(@$_POST['first_name'])));
$gender = mysql_real_escape_string(strip_tags(stripslashes(@$_POST['gender'])));
$age = mysql_real_escape_string(strip_tags(stripslashes(@$_POST['age'])));
$username = mysql_real_escape_string(strip_tags(stripslashes(@$_POST['username'])));
$password = mysql_real_escape_string(strip_tags(stripslashes(@$_POST['password'])));
$password2 = mysql_real_escape_string(strip_tags(stripslashes(@$_POST['password2'])));
$email = mysql_real_escape_string(strip_tags(stripslashes(@$_POST['email'])));
$email2 = mysql_real_escape_string(strip_tags(stripslashes(@$_POST['email2'])));
$d = date("Y-m-d"); // Year - Month - Day
if ($reg) {
if ($email==$email2) {
//Check if user already exists
$u_check = mysql_query("SELECT `username` FROM `users` WHERE `username`='$username'") or die("MySQL ERROR: ".mysql_error());
//Count the amount of rows where username = $username
$check = mysql_num_rows($u_check);
if ($check == 0) {
//Check all of the fields have been filled in
if ($first_name&&&gender&&age&&$username&&$password&&$password2&&$email&&$email2) {
//Check passwords match
if ($password == $password2) {
//check username characters
if (!ctype_alnum($username)){
echo $characters_error;
}
else {
//check max length un fn ln
if (strlen($username)>25||strlen($first_name)>25) {
echo $max_length_error;
}
else
{
//Check max length pw
if (strlen($password)>30||strlen($password)<8) {
echo $max_length_password_error;
}
else
{
//encrypt
$password = md5($password);
$password2 = md5($password);
$query = mysql_query("INSERT INTO users VALUES ('','$username','$password','$email','$date','$first_name','$age','$gender','','profile_picture_here','banner_picture_here','','variables_next','0','','0','0','0','0','0','0')") or die("MySQL ERROR: ".mysql_error());
die($signedup);
}
}
}
}
else {
echo password_error;
}
}
else
{
echo field_error;
}
}
else
{
echo username_error;
}
}
else
{
echo email_error;
}
}
?>
【问题讨论】:
-
检查您的错误日志。
-
您好,欢迎来到 SO,请添加代码,以便我们查看可能出现的问题。请阅读How to Ask 和minimal reproducible example 以提出更受欢迎的问题。
-
PHPMyAdmin 不是数据库。它是 MySQL 数据库的 Web 界面。
-
请stop using
mysql_*functions。 These extensions 已在 PHP 7 中删除。了解 PDO 和 MySQLi 的 prepared 语句并考虑使用 PDO,it's really pretty easy。 -
您的最后一个 if 语句中似乎有三个
&。&&&不是有效的 PHP。应该是$gender而不是&gender
标签: php html mysql google-chrome