在线客服
扫描二维码
下载博学谷APP扫描二维码
关注博学谷微信公众号
Hook 技术又叫做钩子函数,简单来说,就是把系统的程序拉出来变成我们自己执行代码片段。今天小编用三分钟简述Hook,让大家了解Hook技术。
1、 Hook的定义
Hook,钩子。勾住系统的程序逻辑。在某段SDK源码逻辑执行的过程中,通过代码手段拦截执行该逻辑,加入自己的代码逻辑。
Hook 简单类似网络传输中的中间人拦截,我拦截APP中的原始方法,自己定义一个方法,替换原始的东西,实现我不可描述的目的,大白话就是这样,但是实际过程和应用还是比较复杂的。
常见的使用场景,举几个栗子:
App登录劫持,一般用户手动点击“登录”按钮才会将用户名和密码信息发送至服务器端去验证账号与密码是否正确。这样就很简单了,居心叵测的人只需要找到开发者在使用EditText控件的getText方法后进行网络验证的方法,Hook该方法,就能劫持到用户的账户与密码了。
App注入广告,app 启动的时候加载 HomeActivity 肯定要执行onCreate 方法, 劫持首页的onCreate方法,在里面注入弹窗广告,获得广告收入。App数据篡改,比如玩一款游戏App ,修改里面额金币数,可以反编译App ,找到具体的类和方法,插入自己的方法就可以实现。听起来很牛b,但是要实现,需要掌握很多的逆向技术和其它需要技术,可是非常不易的。
2、实用价值
Hook是中级开发通往高级开发的必经之路。如果把谷歌比喻成安卓的造物主,那么安卓SDK源码里面就包含了万事万物的本源。中级开发者,只在利用万事万物,浮于表层,而高级开发者能从本源上去改变万事万物,深入核心。
最有用的实用价值: hook是安卓面向切面(AOP)编程的基础,可以让我们在不变更原有业务的前提下,插入额外的逻辑。这样,既保护了原有业务的完整性,又能让额外的代码逻辑不与原有业务产生耦合。
3、前置技能
Java反射
熟练掌握类Class,方法Method,成员Field的使用方法源码内部,很多类和方法都是@hide的,外部直接无法访问,所以只能通过反射,去创建源码中的类,方法,或者成员.
阅读安卓源码的能力
Hook的切入点都在源码内部,不能阅读源码,不能理清源码逻辑,则不用谈hook. 其实使用AndroidStudio来阅读源码有个坑,有时候会看到源码里面 “一片飘红”,看似是有什么东西没有引用进来,其实是因为有部分源码没有对开发者开放,解决起来很麻烦, 所以,推荐从安卓官网下载整套源码,然后使用 SourceInsight 查看源码。 如果不需要跳来跳去的话,直接用安卓源码网站一步到位。
4、hook通用思路
无论多么复杂的源码,我们想要干涉其中的一些执行流程,最终的杀招只有一个: “偷梁换柱”。而 “偷梁换柱”的思路,通常都是一个套路:根据需求确定要hook的对象寻找要Hook的对象的持有者,拿到要hook的对象(持有:B类 的成员变量里有 一个是A类的对象,那么B就是A的持有者)定义“要Hook的对象”的代理类,并且创建该类的对象使用上一步创建出来的对象,替换掉要Hook的对象。
以上就是Hook技术的简述,想要更加深入了解的小伙伴可以继续关注博学谷的资讯。
— 申请免费试学名额 —
在职想转行提升,担心学不会?根据个人情况规划学习路线,闯关式自适应学习模式保证学习效果
讲师一对一辅导,在线答疑解惑,指导就业!
相关推荐 更多
面向对象之SOLID设计原则解析
SOLID原则是由罗伯特·C·马丁在21实际早期引入的面向对象编程和面向对象设计的五个基本原则。分别是SRP(单一责任原则)、OCP(开放封闭原则)、LSP(里氏替换原则)、ISP(接口分离原则)、DIP(依赖倒置原则)。它被典型的应用在测试驱动开发商,同时也是敏捷开发以及自适应软件开发基本原则的重要组成部分。下面就跟着小编一起了解一下这五个原则吧。
7578
2019-07-16 18:09:49
不会英语能学编程吗?能学会吗?
不可否认编程中用的是英语,但只要掌握基础的英语知识就够用了。当看到大段的代码摸不着头脑的时候会觉得看起来很复杂,实际上写一个程序,用到的英语其实是很少的。需要用到的英语也就是几十个经常用到的关键词,不用刻意背经常使用就会记住了。
8894
2019-11-27 15:26:07
IT编程入门教程视频免费资源分享
想转行IT但不知道IT编程从哪里入门,零基础人群想要入门IT行业,可以先选择一些免费的IT课程学习,先学习基础知识,有一定了解后选择适合自己的学科系统学习,如果目前还不知道自己的学习方向,可以结合自身情况多了解一些IT学科,有一定认识之后再进行选择。
8924
2020-05-22 10:43:53
删除又恢复?微软怎么惹恼了开源社区?
近日,.NET开源社区“再起波澜”。起因是微软在即将发布的 .NET 6 中悄悄删除了 Hot Reload(热重载) 的核心部分,此举彻底激怒了.NET开源社区开发者,他们强烈反对微软这种行为,认为微软此举是不利于 .NET 开源社区健康发展。
2993
2021-10-25 18:19:27
常用的操作系统有哪些?起什么作用?
常用的操作系统有哪些?起什么作用?操作系统直接运行在计算机上面的系统软件,控制硬件和支持软件运行的计算机程序,常见的操作系统有Windows、mac OS、Linux、iOS、Android等。
3762
2022-02-12 14:53:17