开启辅助访问 切换到宽版

精易论坛

 找回密码
 注册

QQ登录

只需一步,快速开始

用微信号发送消息登录论坛

新人指南 邀请好友注册 - 我关注人的新帖 教你赚取精币 - 每日签到


求职/招聘- 论坛接单- 开发者大厅

论坛版规 总版规 - 建议/投诉 - 应聘版主 - 精华帖总集 积分说明 - 禁言标准 - 有奖举报

查看: 8199|回复: 14
收起左侧

[技术专题] 安卓逆向之记一次从JAVA层到So层的协yi分析

[复制链接]
结帖率:50% (2/4)
发表于 2018-11-20 13:11:19 | 显示全部楼层 |阅读模式   福建省漳州市
本帖最后由 如果 于 2018-11-21 08:24 编辑

Hello,大家好,又和大家见面了,还是我,我是福利皮,上次给大家出的一套JS系列加密课程,不知大家学得如何了,今天发一篇安卓逆向的记录文章。大家如果想学习,或者技术交流可以加福利皮交流群:860058365 我的QQ: 65827186


废话不多说,今天的一个样本是 看了吗视频的一款APP,查了是360加固,这篇不是讲脱壳,我们简单脱出DEX文件后,来进行JAVA层分析...


分析流程:



主要针对协yi中的sign签名来分析,首先第一步就是抓包,这里使用Fiddler进行抓包即可,分包内容如下:

1.png

通过抓包看到,当手机获取验证码时,需要的其中一个参数为sign值,总所周知,它就是验证,当前这个协yi数据包是否有效的一个签名。但这里初步看到的话,并不知道它是什么鬼?


我们通过JAVA层来分析吧,这里我个人习惯使用的是jadx工具,我们通过脱出来的DEX文件进行一个分析。
首先,我们先定位它的关键位置,这里方法挺多的,最简单的就是搜索关键字,我们通过sendLoignCode试一试。


2.png

找到后,我们过去看一下大概的JAVA逻辑代码...


3.png

做了些混淆,但是这个类很明显这里就是对实例化的对象进行一个sign值的赋值了,那么这肯定是我们要关注的。我们可以看看哪里进行了调用。


4.png

从这里进行了实例化这个类,那么这3个参数的第2个就是我们关注的重点,我们向上推,就会发现实际是通过KiUtils这个类的方法进行返回的数据,我们到里面看看。


5.png

到这边似乎我们就无法在跟踪了,因为它加载了so ,我们只能去Native层再分析它的一个代码了。
说干就干吧,把它的so丢进IDA中进行分析..


在java层中,我们可以看到他zc了一个叫 _nativeMessageDigest 的方法,我们找到该方法,它是动态zc的,所以在Jni_onload找到位置:

6.png

流程比较简单,参数传递进来后,从jstring对象转到C的char字符数组后,就进入这个函数了,ki_message_digest ,我们还继续跟进分析。


7.png

进来后发现一个自定义的算法,但实际它是计算一个表,从固定的表中取值,然后获得盐。 它的值最终计算结果为:02>=9{h5
退出这个自定义算法的地方,我们可以看到几个比较关注的函数了,这几个是openssl MD5的一个算法,也比较固定。


8.png

最后,进行一个格式化,输出,数值个数就是8位,也就刚好符合了我们抓包sign的值..

9.png

它的一个组包数据分析总结:


result = MD5(mobile_timestamp_salt)
sign = result.substring(0,7)

好了,就分享到这边吧,再会~ ,本篇文章分析仅供学习交流,请勿用作违法用途,后果自负, 若有侵犯权益 联系我或论坛删除

点评

+8888888   浙江省宁波市  发表于 2020-12-13 12:53
+999999 精币   广东省深圳市  发表于 2018-12-10 16:09

评分

参与人数 2好评 +2 精币 +3 收起 理由
周末派 + 1 + 2 感谢分享,很给力!~
tankeer1 + 1 + 1 感谢分享,很给力!~

查看全部评分


结帖率:89% (110/123)

签到天数: 4 天

发表于 2019-10-3 14:56:30 | 显示全部楼层   山东省青岛市
js 教程讲的非常好, 就是基础不够还是没闹明白有没有更加简单点的.
回复 支持 反对

使用道具 举报

发表于 2019-9-1 16:46:45 | 显示全部楼层   北京市北京市
多谢分享,支持
回复 支持 反对

使用道具 举报

发表于 2019-6-10 06:32:57 | 显示全部楼层   湖北省武汉市
多谢分享,支持
回复 支持 反对

使用道具 举报

发表于 2019-5-27 06:43:29 | 显示全部楼层   湖北省武汉市
感谢分享,很给力
回复 支持 反对

使用道具 举报

结帖率:79% (26/33)
发表于 2019-5-9 13:13:37 | 显示全部楼层   山东省济宁市
学习了
回复 支持 反对

使用道具 举报

结帖率:100% (1/1)
发表于 2018-12-14 13:07:48 | 显示全部楼层   广东省清远市
学习了,谢谢分享!!
回复 支持 反对

使用道具 举报

结帖率:77% (64/83)

签到天数: 1 天

发表于 2018-12-2 14:29:47 | 显示全部楼层   河南省商丘市

学习一下~~~~~~~~~~~~~~~~~~~~~
回复 支持 反对

使用道具 举报

发表于 2018-11-29 14:07:08 | 显示全部楼层   四川省成都市
6666
回复 支持 反对

使用道具 举报

结帖率:90% (66/73)

签到天数: 1 天

发表于 2018-11-21 14:23:18 高大上手机用户 | 显示全部楼层   广东省深圳市
皮师傅牛批
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 注册

本版积分规则 致发广告者

发布主题 收藏帖子 返回列表

sitemap| 易语言源码| 易语言教程| 易语言论坛| 易语言模块| 手机版| 广告投放| 精易论坛
拒绝任何人以任何形式在本论坛发表与中华人民共和国法律相抵触的言论,本站内容均为会员发表,并不代表精易立场!
论坛帖子内容仅用于技术交流学习和研究的目的,严禁用于非法目的,否则造成一切后果自负!如帖子内容侵害到你的权益,请联系我们!
防范网络诈骗,远离网络犯罪 违法和不良信息举报电话0663-3422125,QQ: 793400750,邮箱:wp@125.la
Powered by Discuz! X3.4 揭阳市揭东区精易科技有限公司 ( 粤ICP备12094385号-1) 粤公网安备 44522102000125 增值电信业务经营许可证 粤B2-20192173

快速回复 返回顶部 返回列表