Linux中特殊權限SUID、SGID與SBIT的示例分析

小編給大家分享一下Linux中特殊權限SUID、SGID與SBIT的示例分析,相信大部分人都還不怎么了解,因此分享這篇文章給大家參考一下,希望大家閱讀完這篇文章后大有收獲,下面讓我們一起去了解一下吧!

創(chuàng)新互聯公司專注于聊城網站建設服務及定制,我們擁有豐富的企業(yè)做網站經驗。 熱誠為您提供聊城營銷型網站建設,聊城網站制作、聊城網頁設計、聊城網站官網定制、微信小程序定制開發(fā)服務,打造聊城網絡公司原創(chuàng)品牌,更為您提供聊城網站排名全網營銷落地服務。

前言

對于linux中文件或目錄的權限,應該都知道普通的rwx權限,我們先看看下面兩個的權限是什么

Linux中特殊權限SUID、SGID與SBIT的示例分析

Linux中特殊權限SUID、SGID與SBIT的示例分析

非常奇怪,/tmp目錄和 passwd文件的權限怎么怪怪的,怎么有s和t權限呢。看了下面的內容你就明白了。

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

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

SUID

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

Linux中特殊權限SUID、SGID與SBIT的示例分析

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

Linux中特殊權限SUID、SGID與SBIT的示例分析

上圖紅框中的權限信息有些奇怪,owner 的信息為 rws 而不是 rwx。當 s 出現在文件擁有者的 x 權限上時,就被稱為 SETUID BITS 或 SETUID ,其特點如下:

  • SUID 權限僅對二進制可執(zhí)行文件有效

  • 如果執(zhí)行者對于該二進制可執(zhí)行文件具有 x 的權限,執(zhí)行者將具有該文件的所有者的權限

  • 本權限僅在執(zhí)行該二進制可執(zhí)行文件的過程中有效

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

  • tester 用戶對于 /usr/bin/passwd 這個程序具有執(zhí)行權限,因此可以執(zhí)行

  • passwd 程序passwd 程序的所有者為 root

  • tester 用戶執(zhí)行 passwd 程序的過程中會暫時獲得 root 權限

  • 因此 tester 用戶在執(zhí)行 passwd 程序的過程中可以修改 /etc/shadow 文件

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

Linux中特殊權限SUID、SGID與SBIT的示例分析

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

Linux中特殊權限SUID、SGID與SBIT的示例分析

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

$ sudo chmod 4755 /bin/cat

Linux中特殊權限SUID、SGID與SBIT的示例分析

現在 cat 已經具有了 SUID 權限,試試看,是不是已經可以 cat 到 /etc/shadow 的內容了。因為這樣做非常不安全,所以趕快通過下面的命令把 cat 的 SUID 權限移除掉:

$ sudo chmod 755 /bin/cat

SGID

當 s 標志出現在用戶組的 x 權限時稱為 SGID。SGID 的特點與 SUID 相同,我們通過 /usr/bin/mlocate 程序來演示其用法。mlocate 程序通過查詢數據庫文件 /var/lib/mlocate/mlocate.db 實現快速的文件查找。 mlocate 程序的權限如下圖所示:

Linux中特殊權限SUID、SGID與SBIT的示例分析

很明顯,它被設置了 SGID 權限。下面是數據庫文件 /var/lib/mlocate/mlocate.db 的權限信息:很明顯,它被設置了 SGID 權限。下面是數據庫文件 /var/lib/mlocate/mlocate.db 的權限信息:

Linux中特殊權限SUID、SGID與SBIT的示例分析

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

Linux中特殊權限SUID、SGID與SBIT的示例分析

除二進制程序外,SGID 也可以用在目錄上。當一個目錄設置了 SGID 權限后,它具有如下功能:

  • 用戶若對此目錄具有 r 和 x 權限,該用戶能夠進入該目錄

  • 用戶在此目錄下的有效用戶組將變成該目錄的用戶組

  • 若用戶在此目錄下擁有 w 權限,則用戶所創(chuàng)建的新文件的用戶組與該目錄的用戶組相同

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

Linux中特殊權限SUID、SGID與SBIT的示例分析

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

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

Linux中特殊權限SUID、SGID與SBIT的示例分析

這個文件的權限看起來沒有什么特別的。然后給 testdir 目錄設置 SGID 權限:

$ sudo chmod 2775 testdir

Linux中特殊權限SUID、SGID與SBIT的示例分析

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

Linux中特殊權限SUID、SGID與SBIT的示例分析

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

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

SBIT

其實 SBIT 與 SUID 和 SGID 的關系并不大。

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

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

Linux中特殊權限SUID、SGID與SBIT的示例分析

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

注:SBIT對文件不起作用。

設置 SUID、SGID、SBIT 權限

以數字的方式設置權限

SUID、SGID、SBIT 權限對應的數字如下:

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

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

$ chmod 4755 filename

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

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

Linux中特殊權限SUID、SGID與SBIT的示例分析

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

通過符號類型改變權限

除了使用數字來修改權限,還可以使用符號:

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

以上是“Linux中特殊權限SUID、SGID與SBIT的示例分析”這篇文章的所有內容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內容對大家有所幫助,如果還想學習更多知識,歡迎關注創(chuàng)新互聯行業(yè)資訊頻道!

新聞名稱:Linux中特殊權限SUID、SGID與SBIT的示例分析
URL標題:http://m.kartarina.com/article2/pippic.html

成都網站建設公司_創(chuàng)新互聯,為您提供ChatGPT用戶體驗面包屑導航Google網站收錄搜索引擎優(yōu)化

廣告

聲明:本網站發(fā)布的內容(圖片、視頻和文字)以用戶投稿、用戶轉載內容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網站立場,如需處理請聯系客服。電話:028-86922220;郵箱:631063699@qq.com。內容未經允許不得轉載,或轉載時需注明來源: 創(chuàng)新互聯

成都定制網站建設
主站蜘蛛池模板: 亚洲av无码专区国产不乱码| 亚洲av无码久久忘忧草| 无码专区国产精品视频| 无码八A片人妻少妇久久| 亚洲中文字幕久久精品无码2021| 日韩成人无码一区二区三区| 精品无码人妻久久久久久| 国产精品无码v在线观看| 中文无码精品A∨在线观看不卡| 西西4444www大胆无码| 人妻丰满av无码中文字幕| 成人毛片无码一区二区| 精品人无码一区二区三区| 久久影院午夜理论片无码| 久久久久久亚洲精品无码| 无码AV波多野结衣久久| 亚洲av无码乱码在线观看野外| 精品无码av一区二区三区| 性无码专区无码片| 亚洲国产精品无码久久久秋霞2| 亚洲AV无码一区二区三区鸳鸯影院| 少妇伦子伦精品无码STYLES| 精品人妻无码专区中文字幕| 精品久久久久久中文字幕无码 | 亚洲日韩欧洲无码av夜夜摸| 无码人妻精品一区二区三区9厂| 久久水蜜桃亚洲av无码精品麻豆| 亚洲AV永久无码精品一区二区国产| 在线观看无码AV网址| 精品无码一区在线观看| 亚洲成AV人片在线播放无码| 国产综合无码一区二区三区| 伊人久久无码精品中文字幕| 爆乳无码AV一区二区三区| 亚洲AV无码一区二区一二区| 亚洲日韩看片无码电影| 精品久久无码中文字幕| 无码人妻一区二区三区免费手机| 欧洲成人午夜精品无码区久久| 无码人妻精品一区二区在线视频| 色综合久久无码五十路人妻|