首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >正确过滤掉LFI

正确过滤掉LFI
EN

Stack Overflow用户
提问于 2012-04-24 02:22:46
回答 2查看 1.5K关注 0票数 0

如何在PHP中正确过滤掉本地文件?我一直在寻找,但找不到一个简单的函数来做这件事。据我所知,去掉斜杠是不够的。

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2012-04-24 02:31:46

永远不要在用户输入上使用include() (或它的相关组件,如require()readfile())。永远不会。

票数 4
EN

Stack Overflow用户

发布于 2012-04-24 02:41:12

避免这种情况的最简单的方法就是不要编写来自用户输入的include()代码--通常不需要这样做,只需使用bar.php作为URL,而不是将URL设置为foo.php?page=bar

如果你一定要这样做,你可以用几种方式进行过滤。白名单很简单:

代码语言:javascript
复制
$ok = array('foo.php', 'bar.php', 'baz.php');
$include = in_array($_GET['page'], $ok) ? $_GET['page'] : 'default.php';
include($include);

这只允许包含文件的预设列表。

或者,您可以使用regexp进行过滤(但这样更容易出错):

代码语言:javascript
复制
if (preg_match('!^[a-z]+\.php$!', $_GET['page'])){
    include($_GET['page']);
}else{
    include('default.php');
}
票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/10286085

复制
相关文章

相似问题

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