news 2026/5/1 9:49:01

SELinux理论基础

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
SELinux理论基础

SELinux理论基础

SELinux:Security-Enhanced Linux,翻译过来就是 安全增强型 Linux

在 Android 系统中,SELinux 是安全架构的核心部分:

  • 每个应用和系统进程都有特定的安全上下文
  • 通过策略文件(.te 文件)定义访问规则
  • 防止恶意应用或漏洞影响系统安全

如果没有SElinux权限,直接操作:
APK->JNI->底层驱动(app操作设备驱点,read, write),可能会遇到权限问题,打开不了,不能读,不能写等问题, 但是在以前早期的版本,可能对节点chmod a+x /dev/xxx 进行权限的设置,就能访问了。

但是:开机启动中,根据rc文件提供的启动信息, 会启动一些后台进程,可以在进程对应的rc文件中配置让进程开机启动,但是有可能跑不起来, 如果没有配置selinux相关的策略的话,这是因为app运行的时候,检测安全环境。

SELinux 背后的深层设计目标

DAC自主访问控制模型:

这种是比较粗犷的模型,称之为DAC(自主访问,通过chmod修改访问权限。)一个进程如果是超级用户root,它可以访问系统上的所有关联root的资源。

因此我们需要控制访问权限的颗粒,这就可以通过MAC机制(即SEAndroid),
因为SELinux 设计的核心是引入强制访问控制(MAC),而非依赖传统的自主访问控制(DAC)。这一点对于现代系统至关重要,因为 DAC 的设计缺陷在于它允许具有足够权限的用户自由分配访问权,这在攻击者获得管理员权限后可能会造成严重的系统危害。SELinux 则通过预定义的策略,确保即使管理员也不能轻易修改核心文件或服务的访问权限。

比喻:
传统 Linux (DAC) - 像普通的图书馆
想象一个普通的学校图书馆:

学生 = 普通用户 图书管理员 = root/管理员 借书证 = 文件权限(rwx)

工作方式(DAC):

学生甲有借书证(有读取权限),可以借书 学生乙没有借书证(无权限),不能借书 但是:如果学生甲把自己的借书证给学生乙,学生乙就能借书了 更糟糕:如果有人偷了图书管理员的万能卡(成为root),他就能: 借走任何书 修改借阅记录 甚至删除整个图书馆系统 问题: 权限一旦获得,可以随意传递和滥用。

SELinux (MAC) - 像严格管理的军事图书馆
现在想象一个军事学校的绝密资料馆:

  1. 每个房间都有严格规定(安全上下文)
📁 绝密档案室 → 标签:level_top_secret 📁 内部资料室 → 标签:level_internal 📁 公共阅览室 → 标签:level_public
  1. 每个人都有明确身份(进程域)
👨‍✈️ 将军 → 身份:domain_general 👨‍💼 情报官 → 身份:domain_intel 👨‍🎓 普通学员 → 身份:domain_student 👨‍🔧 清洁工 → 身份:domain_cleaner
  1. 详细的访问规则(策略)
# SELinux 策略类似这样: allow domain_general level_top_secret:file {read write}; allow domain_intel level_internal:file {read}; allow domain_student level_public:file {read}; deny domain_cleaner level_top_secret:file *; # 禁止清洁工访问绝密文件

实际场景对比:
场景:清洁工想进绝密档案室
传统图书馆(DAC):

# 清洁工拿到馆长钥匙(成为root) sudo su # 现在是root了! cd /top_secret_room # 可以进去了 cat nuclear_codes.txt # 可以看核密码!

✅ 技术上可行 ❌ 安全灾难

军事图书馆(SELinux):

# 即使清洁工偷了馆长钥匙 sudo su # 身份变成root cd /top_secret_room # 试图进入 # SELinux 检查: # 当前身份:domain_cleaner # 目标房间:level_top_secret # 策略规定:deny domain_cleaner level_top_secret:* ❌ 权限拒绝!即使你是root也不行!

为什么需要这么严格?
想象 Android 手机:

📱 你的微信(普通应用)想:

# 读取你的通讯录 → ✅ 允许(正当功能) # 读取银行app数据 → ❌ 拒绝(隐私泄露) # 修改系统文件 → ❌ 拒绝(系统安全)

🔧 系统更新服务 想:

# 修改系统文件 → ✅ 允许(本职工作) # 读取你的照片 → ❌ 拒绝(越权)

没有 SELinux:一个被黑的微信可能:

提权到root 读取所有app数据 安装后门 完全控制你的手机

有 SELinux:即使微信被黑:

它还是 wechat_domain 身份 SELinux 说:"wechat身份不能做这些事" 攻击被限制在微信自己的沙箱里

MAC访问控制框架模型
这里的MAC模型,是基于前面的DAC模型的,同样也拥有用户类型,uid和gid的概念。

主体:一般指的是活动的进程
客体:有普通文件,虚拟文件,属性文件,服务service和app
te文件:一般用于描述主体对客体的一套动作行为,就是一种逻辑性的行为描述。
比如:信息部的张经理,允许对员工具有分配系统的xxx权限,这类描述就是te文件中的明文规定,描述了一种主体对客体访问的规章制度。

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/26 3:39:18

【算法题】滑动窗口(一)

滑动窗口是处理子串/子数组问题的经典双指针技巧,核心是通过维护一个“窗口”(左右指针界定的区间),动态调整窗口范围来满足题目条件,从而高效求解问题。 一、无重复字符的最长子串 题目描述: 给定一个字符…

作者头像 李华
网站建设 2026/4/18 10:55:58

Office Tool Plus v10.29.50 office安装激活一条龙

🔞简介:Office Tool Plus是一款相当牛逼的office安装工具,并且安装完了顺带激活,也可以很快捷的卸载office清除激活信息等等。下载最新的office2016免去那么多的麻烦,反方便~【下载地址】:链接:https://dri…

作者头像 李华
网站建设 2026/4/30 23:56:44

锁、互斥、阻塞、自旋、CAS、可见性

今天的目标是:从 OS 视角理解“为什么必须有锁”、“为什么会出现竞态”、“锁为什么能解决”、“CAS 的本质是什么”。这一层是并发编程最容易混乱的地方,因为它跨越:OS 调度(Day3)CPU 缓存一致性(你之前学…

作者头像 李华
网站建设 2026/4/25 8:50:30

Pr 如何批量修改字幕?字体、大小统一调整的方法来了!

在剪辑圈里,统一字幕样式一直是让人头疼的环节。 很多专业剪辑师都吐槽:明明只是几十条字幕,结果改字体、调字号、调描边、调位置……每一个都得点开单独修改。遇到访谈类、讲解类视频,字幕数量动不动上百条,效率直接被…

作者头像 李华
网站建设 2026/5/1 6:54:07

基于java的SpringBoot/SSM+Vue+uniapp的篮球管理系统的详细设计和实现(源码+lw+部署文档+讲解等)

文章目录前言详细视频演示具体实现截图技术栈后端框架SpringBoot前端框架Vue持久层框架MyBaitsPlus系统测试系统测试目的系统功能测试系统测试结论为什么选择我代码参考数据库参考源码获取前言 🌞博主介绍:✌全网粉丝15W,CSDN特邀作者、211毕业、高级全…

作者头像 李华
网站建设 2026/5/1 9:30:45

TinyMCE4支持信创系统word粘贴兼容

企业级文档导入与粘贴方案设计 项目需求分析 作为四川某国企项目负责人,我们面临着企业网站后台管理系统升级的需求,具体需要实现以下功能: Word粘贴功能:支持从Word复制内容粘贴到网站编辑器,自动上传图片Word文档…

作者头像 李华