保护文件以供下载

时间:2012-05-31 13:03:45

标签: php mysql .htaccess

我想要一个文件夹,让我们称之为文档,其中包含登录用户可以下载的文档。这些信息非常敏感。我怎样才能最好地保护文件夹。我来自PHP背景,所以想知道我是否忽略了任何东西。

我将使用.htaccess保护文件夹,当用户点击下载时,它们永远不会显示在文件夹中。下载被强制通过php删除文件夹名称。

当然为了保护用户区域,我正在所有输入字段上实施卫生和验证,并注意SQLInjections。使用SSL连接。关闭所有的PHP警告。安全区域使用SESSION变量来控制访问并重新验证用户的特殊任务,例如更改密码。加上10分钟的超时功能,之后用户必须重新输入详细信息。

我正在尽可能地尽可能地进行沟通,所以无论多么小的建议都会受到欢迎。

2 个答案:

答案 0 :(得分:32)

将文件放在webroot之外。然后使用PHP通过脚本传递文件。这样,没有人可以直接链接到文件并绕过您的控件。 (当然,只有在验证用户有权检索该文件后才能确保执行此操作的脚本。)

示例PHP:

<?php
    if (!isset($_SESSION['authenticated'])) {
        exit;
    }
    $file = '/path/to/file/outside/www/secret.pdf';

    header('Content-Description: File Transfer');
    header('Content-Type: application/octet-stream');
    header('Content-Disposition: attachment; filename=' . basename($file));
    header('Content-Transfer-Encoding: binary');
    header('Expires: 0');
    header('Cache-Control: must-revalidate, post-check=0, pre-check=0');
    header('Pragma: public');
    header('Content-Length: ' . filesize($file));
    ob_clean();
    flush();
    readfile($file);
    exit;
?>

答案 1 :(得分:0)

除了John Conde之外,您还可以将dl url重写为另一个不合理的文件夹,以便为试图超越其访问权限的用户提供蜜罐。

在你的htaccess中添加这种规则

Options -Indexes

<files .htaccess>
  order allow,deny
  deny from all
</files>

#Add all file you want to protect except the one you share...
<FilesMatch "\.(htaccess|htpasswd|ini|phps|fla|psd|log|sh)$">
  Order Allow,Deny
  Deny from all
</FilesMatch>