Linux學習歷程——SUID、SGID、SBIT簡介

来源:https://www.cnblogs.com/joe-four/archive/2018/12/21/joe_four_L_03.html
-Advertisement-
Play Games

一、SUID、SGID、SBIT簡介 SUID:對一個可執行文件,不是以發起者身份來獲取資源,而是以可執行文件的屬主身份來執行。SGID:對一個可執行文件,不是以發起者身份來獲取資源,而是以可執行文件的屬組身份來執行。SBIT:粘滯位,通常對目錄而言。通常對於全局可寫目錄(other也可寫)來說,讓 ...


一、SUID、SGID、SBIT簡介

SUID:對一個可執行文件,不是以發起者身份來獲取資源,而是以可執行文件的屬主身份來執行。
SGID:對一個可執行文件,不是以發起者身份來獲取資源,而是以可執行文件的屬組身份來執行。
SBIT:粘滯位,通常對目錄而言。通常對於全局可寫目錄(other也可寫)來說,讓該目錄具有SBIT後,刪除只對屬於自己的文件有效(但是仍能編輯修改別人的文件,除了root的)。不能根據安全上下文獲取對別人的文件的寫許可權。

 

設置方式:
#chmod u+s
#chmod g+s
#chmod o+t

 同上,去除特殊位有: #chmou u-s .等。

SUID:置於 u 的 x 位,原位置有執行許可權,就置為 s,沒有了為 S .
SGID:置於 g 的 x 位,原位置有執行許可權,就置為 s,沒有了為 S .
SBIT : 粘滯位,置於 o 的 x 位,原位置有執行許可權,就置為 t ,否則為T .

表示方法:
將三個特殊位的用八進位數值表示,放於 u/g/o 位之前。其中 suid :4 sgid:2 SBIT:1 例: 對某個目錄:
#chmod 4551 file // 許可權: r-sr-x--x
#chmod 2551 file // 許可權: r-xr-s--x
#chmod 1551 file // 許可權: r-xr-x--t

 

由於SUID和SGID是在執行程式(程式的可執行位被設置)時起作用,而可執行位只對普通文件和目錄文件有意義,所以設置其他種類文件的SUID和SGID位是沒有多大意義的。 對一個屬主為root的可執行文件,如果設置了SUID位,則其他所有普通用戶都將可以以root身份運行該文件,獲取相應的系統資源。當然這在某些場合時需要的,但是濫用會造成系統的安全隱患。 對一個全局可寫目錄,若其從屬於mygrp組,一個屬於mygrp組的用戶建立文件後屬組為自己的私有組,但是加上給該文件夾加上SGID位後,可以讓用戶創建的文件從屬於該目錄所屬的組,因為是以文件夾屬組的身份來創建的。 對於一個全局可寫目錄,加上SBIT位以後,普通用戶將只能刪除自己的文件,而不能刪除其他用戶的文件。
粘著位(sticky)-----tmp目錄
一般來說都是用於目錄
其他用戶可以寫 但是就是不能隨便的刪除。。。。。。
chmod 777 abc
chmod +t abc
等價於   chmod 1777 abc
,即當一個目錄被設置為"粘著位"(用chmod a+t),則該目錄下的文件只能由
一、超級管理員刪除
二、該目錄的所有者刪除
三、該文件的所有者刪除
也就是說,即便該目錄是任何人都可以寫,但也只有文件的屬主才可以刪除文件
UID---4
GID---2
黏貼位-1

 


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • DncZeus 前言 關於 DncZeus DncZeus = Dnc + Zeus "Dnc" .Net Core 的縮寫; "Zeus" 中文譯為 宙斯 ,是古希臘神話中的眾神之王,奧林匹斯十二主神之首,統治宇宙萬物的至高無上的主神(在古希臘神話中主神專指宙斯),人們常用“眾神和人類的父親”、“ ...
  • 本篇我將帶著大家一起來對Dapper進行下封裝並實現基本的增刪改查、分頁操作的同步非同步方法的實現(已實現MSSQL,MySql,PgSQL)。同時我們再實現一下倉儲層的代碼生成器,這樣的話,我們只需要結合業務來實現具體的業務部分的代碼就可以了,可以大大減少我們重覆而又繁瑣的增刪改查操作,多留點時間給 ...
  • Windows -- cmd命令: ipconfig 和 nbtstat ...
  • 本章學習內容: 1.常見符號 2.命令分隔符-分號";" 3.雙分號 ";;" 4. '單引號和"雙引號 5.`反引號和$() 6.${}和$ 7.冒號: 8.()小括弧 9.(())雙括弧 10.{}大括弧 11.[]和[[]]之間的條件測試區別 12.~波浪號 13.延時 14.變數賦值的註意 ...
  • 有的時候我們需要批量創建文件做測試,為了做區分,一般只要稍稍動動文件名即可,MV命令既可以移動文件,也是可以修改文件名的,但批量修改文件名MV做不到,此時,我們可以用rename命令批量修改是蠻不錯的方法,當然也有其他方法的,具體如下: 語法: rename [ -v ] [ -n ] [ -f ] ...
  • 在客戶端向服務端發送http請求時,若返回狀態碼為304 Not Modified 則表明此次請求為條件請求。在請求頭中有兩個請求參數:If-Modified-Since 和 If-None-Match。 當客戶端緩存了目標資源但不確定該緩存資源是否是最新版本的時候, 就會發送一個條件請求。在進行條 ...
  • 最近剛入門SDK編程,在 我終於知道為什麼windowsApi學的人這麼少了 這篇文章中,確實發現了這樣的問題,我的教程使用VS2013->Windows桌面->win32,就誕生了能使用WinMain()的介面的Windows程式。而換成VS2017來編譯,卻發現問題不止這裡 首先,參考某些資料得 ...
  • iostat命令用途:主要用於監控系統設備的IO負載情況,iostat首次運行時顯示自系統啟動開始的各項統計信息,之後運行iostat將顯示自上次運行該命令以後的統計信息。用戶可以通過指定統計的次數和時間來獲得所需的統計信息。iostat有一個弱點,就是它不能對某個進程進行深入分析,僅對系統的整體情 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...