Права доступа к файлам: почему я не могу перечислить каталог?
Я могу перечислить каталоги в корневой оболочке,
root@ThinkPad:~# ll /media/
total 36
drwxr--r-- 6 root root 4096 2011-05-12 16:41 ./
drwxr-xr-x 22 root root 4096 2011-05-12 13:14 ../
drwxr-xr-x 5 root root 4096 2011-05-12 15:56 hd/
drwxr--r-- 2 root root 16384 2011-05-12 14:20 lost+found/
drwxr-xr-x 5 root root 4096 2011-05-12 16:34 main/
drwxr--r-- 4 root root 4096 2011-05-12 16:41 .Trash-0/
но не из моей учетной записи пользователя:
alex@ThinkPad:~$ ll /media/
ls: cannot access /media/..: Permission denied
ls: cannot access /media/hd: Permission denied
ls: cannot access /media/lost+found: Permission denied
ls: cannot access /media/.Trash-0: Permission denied
ls: cannot access /media/.: Permission denied
ls: cannot access /media/main: Permission denied
total 0
d????????? ? ? ? ? ? ./
d????????? ? ? ? ? ? ../
d????????? ? ? ? ? ? hd/
d????????? ? ? ? ? ? lost+found/
d????????? ? ? ? ? ? main/
d????????? ? ? ? ? ? .Trash-0/
Я не понимаю, почему я не вижу файлы (/media
имеет + разрешение).
2 ответа
Решение
Чтобы иметь возможность "войти" в каталог, что является обязательным условием для перечисления его содержимого, вам также необходимо разрешение +x.
Также обратите внимание, что это требование на всем пути от вершины (корня) структуры каталогов. Чтобы иметь возможность войти в каталог /foo/bar/baz, пользователь должен иметь разрешение +x для каждого промежуточного каталога.
Я использую свой pathlld
скрипт. pathlld
является:
#!/bin/bash
# Show the permissions on all the directories leading from / to
# the parameter.
# Usage: $0 <file_or_dir> <...>
#
# $Header: /home/walt/bin/RCS/pathlld,v 1.4 2010/02/21 20:34:16 walt Exp $
#
#
function pathlld ()
{
if [ "$1" = "/" ] ; then
/bin/ls -ld /
else
parent="${1%/*}"
pathlld "${parent:-/}"
/bin/ls -ld "$1"
fi
}
force=0
if [ "$1" = "-f" ] ; then
force=1
shift
fi
# Make sure we got at least one filename or directory name
file_or_dir="$1"
file_or_dir="${file_or_dir:?'missing.'}"
while [ $# -ne 0 ] ; do
if [ $force -eq 1 -o -e "$1" ] ; then
case "$1" in
/* ) target="$1" ;;
* ) target="$PWD/$1" ;;
esac
pathlld "$target"
[ -L "$target" ] && /bin/ls -ldL "$target"
else
echo "Nonexistent file or directory: $1"
fi
shift
done
Он не обнаруживает файловые системы, смонтированные только для чтения, используйте mount
для этого.