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
    • 最新
    • 标签
主页 / unix / 问题 / 417297
Accepted
Arcticooling
Arcticooling
Asked: 2018-01-16 09:08:28 +0800 CST2018-01-16 09:08:28 +0800 CST 2018-01-16 09:08:28 +0800 CST

如何通过该目录的名称更改目录的所有者和组?

  • 772

我有一个 Ubuntu 16.04 Nginx 服务器环境,在文档根目录下有几个 CMS (WordPress) 网站。

所有站点目录都www-data以递归方式作为所有者和组。


根据我得到的一些安全咨询,这是有问题的,因为来自一个站点的数据可能会改变任何其他相邻站点(例如,安装在其中一个站点的 CMS 中的恶意模块)。

我假设解决方案是更改此命令,该命令在添加新站点后始终运行(并且在更改所有者和组的更新后也在 cron 中):

chown -R www-data:www-data /var/www/html/*

对于一些条件命令,这些命令不仅将这些特征更改www-data为站点目录的实际名称,而且还更改为站点目录的实际名称。

为了澄清,每个站点目录的所有者应该是domain.tld,组也应该是domain.tld(我总是根据站点的 domain.tld 命名站点目录)。

什么可能是这样的条件命令?


注意:Nginx 用户和目录/var/www/html/都将保留在www-data:www-data.

G-Man更新:

我还没有测试,但我认为如果你${domain}作为变量 ( $1) 的第一个参数传递,这很好:

chown -R ${domain}:${domain} ${domain}/*

虽然我会保留它:

chown -R ${domain}:www-data ${domain}/*

当然,adduser ${domain} --disabled-password --disabled-login之前是需要的,如果没有做过。

security nginx
  • 1 1 个回答
  • 1525 Views

1 个回答

  • Voted
  1. Best Answer
    G-Man Says 'Reinstate Monica'
    2018-01-16T18:35:29+08:002018-01-16T18:35:29+08:00

    我可能遗漏了一些东西,但这看起来很简单:

    $ cd /var/www/html
    $ for dir in *
    do
        chown -R "$dir:$dir" "$dir"
    done
    

    如果您担心这些命令的正确性,可以在echo之前插入单词chown,例如,

    $ cd /var/www/html
    $ 用于 * 中的目录
    做
        echo chown -R "$dir:$dir" "$dir"
    完毕

    让它告诉您它将执行哪些chown命令,而无需实际执行它们。这个技巧适用于整个答案,事实上,适用于大多数 shell 脚本解决方案(即,其他问题)。

    如果你想在一行中完成,

    $ cd /var/www/html  &&  for d in *; do chown -R "$d:$d" "$d"; done
    

    我这样做是cd为了避免其他答案 所包含的复杂性。如果你这样做

    $ for dir in /var/www/html/*
    

    thendir将被设置为/var/www/html/domain1, /var/www/html/domain2,/var/www/html/domain3等,这对于操作目录很好,但不会为您提供所需的用户名和组名chown。另一个答案使用了一个相当复杂(并且不完全可靠) awk的过程来将目录路径的最后一级(即目录名称,也是用户名;例如,domain1)与路径的其余部分分开。幸运的是,我们可以完全在 shell 中做同样的事情(但更好一些),就像这样:

    $ for dir in /var/www/html/*
    do
        owner="${dir##*/}"
        chown -R "$owner:$owner" "$dir"
    done
    

    ${dir##*/}是一种特殊形式的参数扩展 ,它获取$dir并删除从最后一个/(斜杠)字符开始的所有内容。当然,这仅留下目录基本名称,即用户名,因此我们将其分配给owner并在chown命令中使用。请注意,此代码是POSIX 兼容的 ,应该可以在任何 POSIX 兼容的 shell 中工作;与本网站上的一些答案不同,它不依赖于 bash。

    如果您想在一行中执行此操作,

    $ for d in /var/www/html/*; do o="${d##*/}"; chown -R "$o:$o" "$d"; done
    

    当然,如果您只关心不希望更改主 shell 的工作目录,那么您可以在子 shell 中执行第一个命令:

    $ (cd /var/www/html  &&  for d in *; do chown -R "$d:$d" "$d"; done)
    

    不言而喻(但我还是会这么说)这要求您在运行任何这些命令之前定义名为domain1、domain2、等的用户(和组)。domain3如果您有一个添加新站点的脚本,那么在创建新目录之前添加一个命令来创建新用户是一件简单的事情,然后再运行chown. 如果您chown使用不是已定义用户名的名称运行,它将给您一条invalid user错误消息。

    • 3

相关问题

  • 简而言之,OpenBSD 的承诺是什么?

  • 在 Nginx Ubuntu 14.04 上托管多个应用程序

  • 加强 rhel6/7 服务器的安全性 [关闭]

  • 如果某人被授予 root 访问权限,是否可以劫持服务器作为人质?[关闭]

  • 是否有实现 RFC 5848“签名系统日志消息”的系统日志守护程序?

Sidebar

Stats

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

    如何将 GPG 私钥和公钥导出到文件

    • 4 个回答
  • Marko Smith

    ssh 无法协商:“找不到匹配的密码”,正在拒绝 cbc

    • 4 个回答
  • Marko Smith

    我们如何运行存储在变量中的命令?

    • 5 个回答
  • Marko Smith

    如何配置 systemd-resolved 和 systemd-networkd 以使用本地 DNS 服务器来解析本地域和远程 DNS 服务器来解析远程域?

    • 3 个回答
  • Marko Smith

    如何卸载内核模块“nvidia-drm”?

    • 13 个回答
  • Marko Smith

    dist-upgrade 后 Kali Linux 中的 apt-get update 错误 [重复]

    • 2 个回答
  • Marko Smith

    如何从 systemctl 服务日志中查看最新的 x 行

    • 5 个回答
  • Marko Smith

    Nano - 跳转到文件末尾

    • 8 个回答
  • Marko Smith

    grub 错误:你需要先加载内核

    • 4 个回答
  • Marko Smith

    如何下载软件包而不是使用 apt-get 命令安装它?

    • 7 个回答
  • Martin Hope
    rocky 如何将 GPG 私钥和公钥导出到文件 2018-11-16 05:36:15 +0800 CST
  • Martin Hope
    Wong Jia Hau ssh-add 返回:“连接代理时出错:没有这样的文件或目录” 2018-08-24 23:28:13 +0800 CST
  • Martin Hope
    Evan Carroll systemctl 状态显示:“状态:降级” 2018-06-03 18:48:17 +0800 CST
  • Martin Hope
    Tim 我们如何运行存储在变量中的命令? 2018-05-21 04:46:29 +0800 CST
  • Martin Hope
    Ankur S 为什么 /dev/null 是一个文件?为什么它的功能不作为一个简单的程序来实现? 2018-04-17 07:28:04 +0800 CST
  • Martin Hope
    user3191334 如何从 systemctl 服务日志中查看最新的 x 行 2018-02-07 00:14:16 +0800 CST
  • Martin Hope
    Marko Pacak Nano - 跳转到文件末尾 2018-02-01 01:53:03 +0800 CST
  • Martin Hope
    Kidburla 为什么真假这么大? 2018-01-26 12:14:47 +0800 CST
  • Martin Hope
    Christos Baziotis 在一个巨大的(70GB)、一行、文本文件中替换字符串 2017-12-30 06:58:33 +0800 CST
  • Martin Hope
    Bagas Sanjaya 为什么 Linux 使用 LF 作为换行符? 2017-12-20 05:48:21 +0800 CST

热门标签

linux bash debian shell-script text-processing ubuntu centos shell awk ssh

Explore

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

Footer

AskOverflow.Dev

关于我们

  • 关于我们
  • 联系我们

Legal Stuff

  • Privacy Policy

Language

  • Pt
  • Server
  • Unix

© 2023 AskOverflow.DEV All Rights Reserve