Aynı chmod'u ayarladım , -rw-r - r-- için nasıl sayı alacağım ?
chmod
destekleriniz olup olmadığına bakın --reference
: “--reference = RFILE, MODE değerleri yerine RFILE modunu kullan” - man chmod.
Aynı chmod'u ayarladım , -rw-r - r-- için nasıl sayı alacağım ?
chmod
destekleriniz olup olmadığına bakın --reference
: “--reference = RFILE, MODE değerleri yerine RFILE modunu kullan” - man chmod.
Yanıtlar:
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: -
stat -c %a /path/to/file
İhtiyacın olan sihir numarası.
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, x
modestring'deki bitlerin üzerine aşırı yüklenmiştir . Eğer x
oradan 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 x
konum 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 setfacl
ve getfacl
komutlarına bakın .
İzinler sadece bir ikili sayının dizgi gösterimidir. Çoğunlukla temsil edilir , gerisi harfleri.0
-
Temel izinler için:
Tüm dönüştürme -
ve kapaklar S
ya T
kadar 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
, 2000
ya da 4000
biraz 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))"
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