繁体   English   中英

PHP语法中明显的错误?

[英]Apparent error in PHP syntax?

我收到以下错误:错误:您的SQL语法错误; 检查与您的MySQL服务器版本相对应的手册,以在第3行的'.98.229)'附近使用正确的语法

在我的PHP代码上,如下所示:

<?php
$con = mysql_connect("****", "****", "****");
if (!$con)
{
die('Could not connect: ' . mysql_error());
}
mysql_select_db("****", $con);
$ip=$_SERVER['REMOTE_ADDR'];

$sql="INSERT INTO users (fname, lname, email, password, ip)
VALUES
('$_POST[fname]', '$_POST[lname]', '$_POST[email]', '$_POST[password]', $ip)";

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

mysql_close($con);
?>

有什么建议吗? :)

$ip可能应该是'$ip'才能使其成为字符串。

我敢肯定,我不会是最后一个对你说你应该使用带有参数化输入的mysqliPDO的人 允许用户输入成为查询字符串的一部分是一项巨大的安全性。

您应该真正使用PDO并在执行操作之前检查POST。 您完全容易受到SQL注入的攻击。

PDO准备好的语句是否足以防止SQL注入?

模式中的IP列是什么类型的字段? 我想它需要像您声明中的其他字符串一样被引用。

您熟悉SQL InjectionPDO吗?

您可能还想对如何最好地在数据库中存储IP地址进行一些研究。

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM