递归检查所有文件的所有权

时间:2013-02-06 00:15:07

标签: linux bash

这是我第一次尝试bash脚本。我正在尝试创建一个脚本来检查从某个目录开始的每个文件所有者和组。

例如,如果我有这个:

files=/*  
for f in $files; do  
    owner=$(stat -c %U $f)  
    if [ "$owner" != "someone"  ]; then  
        echo $f $owner  
    fi  
done

最终目标是修复权限问题。但是,我无法将/*变量放在/中的所有内容下,它只会检查/下的文件并停在任何新目录中。有关如何检查/及其任何子目录下所有内容的权限的任何指示?

3 个答案:

答案 0 :(得分:25)

您可以shopt -s globstar并使用for f in yourdir/**在bash4 +中递归展开,或者您可以使用find

find yourdir ! -user someone

如果您想要与用户名和文件名相同的输出格式,则必须获得系统特定的信息:

GNU$  find yourdir ! -user someone -printf '%p %u\n' 
OSX$  find yourdir ! -user someone -exec stat -f '%N %Su' {} +

答案 1 :(得分:5)

你可以尝试这个,它是一个递归的:

function playFiles {
    files=$1
    for f in $files; do
            if [ ! -d $f ]; then
                    owner=$(stat -c %U $f)
                    echo "Simple FILE=$f  -- OWNER=$owner"
                    if [ "$owner" != "root"  ]; then
                            echo $f $owner
                    fi
            else
                    playFiles "$f/*"
            fi
    done
}
playFiles "/root/*"

在使用:playFiles“/ ”替换playFiles“/ root / ”之前,在另一个目录中播放一些内容。顺便说一下playFiles是一个bash函数。希望这会对你有所帮助。

答案 2 :(得分:5)

以列表格式递归列出所有文件,显示所有权和权限的隐藏文件

main = names(models.LW)