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