吾爱破解 - 52pojie.cn

 找回密码
 注册[Register]

QQ登录

只需一步,快速开始

查看: 2836|回复: 32
收起左侧

[Android 原创] Android逆向-分析只因光视频加载动画

  [复制链接]
debug_cat 发表于 2023-3-2 19:19
本帖最后由 莫问刀 于 2023-3-2 19:19 编辑

typora-copy-images-to: ./images

背景

同事需要这个动画,我就静悄悄的帮他一个,打开极光,打卡一个视频,获取极光的视频加载动画,查看如何实现。就是这个金黄色的动画。

screen_cap_20230228_144408.png

定位控件

通过AS的Layout Inspector选择极光的进程(需要root的设备),等待一段时间就可以把页面的布局dump出来。

Xnip2023-02-03_14-11-52.png

这个抓取的过程有点麻烦,需要刚好加载中的时候抓比较好定位,可以通过自己开一个360WiFi限制网速来模拟,网络太好可能就看不到了。但是看是看不到了,布局中肯定还是存在这个view的组件,就是不方便定位,同样ddms的页面dump也可以。

通过分析可以得到,这个动画组件的对象是Lottie,着就好办了。

如果你不是做开发的,甚至做开发的可能都没听过这个东西。

https://github.com/airbnb/lottie-android,Lottie is a mobile library for Android and iOS that parses Adobe After Effects animations exported as json with Bodymovin and renders them natively on mobile!

从ae,pr这种软件做出啦的特效这个库可以加载,导出来的产物就是图片,json字符串(特效)。

学习Lottie的使用

想拿到这个动画,或者我们想把它扣出来,先学习Lottie是怎么在Android上使用的。

这是使用文档:http://airbnb.io/lottie/#/android

文档中重要的部分是:

特效文件的存在位置可以是。

Lottie can load animations from:

  • A json animation in src/main/res/raw.
  • A json file in src/main/assets.
  • A zip file in src/main/assets. See images docs for more info.
  • A dotLottie file in src/main/assets.
  • A url to a json or zip file.
  • A json string. The source can be from anything including your own network stack.
  • An InputStream to either a json file or a zip file.

项目导入Lottie之后,在页面中增加组件即可:

<com.airbnb.lottie.LottieAnimationView
        android:id="@+id/animation_view"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        app:lottie_rawRes="@raw/hello_world"
        // or
        app:lottie_fileName="hello_world.json"
        // Loop indefinitely
        app:lottie_loop="true"
        // Start playing as soon as the animation is loaded
        app:lottie_autoPlay="true" />

这里可以配置特效对应的文件,就是这么简单?

也可以通过animationView.setAnimation方法动态设置特效json文件,animationView.playAnimation主动开启动画。

分析动画的加载和定位资源

知道这些之后,这个组件的用法也有了,反过来猜测,组件源头应该是一个

  public void setAnimation(final String assetName) {
    this.animationName = assetName;
    animationResId = 0;
    setCompositionTask(fromAssets(assetName));
  }

字符串!直接hook它拿到字符串,再写个demo要验证。

var com_airbnb_lottie_LottieAnimationView_clz = 
    Java.use('com.airbnb.lottie.LottieAnimationView');
// hook设置特效json 
var com_airbnb_lottie_LottieAnimationView_clz_method_setAnimation_0996 = com_airbnb_lottie_LottieAnimationView_clz.setAnimation.overload('java.lang.String');
    com_airbnb_lottie_LottieAnimationView_clz_method_setAnimation_0996.implementation = function(v0) {
        var executor = this.hashCode();
        var beatText = 'public void com.airbnb.lottie.LottieAnimationView.setAnimation(java.lang.String)';
        var beat = newMethodBeat(beatText, executor);
        console.log("设置动画json:" + v0);
        com_airbnb_lottie_LottieAnimationView_clz_method_setAnimation_0996.call(this, v0);
        printBeat(beat);
};
// hook启动动画
var com_airbnb_lottie_LottieAnimationView_clz_method_playAnimation_1116 = com_airbnb_lottie_LottieAnimationView_clz.playAnimation.overload();
com_airbnb_lottie_LottieAnimationView_clz_method_playAnimation_1116.implementation = function() {
        var executor = this.hashCode();
        var beatText = 'public void com.airbnb.lottie.LottieAnimationView.playAnimation()';
        var beat = newMethodBeat(beatText, executor);
        com_airbnb_lottie_LottieAnimationView_clz_method_playAnimation_1116.call(this);
        printBeat(beat);
};

通过hook发现有多个调用,但是没有关系,丢进demo里面去跑一跑看看效果。

其中有一个是这样的。

Xnip2023-02-28_15-14-41.png

是一个彩色的,但是不是金色的,还送了个彩蛋~~~~(经过分析猜测是vip才显示这个动画)

通过上面hook时候打印的堆栈信息,很快就定位到启动位置:

Xnip2023-02-03_16-06-54.png

启动动画前设置了一个资源文件夹setImageAssetsFolder("lottieAni/"),这个文件可以在assets目录中找到。

查看图片居然发现了这个:

Xnip2023-02-28_15-23-23.png

离开答案又近了一点。

继续回到代码,设置的不是string类型的特效,是一个setComposition(lottieCompsition),上面刚好也有一个getComposition的方法,进去看看具体实现:

Xnip2023-02-03_16-06-49.png

从方法实现来看,如果没有缓存,就从fromRawFile中加载出来。开发的小伙伴知道答案在哪里了。

开发知识:我们放资源文件到App中,如果你丢进去的目录是assets或者raw目录,会原封不动的复制进去,不会修改,通常都是放assets目录,但是在使用的时候不能通过语法糖R.xx获取,如果你存放在raw目录可以通过R.raw.xx获取到资源引用。这里的操作就是从raw下取资源。把raw目录下的资源一个个加载,最后发现mediaplayer_loading_vip_layout.json是我们需要的特效。文件的命名也可以猜出是播放器的资源。

Xnip2023-02-28_15-33-47.png

demo加载的代码也比较简单。

LottieAnimationView animationView = (LottieAnimationView) findViewById(R.id.animation_view);
animationView.setAnimation("lottieAni/mediaplayer_loading_vip_layout.json");
animationView.setImageAssetsFolder("lottieAni/");
animationView.loop(true);
animationView.playAnimation();

代码也不多,给出结构和代码预览:

Xnip2023-02-28_16-15-25.png

样本地址:https://wwsk.lanzouy.com/iZVI60otn6pi

总结

我们需要的设备和熟悉的技能。

准备好设备root的手机,debuggable = 1。

布局dump进行分析。

熟悉Android的各种主流开发组件。

反编译定位和hook调试,代码分析。

免费评分

参与人数 12威望 +1 吾爱币 +36 热心值 +10 收起 理由
Rdev + 1 + 1 我很赞同!
小霞的可达鸭 + 1 我很赞同!
ufldh + 1 + 1 我很赞同!
修罗本灭世 + 1 + 1 谢谢@Thanks!
ba1jia + 1 + 1 小黑子!
独行风云 + 2 + 1 感谢发布原创作品,吾爱破解论坛因你更精彩!
allspark + 1 + 1 用心讨论,共获提升!
peiwithhao + 3 + 1 用心讨论,共获提升!
muyu1314520 + 1 我很赞同!
正己 + 1 + 20 + 1 感谢发布原创作品,吾爱破解论坛因你更精彩!
夏了夏天蓝了海 + 1 鼓励转贴优秀软件安全工具和文档!
侃遍天下无二人 + 4 + 1 用心讨论,共获提升!

查看全部评分

发帖前要善用论坛搜索功能,那里可能会有你要找的答案或者已经有人发布过相同内容了,请勿重复发帖。

 楼主| debug_cat 发表于 2023-3-3 09:34

小鸡子哦

免费评分

参与人数 1吾爱币 +1 热心值 +1 收起 理由
peiwithhao + 1 + 1 哈哈&amp;amp;#65400;&amp;amp;#65438;&amp;amp;#65391;!(&amp;amp;#3665;&amp;amp;#8226;&amp;amp;#76

查看全部评分

Rolanju 发表于 2023-3-2 21:25
goda 发表于 2023-3-2 22:21
clovert 发表于 2023-3-2 22:41
看看再说、、、、、、、、、、
YongerCTO 发表于 2023-3-2 22:56
666 学习了
空欢 发表于 2023-3-2 23:30
学到了 牛蛙牛蛙
正己 发表于 2023-3-3 00:16
这思路挺棒,学习了
svip6868 发表于 2023-3-3 01:50
厉害了,逆向工程真的好帅
xixicoco 发表于 2023-3-3 03:53
不错的额,分析的很到位
sdieedu 发表于 2023-3-3 07:41
大佬带我一个呗
您需要登录后才可以回帖 登录 | 注册[Register]

本版积分规则

返回列表

RSS订阅|小黑屋|处罚记录|联系我们|吾爱破解 - LCG - LSG ( 京ICP备16042023号 | 京公网安备 11010502030087号 )

GMT+8, 2025-1-9 18:13

Powered by Discuz!

Copyright © 2001-2020, Tencent Cloud.

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