濮阳杆衣贸易有限公司

主頁 > 知識庫 > Linux中特殊權(quán)限SUID、SGID與SBIT的深入講解

Linux中特殊權(quán)限SUID、SGID與SBIT的深入講解

熱門標(biāo)簽:地圖標(biāo)注需要提交啥資料入駐 福州呼叫中心外呼系統(tǒng)哪家好 昆明外呼系統(tǒng) 七大洲地圖標(biāo)注 新鄉(xiāng)人工智能電話機(jī)器人加盟 河南省鄭州市地圖標(biāo)注 臨汾電銷機(jī)器人費(fèi)用 地圖標(biāo)注w是什么方向 400電話申請找哪家公司

前言

對于linux中文件或目錄的權(quán)限,應(yīng)該都知道普通的rwx權(quán)限(關(guān)于linux中rwx權(quán)限的看我的這篇博文http://www.cnblogs.com/javaee6/p/3994750.html)。我們先看看下面兩個的權(quán)限是什么

非常奇怪,/tmp目錄和 passwd文件的權(quán)限怎么怪怪的,怎么有s和t權(quán)限呢??戳讼旅娴膬?nèi)容你就明白了。

setuid 和 setgid 分別是 set uid ID upon execution 和 set group ID upon execution 的縮寫。我們一般會再次把它們縮寫為 suid 和 sgid。它們是控制文件訪問的權(quán)限標(biāo)志(flag),它們分別允許用戶以可執(zhí)行文件的 owner 或 owner group 的權(quán)限運(yùn)行可執(zhí)行文件。

說明:本文的演示環(huán)境為 ubuntu 16.04。

SUID

在 Linux 中,所有賬號的密碼記錄在 /etc/shadow 這個文件中,并且只有 root 可以讀寫入這個文件:

如果另一個普通賬號 tester 需要修改自己的密碼,就要訪問 /etc/shadow 這個文件。但是明明只有 root 才能訪問 /etc/shadow 這個文件,這究竟是如何做到的呢?事實(shí)上,tester 用戶是可以修改 /etc/shadow 這個文件內(nèi)的密碼的,就是通過 SUID 的功能。讓我們看看 passwd 程序文件的權(quán)限信息:

上圖紅框中的權(quán)限信息有些奇怪,owner 的信息為 rws 而不是 rwx。當(dāng) s 出現(xiàn)在文件擁有者的 x 權(quán)限上時,就被稱為 SETUID BITS 或 SETUID ,其特點(diǎn)如下:

  • SUID 權(quán)限僅對二進(jìn)制可執(zhí)行文件有效
  • 如果執(zhí)行者對于該二進(jìn)制可執(zhí)行文件具有 x 的權(quán)限,執(zhí)行者將具有該文件的所有者的權(quán)限
  • 本權(quán)限僅在執(zhí)行該二進(jìn)制可執(zhí)行文件的過程中有效

下面我們來看 tester 用戶是如何利用 SUID 權(quán)限完成密碼修改的:

  • tester 用戶對于 /usr/bin/passwd 這個程序具有執(zhí)行權(quán)限,因此可以執(zhí)行
  • passwd 程序passwd 程序的所有者為 root
  • tester 用戶執(zhí)行 passwd 程序的過程中會暫時獲得 root 權(quán)限
  • 因此 tester 用戶在執(zhí)行 passwd 程序的過程中可以修改 /etc/shadow 文件

但是如果由 tester 用戶執(zhí)行 cat 命令去讀取 /etc/shadow 文件確是不行的:

原因很清楚,tester 用戶沒有讀 /etc/shadow 文件的權(quán)限,同時 cat 程序也沒有被設(shè)置 SUID。我們可以通過下圖來理解這兩種情況:

如果想讓任意用戶通過 cat 命令讀取 /etc/shadow 文件的內(nèi)容也是非常容易的,給它設(shè)置 SUID 權(quán)限就可以了:

$ sudo chmod 4755 /bin/cat

現(xiàn)在 cat 已經(jīng)具有了 SUID 權(quán)限,試試看,是不是已經(jīng)可以 cat 到 /etc/shadow 的內(nèi)容了。因?yàn)檫@樣做非常不安全,所以趕快通過下面的命令把 cat 的 SUID 權(quán)限移除掉:

$ sudo chmod 755 /bin/cat

SGID

當(dāng) s 標(biāo)志出現(xiàn)在用戶組的 x 權(quán)限時稱為 SGID。SGID 的特點(diǎn)與 SUID 相同,我們通過 /usr/bin/mlocate 程序來演示其用法。mlocate 程序通過查詢數(shù)據(jù)庫文件 /var/lib/mlocate/mlocate.db 實(shí)現(xiàn)快速的文件查找。 mlocate 程序的權(quán)限如下圖所示:

很明顯,它被設(shè)置了 SGID 權(quán)限。下面是數(shù)據(jù)庫文件 /var/lib/mlocate/mlocate.db 的權(quán)限信息:很明顯,它被設(shè)置了 SGID 權(quán)限。下面是數(shù)據(jù)庫文件 /var/lib/mlocate/mlocate.db 的權(quán)限信息:

普通用戶 tester 執(zhí)行 mlocate 命令時,tester 就會獲得用戶組 mlocate 的執(zhí)行權(quán)限,又由于用戶組 mlocate 對 mlocate.db 具有讀權(quán)限,所以 tester 就可以讀取 mlocate.db 了。程序的執(zhí)行過程如下圖所示:

除二進(jìn)制程序外,SGID 也可以用在目錄上。當(dāng)一個目錄設(shè)置了 SGID 權(quán)限后,它具有如下功能:

  • 用戶若對此目錄具有 r 和 x 權(quán)限,該用戶能夠進(jìn)入該目錄
  • 用戶在此目錄下的有效用戶組將變成該目錄的用戶組
  • 若用戶在此目錄下?lián)碛?w 權(quán)限,則用戶所創(chuàng)建的新文件的用戶組與該目錄的用戶組相同

下面看個例子,創(chuàng)建 testdir 目錄,目錄的權(quán)限設(shè)置如下:

此時目錄 testdir 的 owner 是 nick,所屬的 group 為 tester。

先創(chuàng)建一個名為 nickfile 的文件:

這個文件的權(quán)限看起來沒有什么特別的。然后給 testdir 目錄設(shè)置 SGID 權(quán)限:

$ sudo chmod 2775 testdir

然后再創(chuàng)建一個文件 nickfile2:

新建的文件所屬的組為 tester!

總結(jié)一下,當(dāng) SGID 作用于普通文件時,和 SUID 類似,在執(zhí)行該文件時,用戶將獲得該文件所屬組的權(quán)限。當(dāng) SGID 作用于目錄時,意義就非常重大了。當(dāng)用戶對某一目錄有寫和執(zhí)行權(quán)限時,該用戶就可以在該目錄下建立文件,如果該目錄用 SGID 修飾,則該用戶在這個目錄下建立的文件都是屬于這個目錄所屬的組。

SBIT

其實(shí) SBIT 與 SUID 和 SGID 的關(guān)系并不大。

SBIT 是 the restricted deletion flag or sticky bit 的簡稱。

SBIT 目前只對目錄有效,用來阻止非文件的所有者刪除文件。比較常見的例子就是 /tmp 目錄:

權(quán)限信息中最后一位 t 表明該目錄被設(shè)置了 SBIT 權(quán)限。SBIT 對目錄的作用是:當(dāng)用戶在該目錄下創(chuàng)建新文件或目錄時,僅有自己和 root 才有權(quán)力刪除。

注:SBIT對文件不起作用。

設(shè)置 SUID、SGID、SBIT 權(quán)限

以數(shù)字的方式設(shè)置權(quán)限

SUID、SGID、SBIT 權(quán)限對應(yīng)的數(shù)字如下:

SUID->4
SGID->2
SBIT->1

所以如果要為一個文件權(quán)限為 "-rwxr-xr-x" 的文件設(shè)置 SUID 權(quán)限,需要在原先的 755 前面加上 4,也就是 4755:

$ chmod 4755 filename

同樣,可以用 2 和 1 來設(shè)置 SGID 和 SBIT 權(quán)限。設(shè)置完成后分別會用 s, s, t 代替文件權(quán)限中的 x。

其實(shí),還可能出現(xiàn) S 和 T 的情況。S 和 t 是替代 x 這個權(quán)限的,但是,如果它本身沒有 x 這個權(quán)限,添加 SUID、SGID、SBIT 權(quán)限后就會顯示為大寫 S 或大寫 T。比如我們?yōu)橐粋€權(quán)限為 666 的文件添加 SUID、SGID、SBIT 權(quán)限:

執(zhí)行 chmod 7666 nickfile,因?yàn)?666 表示 "-rw-rw-rw",均沒有 x 權(quán)限,所以最后變成了 "-rwSrwSrwT"。

通過符號類型改變權(quán)限

除了使用數(shù)字來修改權(quán)限,還可以使用符號:

$ chmod u+s testfile # 為 testfile 文件加上 SUID 權(quán)限。
$ chmod g+s testdir # 為 testdir 目錄加上 SGID 權(quán)限。
$ chmod o+t testdir # 為 testdir 目錄加上 SBIT 權(quán)限。

總結(jié)

SUID、SGID、SBIT 權(quán)限都是為了實(shí)現(xiàn)特殊功能而設(shè)計的,其目的是彌補(bǔ) ugo 權(quán)限無法實(shí)現(xiàn)的一些使用場景。

參考:

  • chmod man page
  • setuid-Wikipedia
  • linux中SUID,SGID和SBIT的奇妙用途
  • linux特殊權(quán)限SUID、SGID、SBIT

標(biāo)簽:岳陽 鎮(zhèn)江 臨沂 紅河 烏海 四川 股票

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《Linux中特殊權(quán)限SUID、SGID與SBIT的深入講解》,本文關(guān)鍵詞  Linux,中,特殊,權(quán)限,SUID,SGID,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請?zhí)峁┫嚓P(guān)信息告之我們,我們將及時溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《Linux中特殊權(quán)限SUID、SGID與SBIT的深入講解》相關(guān)的同類信息!
  • 本頁收集關(guān)于Linux中特殊權(quán)限SUID、SGID與SBIT的深入講解的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章
    通城县| 额尔古纳市| 静宁县| 文登市| 应城市| 潍坊市| 长葛市| 梁山县| 潜江市| 宜春市| 江口县| 琼结县| 新丰县| 潜山县| 奉节县| 德安县| 武胜县| 北辰区| 长乐市| 利川市| 琼中| 开鲁县| 苏州市| 滨州市| 呈贡县| 玛曲县| 潼关县| 延吉市| 常宁市| 通河县| 镶黄旗| 甘泉县| 义马市| 长海县| 渭南市| 沂水县| 九龙城区| 天峻县| 奎屯市| 大化| 讷河市|