IT技术博客大学习 共学习 共进步
全部 移动开发 后端 数据库 AI 算法 安全 DevOps 前端 设计 开发者

如何安全的Include文件

火丁笔记 2014-11-28 12:47:39 累计浏览 2,700 次
本机暂存

   似乎多数人都觉得Include文件是一件非常简单的事情,可惜漏洞往往出现在我们忽视的地方。正所谓千里之堤溃于蚁穴,二战期间,法国人寄希望与马奇诺防线,却忽视了原本认为非常安全的阿登高地,让德国人有机可乘,最终的结果大家都知道了。

   下面这个例子虽然是我杜撰的,但是我确信现实情况里一定存在类似的问题:

<?php

$debug = false;

// ...

$config = include 'config.php';

// ...

if ($debug) {
    phpinfo();
}

?>

   码农在代码中埋了一个调试开关,缺省是关闭状态,必要的时候可以开启,以便显示一些特殊的信息,同时代码里包含了一个配置文件,它的内容大致如下所示:

<?php

return array(
    'foo' => '...',
    'bar' => '...',
);

?>

   突然有一天,码农因为一些其它的缘由修改了配置文件,引入了一些临时变量:

<?php

$debug = true;

$config = array(
    'foo' => '...',
    'bar' => '...',
);

/*
if ($debug) {
    var_dump($config);
}
*/

return $config;

?>

   结果问题产生了!配置文件里的临时变量(debug)污染了其它脚本的变量空间,进而导致代码执行的结果不再符合预期,最终问题也就在所难免了。

   如何安全的Include文件?很简单,在Include的时候注意限制变量的作用域即可:

<?php

$config = call_user_func(function() {
    return include 'config.php';
});

?>

   类似的做法在Javascript中很常见,但在PHP中却鲜有人注意,你的代码有问题么?

同分类推荐文章

  1. 绿盟科技《APT组织研究年鉴》(2026 版)正式发布 (2026-06-16 20:21:10)
  2. 【已复现】Linux内核Fragnesia权限提升漏洞(CVE-2026-46300) (2026-06-15 10:53:58)
  3. 企业文档安全最佳实践(二):给文档上“身份证”——手动标密与智能自动标密 (2026-06-12 17:18:33)

查看更多 安全 文章 →

建议继续学习

  1. 浅谈php web安全 (累计阅读 6,979)
  2. 跨域请求的iframe解决方案(1) (累计阅读 6,501)
  3. anti spam杂谈 (累计阅读 5,935)
  4. Cookie安全漫谈 (累计阅读 4,684)
  5. 一段Javascript的代码 (累计阅读 4,331)
  6. 淘宝网:前端安全须知 (累计阅读 3,921)
  7. 浅谈Web安全验证码 (累计阅读 3,485)
  8. nginx访问控制Access Control的问题 (累计阅读 3,462)
  9. IIS写权限利用续以及写权限漏洞来由解释 (累计阅读 3,380)
  10. require(),include(),require_once()和include_once()的异同 (累计阅读 3,314)