插件开发Android知识Android源码分析

插件开发之360 DroidPlugin源码分析(三)Binde

2016-09-03  本文已影响80人  码农突围

Hook机制中Binder代理类关系图

这里写图片描述

Hook机制中Binder代理时序图

这里写图片描述
这里写图片描述

MyServiceManager

这里写图片描述

ServiceManagerCacheBinderHook

这里写图片描述 这里写图片描述 这里写图片描述

前面把service cache存起来,下次如果要真正和service进行通信,通过getOriginService()把原始的service cache拿出来用就行了。

ServiceManagerBinderHook

这里写图片描述

这个类继承自ProxyHook,主要是用来hook住getService()和checkService()这两个API。如果这两个API被调用,并且在mProxiedObjCache发现有对应的代理对象,则直接返回这个代理对象。

BinderHook

这里写图片描述 这里写图片描述

先调用ServiceManagerCacheBinderHook的onInstall()方法更新一下service cache,然后生成一个新的代理对象放到mProxiedObjCache里。这样下次不管是从cache里取,还是直接通过binder调用,就都会返回我们的代理对象。

Binder代理其实在android 系统中也是一个十分重要的角色。

这部分可以从网上搜下相关资料。360 plugin 的Binder代理就是借鉴了系统的Binder相关。

上一篇下一篇

猜你喜欢

热点阅读