Dize göre izin numarası nasıl alınır: -rw-r - r--


53

Aynı chmod'u ayarladım , -rw-r - r-- için nasıl sayı alacağım ?


2
Programlı olarak mı yoksa sadece nasıl tercüme edileceğini bilmen gerekiyor mu?
mattdm

Tercüme etmek için tembelim :) stat benim için bir an için iyidir.
cnd

9
“Aynısını ayarla” ile ne demek istiyorsun? -Rw-r - r-- iznine sahip bir dosyanız var mı ve aynı izinlere sahip başka bir dosya mı ayarlamak istiyorsunuz? Ardından chmoddestekleriniz olup olmadığına bakın --reference: “--reference = RFILE, MODE değerleri yerine RFILE modunu kullan” - man chmod.
Manatwork


Hangi Unix'i kullanıyorsunuz?
Kusalananda

Yanıtlar:


53

Lütfen statçıktıyı kontrol edin :

# stat .xsession-errors 
  File: ‘.xsession-errors’
  Size: 839123          Blocks: 1648       IO Block: 4096   regular file
Device: 816h/2070d      Inode: 3539028     Links: 1
Access: (0600/-rw-------)  Uid: ( 1000/     lik)   Gid: ( 1000/     lik)
Access: 2012-05-30 23:11:48.053999289 +0300
Modify: 2012-05-31 07:53:26.912690288 +0300
Change: 2012-05-31 07:53:26.912690288 +0300
 Birth: -

11
stat -c %a /path/to/fileİhtiyacın olan sihir numarası.
12'den

ve cevap yukarıdaki Access bloğunda. Örnekte kullandığı dosya, söz konusu olandan farklı erişim ayarlarına sahip. Sorudaki kişi Erişim'i gösterirdi: (0644 / -rw-r - r--)
nycynik

65
r=4
w=2
x=1

Her grupta Örneğiniz 6 (r + w = ​​4 + 2) 4 (r = 4) 4 (r = 4).


26

Tam izin modu numarası 4 basamaklı bir sekizli sayıdır, ancak çoğu zaman yalnızca en az 3 önemli basamağı kullanırsınız. Her grubu r = 4, w = 2, x = 1 alarak izin dizgisine ekleyin. Örneğin:

 421421421
-rwxr-xr--
 \_/        -- r+w+x = 4+2+1 = 7
    \_/     -- r+_+x = 4+0+1 = 5
       \_/  -- r+_+_ = 4+0+0 = 4     => 0754

Şimdi, bazen böyle garip bir mütevazı göreceksiniz:

-rwsr-xr-T

Dördüncü basamak, xmodestring'deki bitlerin üzerine aşırı yüklenmiştir . Eğer xoradan başka bir harf görürseniz , o zaman bu "özel" dördüncü basamak bitlerinden birinin ayarlandığı ve harf küçük harf ise, o xkonum için de ayarlandığı anlamına gelir. Yani bunun için çeviri:

   4  2  1
 421421421
-rwsr-xr-T
   +  +  +  -- s+_+T = 4+0+1 = 5  
 \_/        -- r+w+s = 4+2+1 = 7  (s is lowercase, so 1)
    \_/     -- r+_+x = 4+0+1 = 5
       \_/  -- r+_+T = 4+0+0 = 4  (T is uppercase, so 0)   => 05754

Bir sayının sekizlik olduğunu göstermenin standart UNIX yolu onu sıfırla başlatmaktır. GNU chmod, verdiğiniz modun yine de sekizlik olduğunu varsayar, ancak sıfırı hazırlamak en güvenli yoldur.

Son olarak, +modelin sonunda bir sonuç görürseniz:

-rwxr-xr-x+

Bu, dosyanın genişletilmiş izinlere sahip olduğu anlamına gelir ve bundan daha fazlasına ihtiyacınız vardır chmod. Başlangıç ​​olarak setfaclve getfaclkomutlarına bakın .


10

Bu basit olabilir

-bash-3.2$ stat --format=%a sample_file
755

3

İzinler sadece bir ikili sayının dizgi gösterimidir. Çoğunlukla temsil edilir , gerisi harfleri.
0-

temel

Temel izinler için:

Tüm dönüştürme -ve kapaklar Sya Tkadar 0, gerisi temsil etmelidir 1.
Oluşturulan sonuçta ortaya çıkan ikili sayı sekizlik olarak basılmalıdır:

$ a=-rw-r--r--
$ b=${a//[ST-]/0}
$ b=${b//[!0]/1}
$ printf '%04o\n' $((2#$b))
0644

Bir satırda:

$ b=${a//[ST-]/0}; b=${b//[!0]/1}; printf '%04o\n' $((2#$b))
0644

Hata düzeltme ve 3 bit tespit 1000, 2000ya da 4000biraz daha fazla kod gerektirir:

#!/bin/bash

Say     (){ printf '%s\n' "$@"; }
SayError(){ a=$1; shift; printf '%s\n' "$@" >&2; exit "$a"; }

e1="Permission strings should have 10 characters or less"
e2="Assuming first character is the file type"
e3="Permission strings must have at least 9 characters"
e4="Permission strings could only contain 'rwxsStT-'"

a=$1

((${#a}>10))  &&   SayError 1 "$e1"
((${#a}==10)) && { Say        "$e2"; a=${a#?}; }
((${#a}<9))   &&   SayError 2 "$e3"
a=${a//[^rwxsStT-]}
((${#a}<9))   &&   SayError 3 "e4"
b=${a//[ST-]/0}; b=${b//[!0]/1}; c=0
[[ $a =~ [sS]......$ ]] && c=$((c|4)) 
[[ $a =~    [sS]...$ ]] && c=$((c|2)) 
[[ $a =~       [tT]$ ]] && c=$((c|1))

printf '%04o\n' "$((2#$b|c<<9))"

0

Dize ve onaltılı izin değerlerine sahip dosyaların listesini alın. Çıktının daha kolay olması için% N'nin sonunda çıktısını almak.

stat -c "%A %a %N" *

-rw-r--r-- 644 `file2.txt'
-rw-r--r-- 644 `file3.txt'
-rw-r--r-- 644 `file4.txt'
-rw-r--r-- 644 `file.txt'
drwxr-xr-x 755 `hsperfdata_root'
-rw-r--r-- 644 `junk.txt'
drwx------ 700 `vmware-root'

Bu, tüm dosyaları belirli bir onaltılık izne sahip bulacak.

find /tmp1 -user root -perm 644

-2

Dizindeki tüm eşzamanlı dosyalar için

-bash-4.1$ chmod -R 640 *

Tüm dosyalar için

-bash-4.1$ chmod 640 *
Sitemizi kullandığınızda şunları okuyup anladığınızı kabul etmiş olursunuz: Çerez Politikası ve Gizlilik Politikası.
Licensed under cc by-sa 3.0 with attribution required.