首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >php mysql adodb

php mysql adodb
EN

Stack Overflow用户
提问于 2010-11-24 20:56:18
回答 2查看 1.5K关注 0票数 1

我正在使用PHP和adodb,但是遇到了一个很大的问题。我正在使用adodb来加速开发,这样我就可以做如下事情:

代码语言:javascript
复制
$r["Name"] = $_POST['txtName'];

if ($_POST["ID"] != "")
  $conn->AutoExecute("content", $r, 'UPDATE', 'AutoID = ' . $_POST["ID"]);      
else
  $conn->AutoExecute("content", $r, 'INSERT');

但是,如果名称中有一个单引号,则会使用斜杠将其保存到db中!因此,如果名称是证言,它将保存为证言,这给我带来了巨大的问题,有没有什么我可以避免的,但仍然像上面这样编程,因为它比准备insert / update语句要快得多。

干杯

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2010-11-24 22:56:51

这个问题的正确和最终解决方案由两部分组成:

  1. 在您的代码中以编程方式禁用所有magic_quotes。这样可以确保您有一个已知的配置可以使用,如果/当管理员在访问database!

之前更改所有传入的用户输入时,该配置不会被破坏

虽然第一部分是好的编程,但第二部分对于编写安全的应用程序是绝对必要的!

引用用户输入有两种方法:

手动

  1. (使用AdoDB的qstrQuote),在这种情况下,您必须非常非常小心,以免遗漏任何内容。对于小项目来说,这是非常可行的,我在过去已经做过很多次了,
  2. 使用带绑定变量的预准备语句来进行查询。这确保只要您正确指定变量类型,就不会在您的应用程序中出现SQL注入,而且比第一种方法更不容易出错。这是我一段时间以来一直在做的事情。

更新:

如果您使用预准备语句,您可能会发现AdoDB不会给您带来太多好处,而且您可以使用PDO完成大部分工作。当你需要一些“自动的”东西时,你可以自己编写一些特定于应用程序的函数。根据我的经验,这只是比包含AdoDB的工作量多一点,总体上要好一些。

票数 3
EN

Stack Overflow用户

发布于 2010-11-24 22:40:24

感谢您的输入,我决定使用此函数在运行时启用魔术引号:

代码语言:javascript
复制
if (get_magic_quotes_gpc()) {
    function stripslashes_gpc(&$value)
    {
        $value = stripslashes($value);
    }
    array_walk_recursive($_GET, 'stripslashes_gpc');
    array_walk_recursive($_POST, 'stripslashes_gpc');
    array_walk_recursive($_COOKIE, 'stripslashes_gpc');
    array_walk_recursive($_REQUEST, 'stripslashes_gpc');
}

然而,这会导致SQL注入吗?

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/4267015

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档