【问题标题】:Inserted data was not saving in phpmyadmin database插入的数据未保存在 phpmyadmin 数据库中
【发布时间】:2014-11-30 10:57:00
【问题描述】:

我是 php 新手。我正在尝试在 php mysql 中进行登录和注册。为此,我创建了一个简单的表单并测试了数据是否插入到 phpmyadmin 中。这些值未保存在 db 中。我不知道错误在哪里。 我已经包含下面的编码

我的数据库连接:

<?php

  $connect = mysql_connect("localhost", "root", "") or die("Unable to connect database".mysql_error());

  mysql_select_db("logindb", $connect) or die ("sorry db connection fail");
?>

我的注册表:

<?php
include("config.php");
?>
<!DOCTYPE html>
<html>
<head>
    <title>Login screen</title>
    <style type="text/css">
    .register-form{
        width: 500px;
        margin: 0 auto;
        text-align: center;
        padding: 10px;
        padding: 10px;
        background : #c4c4c4;
        border-radius: 10px;
        -webkit-border-radius:10px;
        -moz-border-radius:10px;
    }
    .register-form form input{padding: 5px;}
    .register-form .btn{
        background: #726E6E;
        padding: 7px;
        border-radius: 5px;
        text-decoration: none;
        width: 50px;
        display: inline-block;
        color: #FFF;
    }
    .register-form .register{
        border: 0;
        width: 60px;
        padding: 8px;
    }
    </style>
</head>
<body>
<?php
if(isset($_POST['submit']))
{
$name=mysql_real_escape_string($_POST['username']);
$email=mysql_real_escape_string($_POST['email']);
$password=mysql_real_escape_string($_POST['password']);
$cpassword=mysql_real_escape_string($_POST['confirmpassword']);
$query = mysql_query("inser into register values('', '$name', '$email', '$password',   '$cpassword')");
if($query)
{
    header("location:success.php");
}
}

?>
    <div class="register-form">
        <h1>Register</h1>
        <form action="" method="post">
            <p><label>User Name: </label>
            <input type="text" id="username" name="username" placeholder="Username">
            </p>
            <p><label>E-Mail&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; :</label>
            <input id="email" name="email" type="email">
            </p>
            <p><label>Password&nbsp;&nbsp; :</label>
            <input id="password" name="password" type="password">
            </p>
            <p><label>confirm Password &nbsp;&nbsp; :</label>
            <input id="confirmpassword" name="confirmpassword" type="password">
            </p>
            <input type="submit" name="submit" value="register" class="btn register">
            <a class="btn" href="login.php">Login</a>
        </form>
    </div>
</body>
</html>

创建新页面成功后我重定向到success.php

<!DOCTYPE html>
<html>
<head>
    <title>success full</title>
</head>
<body>
    <h1>Successfully registered</h1>
</body>
</html>

输入数据后,点击提交。我回声并看到了 sql 查询,我得到了价值,但它没有保存在 phpmyadmin 数据库中。我是php新手,请帮助我开发更多的php。 再次感谢您。

【问题讨论】:

  • 它必须插入而不是插入..
  • 是的,谢谢兄弟。我改变了,但它不起作用。
  • 如果问题中的错字已更正,请更正。

标签: php mysql


【解决方案1】:

除非有必要,否则将 PHP 放在任何 HTML 之前。此外,请在查询中指定列,因为空白字符串可能会导致查询失败。
您真的需要将确认密码存储在数据库中吗?我不相信你这样做,并确保你散列它。确认数据库中的所有列都与您插入的内容匹配。

<?php
include("config.php");

if(isset($_POST['submit'])) {
    $name=mysql_real_escape_string($_POST['username']);
    $email=mysql_real_escape_string($_POST['email']);
    $password=mysql_real_escape_string($_POST['password']);
    $cpassword=mysql_real_escape_string($_POST['confirmpassword']);
    $query = mysql_query("INSERT INTO register
                          (name_column,email_column,password_column)
                          VALUES('".$name."', '".$email."', '".$password."')");
    if($query) {
        header("location:success.php");
    }

} else {
    echo "no form data received.";
}

?>
<!DOCTYPE html>
//HTML HERE//

【讨论】:

    【解决方案2】:
    insert into register values('', '".$name."', '".$email."', '".$password."','".$cpassword."')
    

    【讨论】:

      【解决方案3】:

      改变

      $query = mysql_query("insert into register values('', '$name', '$email', '$password',   '$cpassword')");
      

      // Specify the last parameter to the DB NAME!
      $connect = mysql_connect("localhost", "root", "logindb")
      

      删除

      mysql_select_db("logindb", $connect) or die ("sorry db connection fail");
      

      【讨论】:

      • 感谢您的评论,我试过了,但它不起作用。
      猜你喜欢
      • 1970-01-01
      • 1970-01-01
      • 2018-09-15
      • 2019-10-04
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      相关资源
      最近更新 更多