当前位置: 首页 > news >正文

SElinux策略文件配置

SElinux策略文件配置

经过前面的一大堆理论的学习,我们知道,还需要编写相关的规则文件,才能通过 SElinux 的检测

Selinux权限配置及安全上下文文件目录:

编译selinux_policy

所以在device下搜索emulator_x86_64的关键字,因为device是产品配置相关的目录:

上面导入的是build/make/target/board/emulator_x86_64/BoardConfig.mk,于是需要在这个文件中配置sepolicy所在的路径,这样系统可以将其加入编译到selinux_policy


编译


编译后会得到两个结果
第一个:上下文标签
第二个:编译后的二进制策略文件precompiled_sepolicy
但是,这个文件是放在哪个目录下呢:请用以下指令搜索

dzz@ubuntu:~/aosp/out/target/product/emulator_x86_64$ find . -name "precompiled_sepolicy" ./obj/ETC/precompiled_sepolicy_intermediates/precompiled_sepolicy ./vendor/etc/selinux/precompiled_sepolicy dzz@ubuntu:~/aosp/out/target/product/emulator_x86_64$

可以得到的是./vendor/etc/selinux/precompiled_sepolicy

避免遗漏,把整个 selinux 文件push 到android 模拟器上面就好

调试

查看sedemo_dev设备文件的上下文标签

ls -laZ /dev/sedemo_dev_dzz


为什么不是前面定义的标签?(sedemo_dev_dzz_t)



显然,通过restorecon切换,上下文标签已经是我们定义的了

但是这样麻烦,我们期望他能自己切换域;添加一句即可

domain_auto_trans(shell, sedemo_dt_exec, sedemo_dt)

因为切换进程域的时候,如果是由shell指令去切换,将切换成对应的sedemo_dt这个域,sedemo_dt_exec是类型
然后继续编译:

make selinux_policy -j16

然后重复上面的push:

adb push out/target/product/emulator_x86_64/vendor/etc/selinux /vendor/etc/

重启设备,让系统根据file_contexts的内容自动打标签:

adb reboot

运行

//如果不是宽容模式,先切换到宽容模式(为方便调试) setenforce 0 touch /dev/sedemo_dev_dzz restorecon /dev/sedemo_dev_dzz ls -lZ /dev/sedemo_dev_dzz ls -lZ /vendor/bin/sedemo_dzz

开两个终端,左边抓log ,右边运行,先在宽容模式下调试logcat | grep "avc" | grep -E "sedemo_dzz|sedemo"


做到之后,使用 audit2allow 转换为 allow

先安装audit2allow sudo apt install policycoreutils-python-utils 屏蔽以下4个语句 : sudo vim /usr/bin/audit2allow //打开文件,屏蔽以下几行 350 self.__parse_options() |~ 351 #if self.__options.policy: |~ 352 # audit2why.init(self.__options.policy) |~ 353 #else: |~ 354 # audit2why.init() 转换成te策略: audit2allow -i avc.txt > hello.te


运行转换后的结果

加到te 文件,重新编译

make selinux_policy -j16
adb reboot

重启完成后,就可以使用强制模式执行了

setenforce 1 //切换到强制模式 getenforce runcon u:r:sedemo_dt:s0 /vendor/bin/sedemo_dzz


可以看到代码中的死循环没有退出,另一个终端,也能看到文件写入的内容了

http://www.cnnetsun.cn/news/28472.html

相关文章:

  • 瑞士发布国家级开源大模型Apertus:AI公共基础设施的全球新范式
  • 2025年AI推理里程碑:Inclusion AI开源万亿参数模型Ring-1T,数学推理性能跃升14%
  • 5、内核调试技术全解析
  • 8、Linux内核中的时间处理、延迟与异步工作调度
  • 10、与硬件通信:I/O端口和内存的使用指南
  • 17、Linux 块设备驱动开发全面解析
  • 20、Linux内核开发资源与技术要点解析
  • 29、Linux系统启动与电源管理全解析
  • 32、深入理解进程与线程
  • 45、基于IP地址十六进制表示创建软件密钥及任意进制转换脚本
  • 中文跨模态里程碑:Chinese-CLIP-ViT-Base-Patch16模型深度解析与应用指南
  • 开源多模态新突破:CogVLM2-LLaMA3-Chat-19B-Int4模型深度解析与应用指南
  • 43、Samba与不同操作系统的连接及OS/2系统的使用配置
  • 45、Samba配置中的操作系统特定问题与GNU GPL协议解读
  • 47、网络技术与Samba服务全面解析
  • 40亿参数掀起AI效率革命:Qwen3-4B-FP8重新定义轻量级大模型技术标杆
  • 文心ERNIE4.5工程化部署指南:FastDeploy性能优化与多场景实测报告
  • 14、Docker Swarm 集群搭建与管理指南
  • NVIDIA Canary-Qwen-2.5B震撼发布:语音识别领域的颠覆性突破,5.63%词错率刷新行业标杆
  • 人工智能:引领未来科技变革的核心引擎
  • 轻量级科研利器:Qwen3-Reranker-0.6B重构文献检索范式
  • 39、Linux内核内存管理:固定映射地址与ioremap解析
  • 10、BPF 工具使用指南与技巧
  • 43、保障Web与文件服务安全:技术、挑战与应对策略
  • 47、安全文件服务配置指南
  • 49、Linux文件共享与日志管理全解析
  • 52、系统日志管理与监控全解析
  • 54、系统日志管理、监控与入侵检测技术详解
  • 强力解锁游戏控制器兼容性:ViGEmBus虚拟驱动深度指南
  • UE5 材质-30-各种节点:clamp 节点,及结合 TextureCoordinate 做出来的纹理圆效果。处理小数的数学节点 Ceil,Round,Floor,Frac