RK356X Android 11 增加自定义系统服务调用失败

本文介绍了在Android11上遇到的非SDK接口限制问题,当尝试调用自定义系统服务时,由于Android11加强了对隐藏API的限制,导致调用失败。解决方案是将新增接口添加到hiddenapi-greylist.txt文件中,重新编译系统以允许应用访问这些接口。这一变动对于Android系统的安全性和稳定性有所提升,同时也影响了第三方应用的兼容性。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

平台

RK3566 + Android 11

概述

为方便第三方应用调用系统功能, 增加系统服务提权并提供应用层调用开放接口, 在Android 9及以下版本已实现
基本的实现步骤如下, 服务以MyService命名:

  1. 在frameworks/base/core中增加 IMyService.aidl
  2. 增加IMyService接口实现的应用, 可以存放在frameworks/base/packages/MyService
  3. 修改frameworks/base/services启动MyService, 并增加到SystemService中.
  4. 修改相关SELinux权限.

Android 11上的问题

相同的补丁, 打到Android 11上, 出现了新的问题.

2022-02-10 01:05:48.340 5010-5010/com.ansondroider.apitester W/oider.apiteste: Accessing hidden method Landroid/os/IMyService$Stub;->asInterface(Landroid/os/IBinder;)Landroid/os/IMyService; (blacklist, linking, denied)
2022-02-10 01:05:48.344 5010-5010/com.ansondroider.apitester W/oider.apiteste: Accessing hidden method Landroid/os/IMyService;->reboot(IIIIIII)Z (blacklist, linking, denied)
2022-02-10 01:05:48.346 5010-5010/com.ansondroider.apitester W/oider.apiteste: Accessing hidden method Landroid/os/IMyService;->shutdown(IIIIIII)Z (blacklist, linking, denied)
.....

这个问题出现在第三方应用调用接口时, 初始化接口类的过程中, 接口类需要通过调用 IMyService.Stub.asInterface来获取服务实现跨进程调用, LOG中体现为 找不到相关的类, 理论上, 也会影响反射的方式,

翻阅了相关资料后, 原因可以查看文末参考内容,
解决方法是将增加的接口添加到源码下的hiddenapi-greylist.txt中(不能有空行):

frameworks/base/config/hiddenapi-greylist.txt

Landroid/os/IMyService$Stub;->asInterface(Landroid/os/IBinder;)Landroid/os/IMyService;
Landroid/os/IMyService;->reboot(IIIIIII)Z
Landroid/os/IMyService;->shutdown(IIIIIII)Z

重新编译打包, 完成!

参考

  1. 针对非SDK接口的限制-Google 反射限制
  2. Android 11 中有关限制非 SDK 接口的更新
  3. SystemServer 启动新增服务APK
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值