PHP文件系统安全问题

2024-01-09 38

一、简介

PHP 受大多数服务器系统中文件和目录权限的内置安全机制的影响。这允许控制文件系统中哪些文件是可读的。应该小心对待任何全局可读的文件,要确保所有有权限访问该文件系统的用户都可以安全地读取文件。

PHP 被设计为以用户级别访问文件系统,因此完全可以编写 PHP 脚本来读取系统文件,例如 /etc/passwd,修改网络连接,发送大量打印任务等。这有一些明显的影响,因此需要确保读写的是合适的文件。

二、示例脚本

请看下面的脚本,用户表示想要删除自己主目录下的一个文件。 假设 PHP web 界面通常用于文件管理, 因此 Apache 用户允许删除用户主目录中的文件。

不对变量检查会导致….:

<?php
// 从用户主目录移除一个文件
$username = $_POST['user_submitted_name'];
$userfile = $_POST['user_submitted_filename'];
$homedir = "/home/$username";
unlink("$homedir/$userfile");
echo "The file has been deleted!";
?>

由于 username 和 filename 由用户表单中提交,那就能提交属于其他人的 username 和 filename,甚至可以删除不被允许的文件。这种情况下, 应该使用一些其它形式的身份验证。不妨考虑一下,如果提交的变量是 “../etc/” 和 “passwd” 会发生什么。上面代码将等同于:

… 文件系统攻击:

<?php
// 删除磁盘中任何 PHP 有访问权限的文件。如果 PHP 有 root 权限:
$username = $_POST['user_submitted_name']; // "../etc"
$userfile = $_POST['user_submitted_filename']; // "passwd"
$homedir = "/home/$username"; // "/home/../etc"
unlink("$homedir/$userfile"); // "/home/../etc/passwd"
echo "The file has been deleted!";
?>

有两个重要措施来防止此类问题。

  • PHP web 用户二进制文件仅允许有限的权限。
  • 检查所有提交上来的变量。

这是改进的脚本:

更安全的文件名检查:

<?php
// 删除磁盘中 PHP 有权访问的文件。
$username = $_SERVER['REMOTE_USER']; // 使用认证机制
$userfile = basename($_POST['user_submitted_filename']);
$homedir = "/home/$username";
$filepath = "$homedir/$userfile";
if (file_exists($filepath) && unlink($filepath)) {
$logstring = "Deleted $filepath\n";
} else {
$logstring = "Failed to delete $filepath\n";
}
$fp = fopen("/home/logging/filedelete.log", "a");
fwrite($fp, $logstring);
fclose($fp);
echo htmlentities($logstring, ENT_QUOTES);
?>

然而,这样做也是有缺陷的。如果认证系统允许用户创建自己的登录用户名, 而用户选择 “../etc/” 作为登录名,系统将再次暴露。 出于这个原因,需要编写自定义检查:

更安全的文件名检查:

<?php
$username = $_SERVER['REMOTE_USER']; // 使用认证机制
$userfile = $_POST['user_submitted_filename'];
$homedir = "/home/$username";
$filepath = "$homedir/$userfile";
if (!ctype_alnum($username) || !preg_match('/^(?:[a-z0-9_-]|\.(?!\.))+$/iD', $userfile)) {
die("Bad username/filename");
}
//等等...
?>

根据操作系统的不同,需要关心各种各样的文件,比如设备条目(/dev/ 或 COM1)、配置文件(/etc/ 文件和 .ini 文件)、 众所周知的文件存储区域(/home/, My Documents)等等。出于这个原因,创建一个禁止所有权限而只开放明确允许的策略通常更容易些。

  • 广告合作

  • QQ群号:707632017

温馨提示:
1、本网站发布的内容(图片、视频和文字)以原创、转载和分享网络内容为主,如果涉及侵权请尽快告知,我们将会在第一时间删除。邮箱:2942802716#qq.com(#改为@)。 2、本站原创内容未经允许不得转裁,转载请注明出处“站长百科”和原文地址。
PHP文件系统安全问题
下一篇: PHP数据库安全