Android讀寫權限分析

Android系統使用的是Linux內核,所以Android系統沿用了linux系統的那一套文件讀寫權限。

目錄

  • 1,權限解讀
    • 1.1,權限分為三種類型:
    • 1.2,權限針對的三類對象:
    • 1.3,文件和目錄的權限區別
      • 1.3.1,對于文件
      • 1.3.2,對于目錄
    • 1.4,權限查看實例
      • 1.4.1,文件類型和權限信息
      • 1.4.2,鏈接數
      • 1.4.3,所有者
      • 1.4.4,所屬組
      • 1.4.5,文件大小
      • 1.4.6,時間戳
      • 1.4.7,文件名
  • 2,權限操作
    • 2.1,指令修改
      • 2.1.1,方法一
      • 2.1.2,方法二
      • 2.1.3,方法三
      • 2.1.4,目錄遞歸賦權限
    • 2.2,代碼修改
      • 2.2.1,Java層實現
      • 2.2.2,C++層實現

1,權限解讀

在Linux系統中,讀寫權限是用來控制用戶對文件或目錄的訪問權限的一種機制。按照用戶與組進行分類,針對不同的群體進行了權限管理,用他來確定誰能通過何種方式對文件或目錄進行訪問和操作。
在這里插入圖片描述
上面的這張圖,涉及到一個文件linux權限的基本信息,包括文件類型、文件權限、以及對應的用戶組等信息。

1.1,權限分為三種類型:

Read,讀權限,縮寫r
Write,寫權限,縮寫w
Execute,執行權限,縮寫x
另,root用戶不受文件權限的讀寫權限限制,但執行權限也會受限制。

1.2,權限針對的三類對象:

owner,文件所屬主,縮寫u
group,用戶所屬組,縮寫g
other,其他不相關用戶,縮寫o

1.3,文件和目錄的權限區別

對于文件和目錄,r、w、x有著稍微不同的作用和含義:

1.3.1,對于文件

r:代表可讀(read),可以讀取、查看;
w:代表可寫(write), 可以修改,但是不代表可以刪除該文件,刪除一個文件的前提條件是對該文件所在的目錄有寫權限,才能刪除該文件;
x:代表可執行(execute),可以被執行;

1.3.2,對于目錄

r:代表可讀(read),可以讀取,ls 查看目錄內容;
w:代表可寫(write),可以修改,對目錄內創建+刪除+重命名目錄;
x:代表可執行(execute),可以進入該目錄;

1.4,權限查看實例

adb登錄android系統,通過ls -l查看,如果是linux系統,也可以 ll指令查看。

mt2712_saic_as33:/data/testrwx # ls -l
total 1724
-rw-r--r-- 1 root root 1759120 2024-11-25 12:42 adbd
lrwxrwxrwx 1 root root      17 2019-01-01 00:08 linktest -> data/testlink.txt
drwxrwxrwx 2 root root    4096 2019-01-01 00:33 testdir1
mt2712_saic_as33:/data/testrwx #

上面查詢到的信息,一共分為7列。

1.4.1,文件類型和權限信息

第一列,第一個字符表示的是文件類型,其可能是普通文件、目錄、符號鏈接等,可能的值如下:
-:普通文件,如上面的adbd文件的信息中,一個字符就是-
d:目錄
l:符號鏈接
b:塊設備文件
c:字符設備文件
s:套接字文件
p:命令管道文件
其余的字符分為三組,每組三個字符,分別代表文件所有者的權限、組內其他用戶的權限和其他用戶的權限。每組字符的含義如下:
r:可讀權限(4)
w:可寫權限(2)
x:可執行權限(1)
-:無權限(0)
整理第一列的權限表示如下表格式:
在這里插入圖片描述
如前面adbd文件的權限為-rw-r–r–,參照上面的表,解讀為adbd是個文件,所有者對這個文件可讀可寫不可執行,所屬組用戶對文件可讀不可寫不可執行,其他用戶也對此文件可讀不可寫不可執行。
如果用數字來表示adbd文件權限,二進制應該為110100100,十進制應該為644。

1.4.2,鏈接數

這一列顯示了文件的硬鏈接數。對于目錄,這一列顯示了目錄下的子目錄數。如果是普通文件,這一列顯示為-。

1.4.3,所有者

這一列顯示了文件的所有者用戶名,如上面截圖里的實際情況,為root用戶,因為本人是root后adb登錄創建的文件。

1.4.4,所屬組

這一列顯示了文件所屬的用戶組名稱,如上面截圖里的實際情況,為root組,因為本人是root后adb登錄創建的文件。

1.4.5,文件大小

這一列顯示了文件的大小,以字節為單位。對于目錄,這一列顯示為4096,為啥是4096呢??因為在 Linux/Android 系統中,?目錄本身是一種特殊類型的文件?,它存儲的是目錄條目,系統會給目錄分配固定大小的塊(block),而默認block大小就是4096字節。

1.4.6,時間戳

這一列顯示了文件的最后修改時間或最后訪問時間,分為年月日和時分秒。具體顯示的日期和時間取決于系統的配置和語言環境。

1.4.7,文件名

這一列顯示了文件的名稱。

2,權限操作

可以通過chmod指令來修改文件權限,或者也可以通過代碼來修改。

2.1,指令修改

使用chmod指令修改,指令格式:chmod [選項] <文件名>
以如下adbd文件為例,修改前權限為:

mt2712_saic_as33:/data/testrwx # ls -l
total 1724
-rw-r--r-- 1 root root 1759120 2024-11-25 12:42 adbd
lrwxrwxrwx 1 root root      17 2019-01-01 00:08 linktest -> data/testlink.txt
drwxrwxrwx 2 root root    4096 2019-01-01 00:33 testdir1
mt2712_saic_as33:/data/testrwx #

有幾種修改方式,如下。

2.1.1,方法一

示例執行指令chmod 776 adbd

mt2712_saic_as33:/data/testrwx # chmod 776 adbd
mt2712_saic_as33:/data/testrwx # ls -l
total 1724
-rwxrwxrw- 1 root root 1759120 2024-11-25 12:42 adbd
lrwxrwxrwx 1 root root      17 2019-01-01 00:08 linktest -> data/testlink.txt
drwxrwxrwx 2 root root    4096 2019-01-01 00:33 testdir1
mt2712_saic_as33:/data/testrwx #

可以看到adbd文件由-rw-r–r–變成了-rwxrwxrw-

2.1.2,方法二

上面是用776數字的方式來表示rwxrwxrw-權限,也可以不用數字而是直接用rwx方式來表示,示例如

mt2712_saic_as33:/data/testrwx # chmod u=rwx,g=rw,o=r adbd
mt2712_saic_as33:/data/testrwx # ls -l
total 1724
-rwxrw-r-- 1 root root 1759120 2024-11-25 12:42 adbd
lrwxrwxrwx 1 root root      17 2019-01-01 00:08 linktest -> data/testlink.txt
drwxrwxrwx 2 root root    4096 2019-01-01 00:33 testdir1
mt2712_saic_as33:/data/testrwx #

在執行chmod u=rwx,g=rw,o=r adbd指令后,adbd權限就變成了rwxrw-r–

文件權限的值可以通過字符也可以通過數字來表示,示例如下:
字符:rwx rw- r--
數字:111 110 1007    6   4

2.1.3,方法三

指令格式:chmod [who opt per] file
這里的who、opt、per可能的值分別為:

  who:u g o a  //u表示文件所有者,g表示與文件所有者屬于同一組的其他用戶,o表示其他用戶opt:+=	// + 、-、= 變更權限,+是增加,-是除去,=相同per:r w x X	//讀、寫、執行

示例如下

mt2712_saic_as33:/data/testrwx # ls -l
total 1724
-rwxrw-r-- 1 root root 1759120 2024-11-25 12:42 adbd
lrwxrwxrwx 1 root root      17 2019-01-01 00:08 linktest -> data/testlink.txt
drwxrwxrwx 2 root root    4096 2019-01-01 00:33 testdir1
mt2712_saic_as33:/data/testrwx # chmod o+w adbd
mt2712_saic_as33:/data/testrwx #
mt2712_saic_as33:/data/testrwx #
mt2712_saic_as33:/data/testrwx # ls -l
total 1724
-rwxrw-rw- 1 root root 1759120 2024-11-25 12:42 adbd
lrwxrwxrwx 1 root root      17 2019-01-01 00:08 linktest -> data/testlink.txt
drwxrwxrwx 2 root root    4096 2019-01-01 00:33 testdir1
mt2712_saic_as33:/data/testrwx #

這里的chmod o+w adbd,是指給文件adbd文件的other用戶添加w寫權限,所以權限從rwxrw-r–變成了rwxrw-rw-。

2.1.4,目錄遞歸賦權限

上面介紹的一直是文件的權限,對于目錄的權限也是一樣的操作方式,對于目錄-R是常用的一個參數,用于目錄遞歸賦值權限。
示例,testdir1目錄下還有個子目錄testdir2目錄,通過chmod -R XXX 目錄,遞歸賦值權限

mt2712_saic_as33:/data/testrwx/testdir1 # ls -l
total 4
drw-rw---- 2 root root 4096 2019-01-01 01:56 testdir2 	//子目錄testdir2原始權限為660
mt2712_saic_as33:/data/testrwx # chmod -R 766 testdir1	//對testdir1以及其子目錄都賦值766權限
mt2712_saic_as33:/data/testrwx # ls -l
total 1724
-rwxrw-rw- 1 root root 1759120 2024-11-25 12:42 adbd
lrwxrwxrwx 1 root root      17 2019-01-01 00:08 linktest -> data/testlink.txt
drwxrw-rw- 3 root root    4096 2019-01-01 01:56 testdir1
mt2712_saic_as33:/data/testrwx # cd testdir1/
mt2712_saic_as33:/data/testrwx/testdir1 # ls -l
total 4
drwxrw-rw- 2 root root 4096 2019-01-01 01:56 testdir2	子目錄testdir2修改后權限為766
mt2712_saic_as33:/data/testrwx/testdir1 #

2.2,代碼修改

2.2.1,Java層實現

因為是對系統得文件做操作,可能會遇到操作權限得問題,比如permission權限和selinux,這些根據實際使用時報錯來定位解決。java層實現方式如下所示:

	try {String command = "chmod 777 " + destFile.getAbsolutePath();Log.i("test", "command = " + command);Runtime runtime = Runtime.getRuntime(); Process proc = runtime.exec(command);} catch (IOException e) {Log.i("test","chmod fail!!!!");e.printStackTrace();}

或者

File file = new File(context.getFilesDir(), "example.txt");
// 設置可讀權限(所有者、組、其他用戶)
boolean isReadable = file.setReadable(true, false); // 參數2: 是否遞歸子項(僅限目錄)
// 設置可寫權限
boolean isWritable = file.setWritable(true, false);
// 設置可執行權限(通常用于腳本文件)
boolean isExecutable = file.setExecutable(true, false);

2.2.2,C++層實現

通過系統方法chmod(file,mode)修改文件權限,首先你這個服務得有權限修改這個文件,這個操作可能會遇到selinux權限問題。

...
#include <sys/stat.h>//頭文件
...
int changeFileRWX(const char* file_path, mode_t mode) {...int result = chmod(file_path, (mode_t) mode); //需要文件路徑和所需權限即可...
}

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

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

相關文章

Python二分查找【清晰易懂】

1. 二分查找是什么&#xff1f; 想象你在玩“猜數字”游戲&#xff1a; 對方心里想一個 1~100 的數字&#xff0c;你每次猜一個數&#xff0c;對方會告訴你是“大了”還是“小了”。 最快的方法&#xff1a;每次都猜中間的數&#xff01;比如第一次猜50&#xff0c;如果大了&…

關于Qt的各類問題

目錄 1、問題&#xff1a;Qt中文亂碼 2、問題&#xff1a;啟動時避免ComBox控件出現默認值 博客會不定期的更新各種Qt開發的Bug與解決方法,敬請關注! 1、問題&#xff1a;Qt中文亂碼 問題描述&#xff1a;我在設置標題時出現了中文亂碼 this->setWindowTitle("算法…

關于我對接了deepseek之后部署到本地將數據存儲到mysql的過程

寫在前面 今天寫一下使用nodejs作為服務端&#xff0c;vue作為客戶端&#xff0c;mysql的數據庫&#xff0c;對接deepseek的全過程&#xff0c;要實現一個很簡單的效果就是&#xff0c;可以自由的詢問&#xff0c;然后可以將詢問的過程存儲到mysql的數據庫中。 文檔對接 deeps…

游戲引擎學習第182天

回顧和今天的計劃 昨天的進展令人驚喜&#xff0c;原本的調試系統已經被一個新的系統完全替換&#xff0c;新系統不僅能完成原有的所有功能&#xff0c;還能捕獲完整的調試信息&#xff0c;包括時間戳等關鍵數據。這次的替換非常順利&#xff0c;效果很好。 今天的重點是在此基…

CSS終極指南:從基礎到高級實踐

目錄 一、CSS基礎概念與核心語法 1.1 CSS的本質與作用 1.2 CSS語法結構 二、CSS與HTML結合的四種方式 2.1 內聯樣式&#xff08;Inline Style&#xff09; 2.2 內部樣式表&#xff08;Internal Style Sheet&#xff09; 2.3 外部樣式表&#xff08;External Style Sheet…

MATLAB 2024b深度學習新特性全面解析與DeepSeek大模型集成開發

MATLAB 2024b深度學習工具箱通過架構創新與功能強化&#xff0c;為科研創新和行業應用提供了全棧式解決方案。 第一&#xff1a;MATLAB 2024b深度學習工具箱新特性 1、MATLAB Deep Learning Toolbox 2、實時腳本&#xff08;Live Script&#xff09;與交互控件&#xff08…

.NET開源的智能體相關項目推薦

一、AntSK 由AIDotNet團隊開發的人工智能知識庫與智能體框架&#xff0c;支持多模型集成和離線部署能力。 核心能力&#xff1a; ? 支持OpenAI、Azure OpenAI、星火、阿里靈積等主流大模型&#xff0c;以及20余種國產數據庫&#xff08;如達夢&#xff09; ? 內置語義內核&a…

Qt彈出新窗口并關閉(一個按鈕)

參考&#xff1a;Qt基礎 練習&#xff1a;彈出新窗口并關閉的兩種實現方式&#xff08;兩個按鈕、一個按鈕&#xff09;_qt打開一個窗口另一個關閉-CSDN博客 實現&#xff1a; 一個按鈕&#xff0c;點擊一次&#xff0c;按鈕的名字從open window變為close window&#xff0c;…

PHP中yield關鍵字的使用

PHP版本>5.5 原理&#xff1a;yield關鍵字會生成一個Generator類的對象&#xff0c;PHP通過Generator實例計算出下一次迭代的值&#xff0c;再次返回一個Generator對象并停止循環&#xff08;即循環一次執行一次&#xff09;。 理解&#xff1a;使用在for/foreach/while循…

SpringBoot集成騰訊云OCR實現身份證識別

OCR身份證識別 官網地址&#xff1a;https://cloud.tencent.com/document/product/866/33524 身份信息認證&#xff08;二要素核驗&#xff09; 官網地址&#xff1a;https://cloud.tencent.com/document/product/1007/33188 代碼實現 引入依賴 <dependency><…

Tabby 一:如何在Mac配置保姆級教程(本地模型替換hugging face下載)

1. brew安裝 mac需要先安裝brew&#xff0c;如果本地已經安裝過brew這一步可以忽略&#xff0c;遇到問題可以自己ai問 /bin/bash -c "$(curl -fsSL https://gitee.com/cunkai/HomebrewCN/raw/master/Homebrew.sh)" 可能遇到source .zprofile失敗&#xff0c;因為…

C++中使用CopyFromRecordset將記錄集拷貝到excel中時,如果記錄集為0個,函數崩潰,是什么原因

文章目錄 原因分析解決方案1. 檢查記錄集是否為空2. 安全調用COM方法3.進行異常捕獲4. 替代方案&#xff1a;手動處理空數據 總結 在C中使用CopyFromRecordset將空記錄集&#xff08;0條記錄&#xff09;復制到Excel時崩潰的原因及解決方法如下&#xff1a; 原因分析 空記錄集…

【算法學習計劃】貪心算法(上)

目錄 前言&#xff08;什么是貪心&#xff09; leetcode 860.檸檬水找零 leetcode 2208.將數組和減半的最少操作次數 leetcode 179.最大數 leetcode 376.擺動序列 leetcode 300.最長遞增子序列 leetcode 334.遞增的三元子序列 leetcode 674.最長連續遞增序列 leetcode …

PC名詞解釋-筆記本的S0,S1,S2,S3,S4,S5狀態

?&#x1f393;作者簡介&#xff1a;程序員轉項目管理領域優質創作者 &#x1f48c;個人郵箱&#xff1a;[2707492172qq.com] &#x1f310;PMP資料導航&#xff1a;PM菜鳥&#xff08;查閱PMP大綱考點&#xff09; &#x1f4a1;座右銘&#xff1a;上善若水&#xff0c;水善利…

可以把后端的api理解為一個目錄地址,但并不準確

將后端的 API 理解為一個“目錄地址”是可以的&#xff0c;但并不完全準確。讓我們更詳細地解釋一下。 目錄 1、生動形象了解api 2、后端 API 的作用 3、可以將 API 理解為“目錄地址”的原因 &#xff08;1&#xff09;URL 路徑 &#xff08;2&#xff09;層次結構 4、…

Elasticsearch:使用 AI SDK 和 Elastic 構建 AI 代理

作者&#xff1a;來自 Elastic Carly Richmond 你是否經常聽到 AI 代理&#xff08;AI agents&#xff09;這個詞&#xff0c;但不太確定它們是什么&#xff0c;或者如何在 TypeScript&#xff08;或 JavaScript&#xff09;中構建一個&#xff1f;跟我一起深入了解 AI 代理的概…

5G智慧工廠專網部署:IPLOOK助力制造業數字化轉型

5G專網 隨著工業4.0時代的到來&#xff0c;制造業對高效、低延遲和智能化網絡的需求日益增長。5G專網憑借其高速率、低時延和大連接特性&#xff0c;成為智慧工廠數字化轉型的重要支撐。IPLOOK作為全球領先的移動核心網解決方案提供商&#xff0c;基于自身強大的5G核心網產品和…

第六屆 藍橋杯 嵌入式 省賽

參考 第六屆藍橋杯嵌入式省賽程序設計題解析&#xff08;基于HAL庫&#xff09;_藍橋杯嵌入式第六屆真題-CSDN博客 一、分析功能 RTC 定時 1&#xff09;時間初始化 2&#xff09;定時上報電壓時間 ADC測量 采集電位器的輸出電壓信號。 串行功能 1&#xff09;傳送要設置…

第十二篇《火攻篇》:一把火背后的戰爭哲學與生存智慧

《孫子兵法》作為人類歷史上最早的軍事戰略經典&#xff0c;其思想穿透了2500年的時空&#xff0c;至今仍在政治、商業乃至個人決策領域閃耀光芒。第十二篇《火攻篇》看似聚焦于具體的戰術手段&#xff0c;實則蘊含了深刻的戰爭倫理與生存哲學。本文解讀這一篇章如何用一把火點…

word光標一直閃的解決辦法

在選項里&#xff0c;打開首選項&#xff0c;&#xff08;如果打不開&#xff0c;可以新建一個word也許就可以&#xff0c;實在不行只能靠眼疾手快&#xff0c;趁他還沒閃趕緊點&#xff09; 選COM加載項&#xff0c;在里面取消勾選MicrosoftOfficePLUS