php - 为启用了魔术引号的系统创建 real_escape_string() 方法

标签 php mysql oop mysqli magic-quotes-gpc

我正在学习 PHP 的书说,为了防止人们使用引号之类的东西来更改查询,您应该使用 real_escape_string 函数。作者接着说,在一些启用了魔术引号的旧系统上,使用 real_escape_string 可能会导致对某些字符进行双重转义,因此他创建了这个函数:

<?php
    function mysql_fix_string($conn, $string) {
        if (get_magic_quotes_gpc()) $string = stripslashes($string);
        return $conn->real_escape_string($string);
    }
?>

将其转换为 mysqli 类的扩展类中的方法可以吗? (除了我想传递尽可能少的参数之外,我没有任何真正的原因想要这样做。)

如果是这样,这是正确的方法吗?

class mysqli_extended extends mysqli {
    public function fix_string($string) {
        if(get_magic_quotes_gpc()) {
            $string = stripslashes($string);
        }
        return $this->real_escape_string($string);
    }
} 

在这种情况下静态方法更有意义吗?如果是的话,如何将其重写为静态方法,如果不是,那为什么?

<小时/> 由于我刚刚问了大约一百万个问题,我将在此处总结它们:

  1. 是否可以为此目的创建一个方法? (这有什么缺点吗?)
  2. 上面的代码是正确的方法吗?
  3. 它应该是静态方法吗?
  4. 如何将其设为静态方法?

最佳答案

从 php 5.3 开始,魔术引号已被弃用,并在 5.4 中被删除。我推荐learn php the right way

关于php - 为启用了魔术引号的系统创建 real_escape_string() 方法,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/33457898/

相关文章:

PHP fatal error 帮助

php - mysql,其中链接表为 null 或不等于某个 id

mysql - 更改XAMPP中MySQL全局变量的默认值

php - 使用设备对象的 PHP 类

php - 知道为什么我的 'register_shutdown_function'无法捕获 'require'错误吗?

php - 如何为 2 个用户代理加载自定义样式表?

PHP Preg Replace 替换数组

php - 使用 csv/xls 文件将数据插入 mysql 表

c++ - 私有(private)继承和组合,哪个最好,为什么?

java - 用于填充值对象的面向对象代码