开启辅助访问 切换到宽版

精易论坛

 找回密码
 注册

QQ登录

只需一步,快速开始

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

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


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

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

查看: 11353|回复: 8
收起左侧

[技术专题] 音遇App Sign算法逆向过程--so分析

[复制链接]
结帖率:75% (3/4)
发表于 2020-3-12 17:26:05 | 显示全部楼层 |阅读模式   山东省聊城市
好久木有来装逼了  发个帖子  某app  sign算法的逆向


App 下载地址:
  1. https://static.inyuapp.com/d/yinyu-release-2.11.1-15192-offical_2111_jiagu_aligned_signed_offical.apk
复制代码
0x1:查壳
360的加固,请自行脱壳............
0x2:抓包
  1. POST https://ucenter.inyuapp.com/v1/login/mobile/check?__plat=android&__version=2.11.1&__app=inyu HTTP/1.1
  2. User-Agent: YINYU/2.11.1 (AOSP+on+HammerHead, Android 4.4.4, okhttp/3.8.1)
  3. Connection: close
  4. sign: c13bca410fd5a4d2ddf69d39e274e077
  5. ts: 1584002472
  6. Content-Type: application/x-www-form-urlencoded
  7. Content-Length: 34
  8. Host: ucenter.inyuapp.com
  9. Accept-Encoding: gzip

  10. country_code=86&mobile=15845454545
复制代码


这是登陆时候第一个包 应该是验证手机号是否存在的包 协议头 sign 就是我们要分析的算法

0x3:反编译dex文件查找关键字
搜索关键字定位到下图位置
1.png

  1. String v0_2 = InyuString.getUrlSign(v1, v7);
  2.         v1 = "sign";
  3.         if(TextUtils.isEmpty(((CharSequence)v0_2))) {
  4.             v0_2 = "signature-failed";
  5.         }

  6.         arg8.addHeader(v1, v0_2);
复制代码
arg8.addHeader(v1, v0_2);
v1==字符串:sign
v0_2==InyuString.getUrlSign(v1, v7)==加密后的sign

双击 getUrlSign 发现跳转不过去  这是因为多dex文件问题 这个Class在另一个dex文件里  我们切换工具  或者搜素路径定位 getUrlSign  方法所在位置

2.png

搜索方法名定位到以上位置  从上到下分别是类名  方法名   
其中 getUrlSign  方法 native 标志  so中导出函数  那么就是调用so里的方法
最后一个箭头表明了表用的so文件名
0x4:分析so文件
搜索导出函数定位到以下位置
3.png

发现两个函数
1.create_signature
2.coverToMD5
第一个暂且不管 我们看第二个  明显是个md5算法
经过分析
4.png

我们在md5update 函数下端查看寄存器第二个参数 也就是R1的值
ida附加app  点击登录断在以下位置查看R1寄存器
5.png

得到明文:
  1. /v1/login/mobile/check?__app=inyu&__plat=android&__version=2.11.1&country_code=86&mobile=15845454545&salt=kzUIhoqJ0K#9^F@kGE3883004851x$gwzqCpb!M5Mw$GiRPkYuq1&_ts=1584003883
复制代码

继续F9运行 查看抓包结果
6.png

以上得到的明文经过md5 与我们抓包得到的结果一致 明文是没错的
我们来分析下明文
/v1/login/mobile/check?__app=inyu&__plat=android&__version=2.11.1&country_code=86&mobile=15845454545&salt=kzUIhoqJ0K#9^F@kGE3883004851x$gwzqCpb!M5Mw$GiRPkYuq1&_ts=1584003883

__version=2.11.1  app版本号
country_code=86 手机号所在国家代码
mobile=15845454545手机号
salt=kzUIhoqJ0K#9^F@kGE3883004851x$gwzqCpb!M5Mw$GiRPkYuq1  key  
_ts=1584003883  10位时间戳
经过多次调试 发现 salt  大部分不会变 为固定  单其中 kzUIhoqJ0K#9^F@kGE3883004851x$gwzqCpb!M5Mw$GiRPkYuq1  红色部分每次都会变化  仔细看你会发现他其实就是把ts 时间戳进行了反转
那么我们就来看下 这个 salt   是在哪里形成的
双击 create_signature 函数我们来到如下位置
7.png

好像是在这里进行拼接的
果然我们 一眼就看到个函数:reverse
函数的作用是 反转元素的顺序。
本来打算拿frida操作一遍的 但是现在肚子饿了  先填饱肚子吧


ojbk  到此结束


最后:
易语言POST,JS,APP交流群 468241990
欢迎各位大佬做客




评分

参与人数 1好评 +1 精币 +2 收起 理由
it混混 + 1 + 2 感谢发布原创作品,一定好好学习,天天向上

查看全部评分


发表于 2020-11-2 08:58:15 | 显示全部楼层   湖南省长沙市
进来学习一下下
回复 支持 反对

使用道具 举报

发表于 2020-4-3 20:51:30 | 显示全部楼层   湖北省武汉市
6666666666666666666666666
回复 支持 反对

使用道具 举报

结帖率:94% (278/296)

签到天数: 19 天

发表于 2020-3-23 09:35:34 | 显示全部楼层   山西省晋中市
脱壳怎么搞
回复 支持 反对

使用道具 举报

结帖率:82% (28/34)
发表于 2020-3-16 21:58:51 | 显示全部楼层   湖南省永州市
膜拜一把,大佬
回复 支持 反对

使用道具 举报

结帖率:0% (0/4)
发表于 2020-3-15 00:56:54 | 显示全部楼层   浙江省金华市
师傅牛逼 力顶师傅
回复 支持 反对

使用道具 举报

发表于 2020-3-14 23:13:11 | 显示全部楼层   湖南省湘西土家族苗族自治州
支持大牛的原创作品~
回复 支持 反对

使用道具 举报

结帖率:92% (22/24)

签到天数: 6 天

发表于 2020-3-12 19:12:51 | 显示全部楼层   江西省吉安市
录个视频就好了
回复 支持 反对

使用道具 举报

结帖率:100% (11/11)

签到天数: 5 天

发表于 2020-3-12 18:57:55 | 显示全部楼层   广东省汕头市
谢谢分享!
回复 支持 反对

使用道具 举报

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

本版积分规则 致发广告者

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

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

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