android 10.0 selinux权限冲突解决

本文介绍了如何解决Android 10.0系统中遇到的SELinux权限冲突问题。首先通过临时禁用SELinux确认问题,然后通过分析logcat或kernel log中的avc denied错误来定位权限缺失。报错显示system_app进程对su_exec类型的file缺少execute权限,需要在system_app.te文件中添加相应权限。但在添加权限时遇到编译冲突,解决办法是修改neverallow规则,避免与system/sepolicy/public/domain.te冲突,并同步相关文件。
摘要由CSDN通过智能技术生成

1 调试确认SELinux问题

为了澄清是否因为SELinux导致的问题,可先执行:

setenforce 0 (临时禁用掉SELinux)

getenforce  (得到结果为Permissive)

如果问题消失了,基本可以确认是SELinux造成的权限问题,需要通过正规的方式来解决权限问题。

遇到权限问题,在logcat或者kernel的log中一定会打印avc denied提示缺少什么权限,可以通过命令过滤出所有的avc denied,再根据这些log各个击破:

cat /proc/kmsg | grep avc

dmesg | grep avc

2.报错信息

报错:

avc:  denied  { execute} for  pid=19029 comm="su" path="/system/xbin/su" dev="dm-4" ino=3540 scontext=u:r:system_app:s0 tcontext=u:object_r:su_exec:s0 tclass=file permissive=0

分析:

缺少什么权限:  { execute} 权限

谁缺少权限: scontext&#

评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

安卓兼职framework应用工程师

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值