PHP插入到不插入数据中
下面是我的Html和php代码,都在单独的文件中,用于我的insert查询。它试图插入注册详细信息,但一直失败,任何我出错的原因。 我尝试过使用不同类型的语音标记,但仍然不起作用,我的教科书也展示了这种方法。数据库可以让用户登录并检查用户是否存在,但不能插入数据。谢谢PHP插入到不插入数据中,php,mysql,Php,Mysql,下面是我的Html和php代码,都在单独的文件中,用于我的insert查询。它试图插入注册详细信息,但一直失败,任何我出错的原因。 我尝试过使用不同类型的语音标记,但仍然不起作用,我的教科书也展示了这种方法。数据库可以让用户登录并检查用户是否存在,但不能插入数据。谢谢 <?php include 'db.php'; session_start(); ?> <!DOCTYPE html> <html> <head> </head>
<?php
include 'db.php';
session_start();
?>
<!DOCTYPE html>
<html>
<head>
</head>
<?php
include 'header.php';
?>
<div id="logincontent">
<div id="registerform" class="loginform-in">
<h1>Registration</h1>
<fieldset>
<form id="myForm" action="registerscript.php" method="POST">
Email: <input type="text" name="username"/><br />
Password: <input type="password" name="pass"/><br />
First Name: <input type="text" name="fname"/><br />
Last Name: <input type="text" name="lname"/><br />
Address 1: <input type="text" name="add1"/><br />
Address 2: <input type="text" name="add2"/><br />
Postcode: <input type="text" name="pcode"/><br />
Telephone: <input type="text" name="phone"/><br />
<button id="submit">Register</button>
</form>
<div id="ack"></div>
</fieldset>
</div>
</div>
</body>
</html>
登记处
电子邮件:
密码:
名字:
姓氏:
地址1:
地址2:
邮政编码:
电话:
登记
PHP文件
<?php
include('db.php');
$email = mysql_real_escape_string( $_POST["username"] );
$pass = mysql_real_escape_string( md5($_POST["pass"]) );
$firstname = mysql_real_escape_string( $_POST["fname"] );
$surname = mysql_real_escape_string( $_POST["lname"] );
$add1 = mysql_real_escape_string( $_POST["add1"] );
$add2 = mysql_real_escape_string( $_POST["add2"] );
$pcode = mysql_real_escape_string( $_POST["pcode"] );
$phone = mysql_real_escape_string( $_POST["phone"] );
if( empty($email) || empty($pass) )
{
echo "Email and Password are Mandatory";
exit();
}
$res = mysql_query("SELECT email FROM members WHERE email='$email'");
$row = mysql_fetch_row($res);
if( $row > 0 )
echo "The Email $email has already been taken. Click Forgot Password to Retrieve";
else
{
$sql = "INSERT INTO members (memberid, firstname, surname, address1, address2, postcode, telephone, email, password) VALUES (
'',
'$firstname',
'$surname',
'$add1',
'$add2',
'$pcode',
'$phone',
'$email'
'$pass')";
if( mysql_query($sql) )
echo "Registration Successfull";
else
echo "An Error Occured Please Try Again";
}
您在这里漏掉了一个逗号
'$phone',
'$email', //<-------------- Here
'$pass')";
“$phone”,
“$email”,//添加以下内容以查找MySQL错误:
else
echo "An Error Occured Please Try Again";
echo mysql_errno($res) . mysql_error($res);
从$sql=insert to…
中删除memberid这可能是mysql数据库中的自动增量类型值
顺便说一句,您最好使用mysqli或pdo,而不是使用mysql。通过准备好的语句,您可以限制SQL注入的风险。md5关于密码,最好不要麻烦并将其存储为纯文本()从$SQL=insert-into中删除memberid…
这可能是自动增量类型整理好了谢谢@Mr.radial我想我明白了,shankar damodarans也有帮助$res=mysql\u查询(“选择来自成员的电子邮件,其中email=”“$email。””);
是的,我仍然没有更好的解决方法:(.如果有人看到任何东西,请说我真的迷路了。