dpauf28808 2013-08-13 23:19
浏览 23
已采纳

什么是最好的PHP函数来隐藏在后端的文件?

I have files in different formats: ePub/mobi/pdf/etc.

But I don't want anyone to access those files and certain files cannot be access by some users. So I cannot use HTTP to protect the folder that contains the files because it might give access to one user to all the files...

So is there a PHP function that can get a file from a folder that cannot be access publicly to then send it back to the user?

Thanks in advance!

  • 写回答

2条回答 默认 最新

  • douliang6563 2013-08-13 23:25
    关注

    Just store the file out of the root directory that holds all of your front-facing files. So assuming your directory structure is as such:

    root
    -- public_html
    -- -- access_book.php
    -- -- index.php
    -- -- ...
    -- books
    -- -- mobi_dick.pdf
    -- -- ...
    

    Then, just grab your file with a relative path (here is an example pulled from readfile):

    <?php
        // Replace this with the path to the actual file
        $file = '../books/mobi_dick.pdf';
    
        if (file_exists($file)) {
            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');
            header('Pragma: public');
            header('Content-Length: ' . filesize($file));
    
            ob_clean();
            flush();
            readfile($file);
            exit;
        }
    ?>
    

    You may have to configure open_basedir for PHP to open a file outside of the web root.

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(1条)

报告相同问题?

悬赏问题

  • ¥15 poi合并多个word成一个新word,原word中横版没了.
  • ¥15 【火车头采集器】搜狐娱乐这种列表页网址,怎么采集?
  • ¥15 求MCSCANX 帮助
  • ¥15 机器学习训练相关模型
  • ¥15 Todesk 远程写代码 anaconda jupyter python3
  • ¥15 我的R语言提示去除连锁不平衡时clump_data报错,图片以下所示,卡了好几天了,苦恼不知道如何解决,有人帮我看看怎么解决吗?
  • ¥15 在获取boss直聘的聊天的时候只能获取到前40条聊天数据
  • ¥20 关于URL获取的参数,无法执行二选一查询
  • ¥15 液位控制,当液位超过高限时常开触点59闭合,直到液位低于低限时,断开
  • ¥15 marlin编译错误,如何解决?