Android Native Binder,在Native层与App交互数据

    Binder底层是基于C实现的,所以能够做为Native进程与App层交互数据的渠道。其应用场景为:Native Service、Hal驱动设置、应用层JNI服务等。html

    Android 4.4引入SEAndroid/SELinux 安全机制,至Android 5.0之后,Android彻底采用此安全机制,对应用访问和操做文件权限进行限制,采用管道、共享内存、LocalSocket等方式进行跨进程交互面临着文件访问权限问题,若非修改固件源码的sepolicy文件(AOSP给定路径为/device/manufacturer/device-name/sepolicy)赋予进程文件访问权限,则可能会发生通信失败。linux

    采用Binder进行进程间通信,是相对标准、优雅、高效的方式。git

C端:github

    在Android8.0如下,需继承IInterface.h(路径在/frameworks/native/include/binder/IInterface.h),经过Parcel类(/frameworks/native/include/binder/IParcel.h)完成交互数据传递。Android 8.0以上,可采用HIDL语言定义接口,编译SO库时系统解析生成C代码。api

Android端:安全

   可经过AIDL语言定义交互接口,引用Framework.jar(测试

compileOnly files('libs/framework.jar')

),使用ui

ServiceManager.getService(String SERVICE_DESCRIPTOR)方法获取C层Binder服务。

   两端需约定使用相同的服务描述符。code

另外,Android  9.0以上增强了对Hal 层 Service的Selinux限制,若是要测试binder,在已root的设备上,可以使用 htm

   setenforce 0

命令,暂时关闭Selinux,进行测试。若是有系统源码,需设置\system\sepolicy\prebuilts\api\28.0\public 文件夹下的例外规则,从新编译系统,使得binder通讯不被Selinux限制。

Demo代码:https://github.com/AceSui/NativeJavaBinder

原文出处:https://www.cnblogs.com/acesui/p/12002758.html

相关文章
相关标签/搜索