Unix: Как проверить разрешения для конкретного каталога? - PullRequest
273 голосов
/ 03 декабря 2008

Я знаю, что использование ls -l "directory/directory/filename" говорит мне о правах доступа к файлу. Как мне сделать то же самое в каталоге? Очевидно, я мог бы использовать ls -l в каталоге выше в иерархии, а затем просто прокрутить, пока не найду его, но это такая боль. Если я использую ls -l для фактического каталога, он дает разрешения / информацию о файлах внутри него, а не о реальном каталоге. Я попробовал это в терминале Mac OS X 10.5 и Linux (Ubuntu Gutsy Gibbon), и это тот же результат. Есть какой-то флаг, который я должен использовать?

Ответы [ 9 ]

376 голосов
/ 03 декабря 2008

Вот краткий ответ:

$ ls -ld directory

Вот что он делает:

-d, --directory
    list directory entries instead of contents, and do not dereference symbolic links

Вас могут заинтересовать manpages . Вот откуда все люди здесь получают свои хорошие ответы.

см. онлайновые справочные страницы

55 голосов
/ 03 декабря 2008

Вы также можете использовать команду stat, если хотите получить подробную информацию о файле / каталоге. (Я уточняю это, когда вы говорите, что изучаете ^^)

12 голосов
/ 06 мая 2015

Существует также

getfacl /directory/directory/

, включая ACL

Хорошее введение в Linux ACL здесь

7 голосов
/ 07 марта 2017

$ ls -ld каталог

(ls) указывает список файлов и каталогов. (-) указывает, что файл является обычным файлом. (l) указывает на длинный листинг. (d) указывает, что файл является каталогом, который в основном является файлом особого вида.

6 голосов
/ 08 ноября 2016

В GNU / Linux попробуйте использовать ls, namei, getfacl, stat.

Для Dir

[flying@lempstacker ~]$ ls -ldh /tmp
drwxrwxrwt. 23 root root 4.0K Nov  8 15:41 /tmp
[flying@lempstacker ~]$ namei -l /tmp
f: /tmp
dr-xr-xr-x root root /
drwxrwxrwt root root tmp
[flying@lempstacker ~]$ getfacl /tmp
getfacl: Removing leading '/' from absolute path names
# file: tmp
# owner: root
# group: root
# flags: --t
user::rwx
group::rwx
other::rwx

[flying@lempstacker ~]$ 

или

[flying@lempstacker ~]$ stat -c "%a" /tmp
1777
[flying@lempstacker ~]$ stat -c "%n %a" /tmp
/tmp 1777
[flying@lempstacker ~]$ stat -c "%A" /tmp
drwxrwxrwt
[flying@lempstacker ~]$ stat -c "%n %A" /tmp
/tmp drwxrwxrwt
[flying@lempstacker ~]$

Для файла

[flying@lempstacker ~]$ ls -lh /tmp/anaconda.log
-rw-r--r-- 1 root root 0 Nov  8 08:31 /tmp/anaconda.log
[flying@lempstacker ~]$ namei -l /tmp/anaconda.log
f: /tmp/anaconda.log
dr-xr-xr-x root root /
drwxrwxrwt root root tmp
-rw-r--r-- root root anaconda.log
[flying@lempstacker ~]$ getfacl /tmp/anaconda.log
getfacl: Removing leading '/' from absolute path names
# file: tmp/anaconda.log
# owner: root
# group: root
user::rw-
group::r--
other::r--

[flying@lempstacker ~]$

или

[flying@lempstacker ~]$ stat -c "%a" /tmp/anaconda.log
644
[flying@lempstacker ~]$ stat -c "%n %a" /tmp/anaconda.log
/tmp/anaconda.log 644
[flying@lempstacker ~]$ stat -c "%A" /tmp/anaconda.log
-rw-r--r--
[flying@lempstacker ~]$ stat -c "%n %A" /tmp/anaconda.log
/tmp/anaconda.log -rw-r--r--
[flying@lempstacker ~]$
5 голосов
/ 01 июля 2013

В OS X вы можете использовать:

ls -lead

Опция e показывает ACL. А списки ACL очень важны для знания точных разрешений в вашей системе.

5 голосов
/ 03 декабря 2008

В дополнение к вышеупомянутым постам, я хотел бы отметить, что "man ls" даст вам хорошее руководство по команде "ls" (List ".

Также, используя ls -la, myFile выведет список и покажет все факты об этом файле.

1 голос
/ 20 сентября 2018

Отображает файлы с разрешениями

stat -c '%a - %n' directory/*
1 голос
/ 13 декабря 2017

ls -lstr

Это показывает нормальное представление ls с разрешениями и user: group, а также

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...