html表单将数据输入到mysql数据库中

时间:2014-04-03 11:10:15

标签: php html mysql forms

我试图在提交后获取我的html表单,然后将数据保存到mysql数据库中。 但是,一旦我点击提交按钮,它就会把我带到浏览器中显示的PHP代码。

为什么要这样做?

我在我的环境中使用XAMP,当我检查数据库时也没有添加任何数据。

非常感谢任何帮助。

//html form
<div id="contact_form">
<form action="contact_insert.php"     method="post">
Firstname: <input type="text" name="firstname">
Lastname: <input type="text" name="surname">
Email: <input type="text" name="email">
<input type="submit">
</form>
</div> 


//php contact_insert.php page
<?php

$username="root";
$password="password";
$server="127.0.0.1";
$database="eddiesdb";

$con = mysql_connect($server,$username,$password);
// Check connection
if (mysql_connect_errno())
  {
  echo "Failed to connect to MySQL: " . mysqli_connect_error();
  }

$sql="INSERT INTO customer (FirstName, Surname, EmailAddress)
VALUES
('$_POST[firstname]','$_POST[surname]','$_POST[email]')";

if (!mysqli_query($con,$sql))
  {
  die('Error: ' . mysqli_error($con));
  }
    echo "1 record added";

mysqli_close($con);

?> 

6 个答案:

答案 0 :(得分:2)

您可以使用此代码.. 不要使用mysql和mysqli组合。

  <div id="contact_form">
    <form action="contact_insert.php" method="post">
    Firstname: <input type="text" name="firstname">
    Lastname: <input type="text" name="surname">
    Email: <input type="text" name="email">
    <input type="submit" name="submit">
    </form>
    </div> 

<?php
    if(isset($_POST['submit']))
{
$username="root";
$password="password";
$server="127.0.0.1";
$database="eddiesdb";

$con = mysql_connect($server,$username,$password);

$sql="INSERT INTO customer (FirstName, Surname, EmailAddress)
VALUES
('$_POST[firstname]','$_POST[surname]','$_POST[email]')";
$a=mysql_query($sql);

if (!$a)
  {
 echo mysql_error();
  }
else
{
    echo "1 record added";
}
mysql_close($con);
}
?> 

答案 1 :(得分:0)

确保您的文件扩展名为.php

确保已将PHP代码放在<?php ... ?>标记中。

答案 2 :(得分:0)

你的剧本:

$con = mysql_connect($server,$username,$password);
// Check connection
if (mysql_connect_errno())
  {
  echo "Failed to connect to MySQL: " . mysqli_connect_error();
  }

$sql="INSERT INTO customer (FirstName, Surname, EmailAddress)
VALUES
('$_POST[firstname]','$_POST[surname]','$_POST[email]')";

if (!mysqli_query($con,$sql))
  {
  die('Error: ' . mysqli_error($con));
  }
    echo "1 record added";

mysqli_close($con);

您撰写了if (!mysqli_query($con,$sql)),但在$con中,您使用的是mysql_connect,而不是mysqli_connect

所以,它将是:

if (!mysql_query($con,$sql)) {
      die('Error: ' . mysql_error($con));
}
        echo "1 record added";

    mysql_close($con);

答案 3 :(得分:0)

你像这样创建了MySql的对象

$con = mysql_connect($server,$username,$password);

你可以在下面使用mysqli_qurey

if (!mysqli_query($con,$sql))

怎么可能?

答案 4 :(得分:0)

您对本地数据库的密码必须为空,您应该将xammp(form.html和contact_insert.php)中的htdocs文件保存在同一文件夹中。

答案 5 :(得分:0)

您的脚本

<?php

$username="root";
$password="password";
$server="127.0.0.1";
$database="dbname";

$con = mysql_connect($server,$username,$password);
mysql_select_db("dbname");
// Check connection
if (mysql_errno()) {
  echo "Failed to connect to MySQL: " . mysqli_connect_error();
}

$fname = $_POST['firstname'];
$sname = $_POST['surname'];
$email = $_POST['email'];

$sql="INSERT INTO customer (FirstName, Surname, EmailAddress) VALUES ('".$fname."','".$sname."','".$email."')";

if (!mysql_query($con,$sql)){
  die('Error: ' . mysql_error($con));
}
echo "1 record added";

mysql_close($con);

?>