AskOverflow.Dev

AskOverflow.Dev Logo AskOverflow.Dev Logo

AskOverflow.Dev Navigation

  • 主页
  • 系统&网络
  • Ubuntu
  • Unix
  • DBA
  • Computer
  • Coding
  • LangChain

Mobile menu

Close
  • 主页
  • 系统&网络
    • 最新
    • 热门
    • 标签
  • Ubuntu
    • 最新
    • 热门
    • 标签
  • Unix
    • 最新
    • 标签
  • DBA
    • 最新
    • 标签
  • Computer
    • 最新
    • 标签
  • Coding
    • 最新
    • 标签
主页 / server / 问题 / 415399
Accepted
Kzqai
Kzqai
Asked: 2012-07-26 14:47:13 +0800 CST2012-07-26 14:47:13 +0800 CST 2012-07-26 14:47:13 +0800 CST

上传图像的适当 linux 权限允许删除和重新上传

  • 772

我应该设置什么权限以及如何允许 apache 覆盖上传的图像,删除它们并重新上传它们,以及允许将基础文件夹的权限传递给新上传的文件(如果这是正确的方法)?

我的图片直接是,例如:/images/subset1/ /images/subset2/ /images/subset3/

非常标准,图像上传到每个子文件夹。

php
  • 1 1 个回答
  • 1143 Views

1 个回答

  • Voted
  1. Best Answer
    LSerni
    2012-07-26T15:10:52+08:002012-07-26T15:10:52+08:00

    要使 Apache 能够读取和写入目录,该目录必须是:

    • 由用户 apache 拥有,模式为 7xy(文件为 6xy);x 和 y 都可以为零;

    或者

    • 由另一个用户拥有,但组所有权与 Apache 相同,模式为 x7y 或 x6y(x 通常是 2 = 文件写入和 4 = 文件读取的总和,因此为 6,而 1 = 目录扫描,因此目录为 7)

    或者

    • 由不同于 Apache 的用户、不同于 Apache 的组以及模式 xy6 或 xy7 拥有。这意味着该文件绝对是任何人都可写的,因此是个坏主意。尝试将文件所有权更改为属于上述更合理的情况之一。

    要更改权限,您需要拥有文件/目录的所有权。然后您可以通过 shell(chmod 命令)或通过 FTP 更改权限。要更改所有权,您必须是超级用户 root,并且不能通过 FTP 执行此操作,需要某种 shell 访问权限才能运行 chown 实用程序或其某些 GUI 变体。

    我认为,您最好的选择是让非 Apache 用户拥有文件和目录,并且没有访问权限,除了目录的 4(读取)+ 1(=5)。然后在一组有限的特殊目录中,拥有 Apache 所有权和权限 600(文件)和 700(子目录)。然后,如果可能,将 Web 服务器(PHP、python 等)配置为不解释可写区域中的文件。在那里,Apache 将能够编写所有内容,但不能执行它。

    这是因为让 Apache 可写所有文件可能允许某人上传可执行代码,从而“命令”服务器执行您不​​喜欢的操作(发送垃圾邮件、提升权限、运行端口扫描和僵尸网络……)。如果需要写入文件的可能性,则应防止运行这些文件。

    • 2

相关问题

  • 用户特定的 Php.ini 当 php 作为模块运行时?

  • 使 php mail() 函数在 ubuntu-server 上工作的步骤是什么?

  • Web 服务器和数据库服务器位于完全不同的位置

  • PHP 作为 CGI 还是 Apache 模块?

  • 通过 VPN 连接什么是远程服务器 IP?

Sidebar

Stats

  • 问题 205573
  • 回答 270741
  • 最佳答案 135370
  • 用户 68524
  • 热门
  • 回答
  • Marko Smith

    新安装后 postgres 的默认超级用户用户名/密码是什么?

    • 5 个回答
  • Marko Smith

    SFTP 使用什么端口?

    • 6 个回答
  • Marko Smith

    命令行列出 Windows Active Directory 组中的用户?

    • 9 个回答
  • Marko Smith

    什么是 Pem 文件,它与其他 OpenSSL 生成的密钥文件格式有何不同?

    • 3 个回答
  • Marko Smith

    如何确定bash变量是否为空?

    • 15 个回答
  • Martin Hope
    Tom Feiner 如何按大小对 du -h 输出进行排序 2009-02-26 05:42:42 +0800 CST
  • Martin Hope
    Noah Goodrich 什么是 Pem 文件,它与其他 OpenSSL 生成的密钥文件格式有何不同? 2009-05-19 18:24:42 +0800 CST
  • Martin Hope
    Brent 如何确定bash变量是否为空? 2009-05-13 09:54:48 +0800 CST
  • Martin Hope
    cletus 您如何找到在 Windows 中打开文件的进程? 2009-05-01 16:47:16 +0800 CST

热门标签

linux nginx windows networking ubuntu domain-name-system amazon-web-services active-directory apache-2.4 ssh

Explore

  • 主页
  • 问题
    • 最新
    • 热门
  • 标签
  • 帮助

Footer

AskOverflow.Dev

关于我们

  • 关于我们
  • 联系我们

Legal Stuff

  • Privacy Policy

Language

  • Pt
  • Server
  • Unix

© 2023 AskOverflow.DEV All Rights Reserve