簡述Android中SELinux的TE
一、SELinux資源訪問基本概念
SELinux使用類型強(qiáng)制來改進(jìn)強(qiáng)制訪問控制。所有的主體(程序進(jìn)程)對客體(文件/socket等資源)的訪問都有一條TE規(guī)則來許可。當(dāng)程序訪問一個(gè)資源的時(shí)候,系統(tǒng)會(huì)搜索所有的TE規(guī)則集,并根據(jù)結(jié)果進(jìn)行處理。這個(gè)規(guī)則集是由訪問向量規(guī)則(AV, Access Vector)來描述的。
內(nèi)核向外部暴露允許訪問的資源權(quán)限,由TE來描述主體擁有什么樣的訪問權(quán)。SELinux定義了30個(gè)不同的客體類別:
security process system capability filesystem file dir fd lnk_file chr_file blk_file socket_file ...
每個(gè)客體類別都定義了操作許可,比如針對file有19個(gè)操作許可:
ioctl read write create getattr setattr lock relablefrom relableto append unlink link rename execute swapon quotaon mounton execute_no_trans entrypoint
這兩個(gè)內(nèi)容在后面介紹常用語法的時(shí)候會(huì)涉及到。所以對于file的操作許可,我們可以看到基本上是對文件的操作方法,所以程序調(diào)用這些功能的時(shí)候,系統(tǒng)會(huì)檢查是否有一個(gè)TE規(guī)則,授予了該程序權(quán)限來使用該功能。
二、Android中的SELinux
2.1 開啟SELinux
首先必須先開啟SELinux功能,google提供了開啟該選項(xiàng)的開關(guān)。在BoardConfig.mk里面會(huì)定義如下變量:
BOARD_SEPOLICY_DIRS += build/target/board/generic/sepolicy
對應(yīng)路徑下面就會(huì)有很多TE文件來描述進(jìn)程對資源的訪問許可。
2.2 聲明類型
type 類型名稱 type system_app;
2.3 關(guān)聯(lián)類型和屬性
有兩種方法可以將某個(gè)類型跟某個(gè)屬性關(guān)聯(lián)起來。
一,在聲明類型的時(shí)候就關(guān)聯(lián)已經(jīng)定義的屬性。
type system_app, domain;
這個(gè)就在定義system_app的時(shí)候就將它跟已經(jīng)定義的domain屬性關(guān)聯(lián)起來了。
typeattribute platform_app mlstrustedsubject;
如果已經(jīng)定義了類型platform_app,可以用typeattribute將它和已經(jīng)定義的mIstrustedsubject關(guān)聯(lián)起來。
注意:所有的屬性和類型都共用一個(gè)命名空間,所以命名的時(shí)候不要出現(xiàn)同名的屬性和類型哦。
三、訪問向量(AV)規(guī)則
AV用來描述主體對客體的訪問許可。通常有四類AV規(guī)則:
allow:表示允許主體對客體執(zhí)行許可的操作。
neverallow:表示不允許主體對客體執(zhí)行制定的操作。
auditallow: 表示允許操作并記錄訪問決策信息。
dontaudit:表示不記錄違反規(guī)則的決策信息,切違反規(guī)則不影響運(yùn)行
通用的類型規(guī)則語法位:
allow platform_app debugfs:file { read ioctl };
表示類別為platform_app的程序進(jìn)程,對debugfs類型的文件執(zhí)行read和ioctl操作。
四、一些特殊的配置文件:
external/sepolicy/attributes -> 所有定義的attributes都在這個(gè)文件 external/sepolicy/access_vectors -> 對應(yīng)了每一個(gè)class可以被允許執(zhí)行的命令 external/sepolicy/roles -> Android中只定義了一個(gè)role,名字就是r,將r和attribute domain關(guān)聯(lián)起來 external/sepolicy/users -> 其實(shí)是將user與roles進(jìn)行了關(guān)聯(lián),設(shè)置了user的安全級別,s0為最低級是默認(rèn)的級別,mls_systemHigh是最高的級別 external/sepolicy/security_classes -> 指的是上文命令中的class,個(gè)人認(rèn)為這個(gè)class的內(nèi)容是指在android運(yùn)行過程中,程序或者系統(tǒng)可能用到的操作的模塊 external/sepolicy/te_macros -> 系統(tǒng)定義的宏全在te_macros文件 external/sepolicy/*.te -> 一些配置的文件,包含了各種運(yùn)行的規(guī)則
五、selinux有兩種工作模式
“permissive”:所有操作都被允許(即沒有MAC),但是如果有違反權(quán)限的話,會(huì)記錄日志
“enforcing”:所有操作都會(huì)進(jìn)行權(quán)限檢查
六、其他
在te文件中經(jīng)常出現(xiàn)如下的函數(shù):
unix_socket_connect(platform_app, agpsd, mtk_agpsd);
這個(gè)其實(shí)是一個(gè)宏。它定義在文件名為te_macros的文件里面,經(jīng)過全局搜索這個(gè)宏,發(fā)現(xiàn)如下定義:
unix_socket_connect($1, qmuxd, qmux) allow qmux $1_qmuxd_socket:sock_file { getattr unlink }; ')
其實(shí)也是一個(gè)allow訪問向量。
七、總結(jié)
在分析時(shí)時(shí)刻牢記,TE規(guī)則描述的是主體對客體訪問的許可。TE的最小單位是類型,這個(gè)概念抽象了主體和客體。每個(gè)主體對客體執(zhí)行某種許可,都需要有對應(yīng)的av規(guī)則描述,否則就會(huì)失敗。在實(shí)際項(xiàng)目過程中如果碰到相關(guān)的問題,可能就需要修改te文件,編輯相關(guān)的操作許可。
總結(jié)
以上所述是小編給大家介紹的Android中SELinux的TE,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會(huì)及時(shí)回復(fù)大家的。在此也非常感謝大家對腳本之家網(wǎng)站的支持!
相關(guān)文章
Android2.3實(shí)現(xiàn)SD卡與U盤自動(dòng)掛載的方法
這篇文章主要介紹了Android2.3實(shí)現(xiàn)SD卡與U盤自動(dòng)掛載的方法,較為詳細(xì)的分析了Android2.3實(shí)現(xiàn)SD卡與U盤自動(dòng)掛載的具體步驟與相關(guān)技巧,需要的朋友可以參考下2016-02-02Android使用addView動(dòng)態(tài)添加組件的方法
這篇文章主要為大家詳細(xì)介紹了Android使用addView動(dòng)態(tài)添加組件的方法,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2016-09-09Android NestedScrolling嵌套滾動(dòng)的示例代碼
這篇文章主要介紹了Android NestedScrolling嵌套滾動(dòng)的示例代碼,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2018-05-05Jetpack Compose實(shí)現(xiàn)列表和動(dòng)畫效果詳解
這篇文章主要為大家詳細(xì)講講Jetpack Compose實(shí)現(xiàn)列表和動(dòng)畫效果的方法步驟,文中的代碼講解詳細(xì),感興趣的小伙伴可以跟隨小編一起學(xué)習(xí)一下2022-06-06Android Studio 合并module到統(tǒng)一文件夾的方法
這篇文章主要介紹了Android Studio 合并module到統(tǒng)一文件夾的方法,補(bǔ)充介紹了android studio關(guān)于同名資源文件的合并技巧,需要的朋友可以參考下2018-04-04Android實(shí)現(xiàn)應(yīng)用內(nèi)置語言切換功能
這篇文章主要為大家詳細(xì)介紹了Android實(shí)現(xiàn)應(yīng)用內(nèi)置語言切換功能,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2017-02-02