使用 mysqli_real_escape_string() 函数时,开发人员可能会遇到错误:“mysqli_real_escape_string() 需要 2 个参数,给定 1 个参数。 ”要解决这个问题,我们需要了解函数的正确用法及其参数要求。
根据官方文档,mysqli_real_escape_string()的语法为:
string mysqli_real_escape_string ( mysqli $link , string $escapestr )
这表明该函数需要两个参数:
提供的代码片段尝试检查 PHP 版本以确定是否使用 mysqli_real_escape_string() 或mysqli_escape_string()。但是,它失败了,因为 mysqli_real_escape_string() 需要 MySQLi 连接链接作为第一个参数,而代码中缺少该参数。
要修复此错误,我们需要向 mysqli_real_escape_string() 提供正确的参数。这可以通过建立 MySQLi 连接并将连接链接作为第一个参数传递给函数来实现。
以下是如何正确使用它的示例:
$mysqli = new mysqli('host', 'username', 'password', 'database'); if (phpversion() >= '4.3.0'){ $string = mysqli_real_escape_string($mysqli, $string); }else{ $string = mysqli_escape_string($mysqli, $string); }
在此代码中, $mysqli 变量代表一个有效的 MySQLi 连接链接,它与要转义的 $string 一起传递给 mysqli_real_escape_string() 。这应该可以解决错误并允许您按预期使用 mysqli_real_escape_string()。
以上是为什么 `mysqli_real_escape_string()` 会抛出'参数不匹配”错误,如何修复它?的详细内容。更多信息请关注PHP中文网其他相关文章!