[Z] Linux下進程的文件訪問權限

原文鏈接:http://blog.csdn.net/chosen0ne/article/details/10581883

?

對進程校驗文件訪問權限包括兩個部分,一是確定進程的角色(屬于哪個用戶或者組),二是確定對應的角色是否具有該操作的權限。

首先看第一部分。默認情況下,進程的有效角色就是當前執行這個進程的用戶及其所在組。但是,文件具有設置用戶ID位和設置組ID位(stat.st_mode的S_ISUID和S_ISGID),用于改變這種默認的行為,將進程的有效角色設置為文件所屬的用戶和組。這主要用于解決執行進程的用戶或組不具備修改這個文件的權限,但卻不得不對文件進行修改的情況。比如,/etc/passwd就是用了設置用戶ID位,因為passwd允許任意用戶修改其密碼,而只有超級用戶才具有對該文件的寫權限,所以在普通用戶執行passwd修改密碼時,必須將設置用戶ID位置位。這里只要記住,進程的角色只能是執行它的用戶或者是它要操作的文件的用戶。

文件的權限包括用戶、組和其他角色的r(讀)、w(寫)和x(執行)。在根據進程角色檢驗權限時,可以分為兩種:文件權限校驗和目錄權限校驗。文件權限校驗比較簡單,在open文件時執行了要對文件進行的操作(O_RDONLY、O_WRONLY和O_RDWR),或者是執行一個文件,只要確定是否具有該權限即可,具體規則后文介紹。目錄也是具有權限的,主要限制其所屬的文件的一些操作,包括:

1. 如果要打開一個文件,必須具有文件路徑中所有目錄的執行權限(即,搜索文件需要目錄的執行權限),比如打開文件/home/work/foo,則必須對/,/home和/home/work三個目錄具有執行權限。

2. 要從一個目錄刪除或者添加一個文件,則必須對這個目錄具有寫權限和執行權限,刪除文件時不需要對該文件具有相關權限。

3. 要獲取一個目錄下所有文件,則需要對該目錄具有讀權限。

在打開、創建和刪除文件時,內核會進行訪問權限的校驗,規則如下:

1. 若進程的有效用戶ID是0(即,超級用戶),則允許訪問。

2. 若進程的有效用戶ID等于文件的所有者ID(即,進程擁有該文件),那么就要檢驗所有者是否具有進行該操作的權限,若具有該權限,則允許,否則拒絕。

3. 若進程的有效組ID是文件的組ID,那么檢驗該組是否具有進行該操作的權限,若具有該權限,則允許,否則拒絕。

4. 執行其他角色的權限檢驗,如果具有該權限,則允許訪問,否則拒絕。

這種測試方式使用的是進程的有效用戶ID和組ID,通過access可以測試進程的實際用戶ID和組ID是否具有該權限。但是只能測試,而不能使用實際角色進行某個文件操作。

在進行創建一個文件時,需要確定這個文件的所有權問題。這個文件的用戶就是進程的有效用戶,而組ID,POSIX允許有兩種實現:

1. 新文件的組ID是進程的有效組ID。

2. 新文件的組ID是它所在目錄的組ID。

轉載于:https://www.cnblogs.com/waytofall/p/3953505.html

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/news/375646.shtml
繁體地址,請注明出處:http://hk.pswp.cn/news/375646.shtml
英文地址,請注明出處:http://en.pswp.cn/news/375646.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

HDU 5371 Manacher Hotaru's problem

求出一個連續子序列,這個子序列由三部分ABC構成,其中AB是回文串,A和C相同,也就是BC也是回文串。 求這樣一個最長的子序列。 Manacher算法是在所有兩個相鄰數字之間插入一個特殊的數字,比如-1, Manacher算法…

MySQL CURDATE() 函數

定義和用法 CURDATE() 函數返回當前的日期。 語法 CURDATE() 實例 例子 1 下面是 SELECT 語句: SELECT NOW(),CURDATE(),CURTIME() 結果類似: NOW()CURDATE()CURTIME()2008-12-29 16:25:462008-12-2916:25:46例子 2 下面的 SQL 創建帶有日期時間列 (Orde…

平庸技術流,用 WebApi +AngularJS 實現網絡爬蟲

最近園子里網絡爬蟲很火爆,從 PHP 到 Python,從 windows服務 到 winform 程序,各路大神各顯神通。小弟也獻下丑,從平庸流出發,簡述下 WebApi AngularJS 方式實現網絡爬蟲。 一、技術框架 1.1 前端: Angular…

linker `cc` not found

運行rustc hello_world.rs時出錯。原因: 我的 gcc 是安裝的指定版本 gcc-4.8,安裝指定版本 gcc 可參考我的另一篇博文,這里找不到 cc 的原因是在移除原來軟鏈的時候,cc 的軟鏈也移除了。重新建立軟鏈即可。 sudo ln -s gcc cc還有…

C# 通過服務啟動窗體(把窗體添加到服務里)實現用戶交互的windows服務[轉發]...

由于個人需要,想找一個鍵盤記錄的程序,從網上下載了很多,多數都是需要注冊的,另外也多被殺軟查殺。于是決定自己寫一個,如果作為一個windows應用程序,可以實現抓取鍵盤的記錄。想要實現隨系統啟動的話&…

error: default argument given for parameter 4

原因&#xff1a;定義函數的時候參數部分有默認值&#xff0c;如下&#xff1a; int classA::print(int a 0) {std::cout << a << std::endl; }分析&#xff1a;聲明函數時參數可以有默認值&#xff0c;定義時不能。

python2.7虛擬環境virtualenv安裝及使用

一 、虛擬環境virtualenv安裝 1. 安裝virtualenv 將Python的目錄添加到系統環境變量后&#xff0c;在命令行輸入&#xff1a; pip install virtualenv C:\Users\heroicai\Desktop>pip install virtualenv2. 建立虛擬環境 在桌面上建立建立一個虛擬環境myenv,輸入:virtualenv…

Io 異常: The Network Adapter could not establish the connection

Io 異常: The Network Adapter could not establish the connection 這個異常的出現一般與數據庫和你的PC的設置有關 這種異常的出現大致上有下面幾種&#xff1a; 1。IP錯誤。 在設置URL時錯誤&#xff0c;例如&#xff1a;jdbc:oracle:thin:192.168.0.36:1521:sharp 數據庫服…

git 刪除tag

git tag -d v1.0如果 tag 已經在遠程分支&#xff0c;還需執行一句git push origin :refs/tags/v1.0另&#xff1a;打 tag 的時候最好加上 description&#xff0c;防止出現未知的錯誤&#xff0c;如 Jenkins 集成的時候生成的包名不對等。

leetcode 的shell部分4道題整理

對shell的某些細節還不是十分熟悉&#xff0c;借鑒了好多別人的東西 1. Word Frequency此題很簡單&#xff0c;只要能排序就可以cat words.txt |tr -s " " "\n" sort | unique -c | sort -r | awk {print $2" "$1}2. Valid Phone Numbers cat …

Mysql操作集錦

mysql安裝成功后可以看到已經存在mysql、information_schema和test這個幾個數據庫&#xff0c;information_schema庫中有一個名為COLUMNS的表&#xff0c;這個表中記錄了數據庫中所有表的字段信息。知道這個表后&#xff0c;獲取任意表的字段就只需要一條select語句即可。 例如…

shadows a parameter

原因&#xff1a;函數內聲明變量與參數名相同。 如&#xff1a; void print(int hello) {int hello;std::cout << hello << std::endl; }解決辦法&#xff1a;改變參數參數名或者局部變量名

iOS 9之WatchKit for WatchOS 2

金田&#xff08;github示例源碼&#xff09; 自AppleWatch發行的同時就可以為AppWatch開發相應的應用程序&#xff0c;不過最初的版本&#xff0c;能開發的功能極為有限&#xff0c;所以也只是有少數的App廠商為Apple定制了App&#xff0c;所以迄今為止&#xff0c;Apple Stor…

創建響應式布局的10款優秀網格工具集錦

在這篇文章中&#xff0c;我們為您呈現了一組優秀的網格工具清單。如果我們錯過了任何沒有列出在這個清單上的東西&#xff0c;請分享給我們。如果網頁設計和開人員采用了正確的工具集&#xff0c;并基于一個靈活的網格架構&#xff0c;以及能夠把響應圖像應用到到設計之中&…

expected initializer before

原因&#xff1a;某個地方缺少分號 如&#xff1a; void print(int a) {int b ///wrong herestd::cout << a << std::endl; }解決&#xff1a;重點排查報錯行前幾行的變量聲明等。

memcpy、memmove、memset、memchr、memcmp、strstr詳解

第一部分  綜述 memcpy、memmove、memset、memchr、memcmp都是C語言中的庫函數&#xff0c;在頭文件string.h中。memcpy和memmove的作用是拷貝一定長度的內存的內容&#xff0c;memset用于緩沖區的填充工作&#xff0c;memchr用于字符的查找工作&#xff0c;memcmp用于比較內…

21分鐘 MySQL 入門教程(轉載)

鏈接&#xff1a;http://www.cnblogs.com/mr-wid/archive/2013/05/09/3068229.html轉載于:https://www.cnblogs.com/hxb316/p/3966731.html

Maven倉庫詳解

轉載自&#xff1a;Maven入門指南④&#xff1a;倉庫 1 . 倉庫簡介 沒有 Maven 時&#xff0c;項目用到的 .jar 文件通常需要拷貝到 /lib 目錄&#xff0c;項目多了&#xff0c;拷貝的文件副本就多了&#xff0c;占用磁盤空間&#xff0c;且難于管理。Maven 使用一個稱之為倉庫…

c++ 從 string 到 short

string test"1234"; short *p reinterpret_cast<short*>(const_cast<char*>(test.c_str()));從 short 到 char * char *q reinterpret_cast<char*>(const_cast<short*>(p));還可以利用 memcpy 這個函數 #include <cstring>short a…

JavaScript02

JavaScript02 如果<head>標簽中包含的外部文件很多&#xff0c;那么這將直接導致頁面展示速度很慢。因為html只有當<body>元素開始之后&#xff0c;才會開始頁面展示動作&#xff0c;因此&#xff0c;最直接的解決辦法就是&#xff0c;將一部分不是頁面加載之后立刻…