[英]PHP not saving data to database
我觉得我正在接近弄清为什么PHP 不将数据保存到数据库中的原因 。 我尝试从众多教程中学习PHP和MySQL,但都失败了。
所以...我觉得尝试连接到MySQL数据库时可能没有指定某些内容。
在最近的教程中,仅将文本从输入内容输出到MySQL中的表中,我收到一条错误消息,指出未找到服务器“ localhost”。 我的Apache已安装在端口60(不是默认端口80)上。 因此,我认为这可能是问题所在。 我尝试将localhost:60
添加到mysqli_connect
而不是localhost
本身,并且错误消失了!
但是,仍然存在一个问题: 1.加载demo.php页面需要花费很多时间(请参见下面的代码)。 2.数据仍未添加。
这是代码(我将视频中的原始MySQL转换为MySQLi并添加了注释):
demo.php:
<?php
define('DB_NAME', 'forms1');
define('DB_USER', 'root');
define('DB_PASSWORD', '');
define('DB_HOST', 'localhost:60');
// stored in a variable to TEST if it's working
$link = mysqli_connect(DB_HOST, DB_USER, DB_PASSWORD, DB_HOST);
// TEST if a link has been established (connection)
if (!$link) {
die('Could not connect:' . mysqli_error($link));
}
// same as above
$db_selected = mysqli_select_db($link,DB_NAME);
if(!$db_selected) {
die('Can\t use ' . DB_NAME . ': ' . mysqli_error($link));
}
// Check SUCCESS with commented command below
// echo 'Connected successfully.';
// stored in a variable to shorten
$value = $_POST['input1'];
// stored in a variable to TEST
$sql = "INSERT INTO demo (input1) VALUES ('$value')";
if(!mysqli_query($link, $sql)) {
die('Error: ' . mysqli_error($link));
}
mysqli_close($link);
?>
演示form.php的:
<form action="demo.php" method="post" />
<p>Input 1: <input type="text" name="input1" /></p>
<input type="submit" value="Submit" />
</form>
我对另一个代码也遇到了同样的问题 ,请参见此处的线程: PHP数据库不会保存数据
我真的希望有人能在这里为我提供帮助。 可惜我还没有工作的基础...
谢谢!
尝试一下:(您当前的代码对我不起作用)HTML表单和PHP / SQL是一体的。
<?php
DEFINE ('DB_USER', 'xxx');
DEFINE ('DB_PASSWORD', 'xxx');
DEFINE ('DB_HOST', 'xxx');
DEFINE ('DB_NAME', 'xxx');
$link = @mysqli_connect (DB_HOST, DB_USER, DB_PASSWORD, DB_NAME)
OR die("could not connect");
if(isset($_POST['submit'])){
// stored in a variable to shorten
$value = mysqli_real_escape_string($link,$_POST['input1']);
// stored in a variable to TEST
$sql = "INSERT INTO demo (input1) VALUES ('$value')";
if(!mysqli_query($link, $sql)) {
die('Error: ' . mysqli_error($link));
}
else { echo "Success"; }
} // if(isset($_POST['submit']))
mysqli_close($link);
?>
<form action="" method="post" />
<p>Input 1: <input type="text" name="input1" /></p>
<input type="submit" name="submit" value="Submit" />
</form>
MySQL使用端口3306作为默认端口。 PHP是否直接连接到数据库? 如果是,请尝试使端口匹配。
您是否向MySQL添加了权限,以允许您的应用连接数据库并与之交互? 您应该阅读有关GRANT和权限的信息。
但是,以上Dagon的评论是一个严肃的评论:仅在您希望数据被盗,被破坏或两者兼而有之时,才应将数据库直接发布到Internet。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.