android property 系统

1.使用目的

目的都是为了测试。

减少编译流程。提高测试效率

2.使用方法流程

2.1 初始化默认值

方法一.

配置文件进行配置。

方法二.

手动初始化

bash 复制代码
setprop test.prop.id 1

2.2 获取键值并

c++ 复制代码
property_get

2.3 配置头文件

c++ 复制代码
<cutils/properties.h>

3.注意事项

3.1 关于无法设置属性 test_flag 的权限问题分析及解决方案

问题原因 (重 - - 命名规则)

错误 PROP_ERROR_PERMISSION_DENIED (0x18) 表明当前进程 缺乏修改该属性的权限,通常由以下原因导致:

  1. SELinux 策略限制

    Android 从 5.0 开始强制启用 SELinux,若属性操作未在 SELinux 策略文件中声明权限,即使应用具备 systemroot 权限也会被拒绝。

  2. 属性命名规则不合法

    • ro. 开头的属性为只读属性,不可修改。
    • 自定义属性需符合系统前缀规范(如 persist.sys.vendor. 等),否则默认策略可能禁止写入。
  3. 进程权限不足

    systemroot 进程可通过 property_set 修改属性值,普通应用需声明 android:sharedUserId="android.uid.system" 并使用平台签名。

解决方案
1. 检查并修正 SELinux 策略
  • Step 1:添加属性上下文

    property_contexts 文件中将属性关联到合法的安全上下文(如 system_prop):

    text 复制代码
    test_flag u:object_r:system_prop:s0
  • Step 2:配置进程的 SELinux 权限

    在进程的 .te 文件(如 hal_test_ztt.te)中添加权限声明:

    text 复制代码
    set_prop(hal_test_ztt, system_prop)
    get_prop(hal_test_ztt, system_prop)

    若属性需自定义类型(如 test_prop),需在 property_contexts.te 文件中同步定义。

  • Step 3:绕过 neverallow 规则(可选)

    若遇到 neverallow 规则冲突(如 default_prop),需在 domain.te 中添加例外或改用自定义属性类型。

2. 规范属性命名
  • 若属性需持久化,使用 persist. 前缀(如 persist.sys.test_flag)。
  • 避免与系统内置属性冲突,建议添加唯一标识符(如 vendor.test_flag.test.flag)。
3. 提升进程权限
  • 对于系统应用
    AndroidManifest.xml 中声明 android:sharedUserId="android.uid.system",并使用平台签名。
  • 对于 Root 设备
    通过 su 提权后操作,但需注意商业版本可能禁用此方式。
4. 临时调试方法
  • 关闭 SELinux 强制模式(仅限调试):

    bash 复制代码
    adb shell setenforce 0

    此操作重启后失效,不可用于生产环境。

验证步骤
  1. 检查 SELinux 日志

    通过 adb shell dmesg | grep avc 查看权限拒绝的详细上下文,确认是否缺少 set_prop 权限。

  2. 测试属性读写

    bash 复制代码
    adb shell setprop test_flag "false"  # 尝试设置
    adb shell getprop test_flag          # 验证值是否生效
  3. 编译并刷写 SELinux 策略

    • 修改策略文件后,执行 make selinux_policy
    • 将生成的 *.sepolicy 文件推送至 /vendor/etc/selinux/ 并重启设备。
相关推荐
“初生”3 小时前
安卓手机安装 ChatGPT 全流程图文指南
android·chatgpt·智能手机
与籍同行4 小时前
20200201工作笔记常用命令要整理
android·笔记
tangweiguo030519874 小时前
Android屏幕适配利器:Kotlin动态尺寸计算工具类完整封装
android·kotlin
speop6 小时前
TASK05【Datawhale 组队学习】系统评估与优化
android·java·学习
zhu62019768 小时前
Android10如何设置ro.debuggable=1?
android·安全·android逆向·android10·ro.debuggable
androidwork9 小时前
Android 内存溢出(OOM)的 Kotlin 排查与优化指南
android·开发语言·kotlin
xzkyd outpaper9 小时前
Android中PID与UID的区别和联系
android·计算机八股
Developings9 小时前
Android logcat命令汇总
android
吃着火锅x唱着歌9 小时前
PHP7内核剖析 学习笔记 第八章 命名空间
android·笔记·学习