Warning: file_get_contents(/data/phpspider/zhask/data//catemap/6/EmptyTag/143.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
PHP插入到不插入数据中_Php_Mysql - Fatal编程技术网

PHP插入到不插入数据中

PHP插入到不插入数据中,php,mysql,Php,Mysql,下面是我的Html和php代码,都在单独的文件中,用于我的insert查询。它试图插入注册详细信息,但一直失败,任何我出错的原因。 我尝试过使用不同类型的语音标记,但仍然不起作用,我的教科书也展示了这种方法。数据库可以让用户登录并检查用户是否存在,但不能插入数据。谢谢 <?php include 'db.php'; session_start(); ?> <!DOCTYPE html> <html> <head> </head>

下面是我的Html和php代码,都在单独的文件中,用于我的insert查询。它试图插入注册详细信息,但一直失败,任何我出错的原因。 我尝试过使用不同类型的语音标记,但仍然不起作用,我的教科书也展示了这种方法。数据库可以让用户登录并检查用户是否存在,但不能插入数据。谢谢

<?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。””);
是的,我仍然没有更好的解决方法:(.如果有人看到任何东西,请说我真的迷路了。