某小说App返回数据 解密分析

一、目标

李老板:奋飞呀,最近被隔离在小区里,没啥可干的呀。

奋飞:看小说呀,量大管饱。

我们今天的目标就是某小说App v2021_09_53

二、步骤

搜索url字符串

App请求小说内容的时候没有加签名,但是返回的数据是加密的。

main.png

那么我们先去jadx搜索一下这个url(novel-content),看看有没有发现。

结果是没有收获。

那么很有可能这个url不是在apk中写死的,而是某个请求返回的。

Charles可以搜索数据包,我们从返回包里面找到了这个url。

main2.png

那就好办了,看看是哪块代码去解析了这个 content_url ,我们在jadx中搜索

"content_url"

这次倒是有收获,但是看不出来这个变量再哪里用了。

插播一个屏蔽登录

只能再想想别的办法了,办法还没想出来,又遇到了新的问题。

第二次启动app的时候,就不让我看书了。一定要我登录,一怒之下登录了,居然还不让我看。还要买VIP。

这下忍不了了,我不过是想写个分析教程,何必这么为难我。

先从提示入手, 搜索 "登录" 来到这里

login.png

理论上说干掉这两个函数应该就可以了,写代码

    var CacheUtilsCls =  Java.use('com.xxoo.net.net.CacheUtils');

    CacheUtilsCls.isVip.implementation = function(){

            return true;

    };


    CacheUtilsCls.isLogin.implementation = function(){

            return true;

    };

作者这个类名起的好风趣呀,我都不忍心打码了。

过滤url

既然知道请求小说内容的url了,我在url这里做一次过滤,应该就可以定位了吧

    var URL = Java.use('java.net.URL');

    URL.openConnection.overload().implementation = function() {

        var retval = this.openConnection();

        console.log('URL openConnection' + retval);


        return retval;

    };


    var OkHttpClient = Java.use("okhttp3.OkHttpClient");


    OkHttpClient.newCall.implementation = function (request) {

        var result = this.newCall(request);

        console.log(request.toString());

        var stack = threadinstance.currentThread().getStackTrace();

        console.log("http >>> Full call stack:" + Where(stack));

        return result;

    };

url和返回数据我都hook了。木有逮住。

大海捞针大法

下面就试试咱们老用的字符串匹配大法了。不管你怎么玩,解密之后的数据大概率是要赋值给字符串的。我们先把字符串赋值来捞一遍。

    var strCls = Java.use("java.lang.StringBuilder");

    strCls.toString.implementation = function(){

        var result = this.toString();

        console.log(result.toString());

        return result;

    }

这次就比较幸运了,我们不仅捞到了明文,还捞到了重要提示

show.png

大海告诉我们,大概率是AES CBC算法做的解密。

字符串匹配定位

有了重要提示,我们就依据这个提示来定位

    var strCls = Java.use("java.lang.StringBuilder");

    strCls.toString.implementation = function(){

        var result = this.toString();

        // console.log(result.toString());

        if(result.toString().indexOf("AES/CBC/PKCS5Padding") >= 0 )

        {

            console.log(result.toString());

            var stack = threadinstance.currentThread().getStackTrace();

            console.log("Rc Full call stack:" + Where(stack));

        }

        return result;

    }

跑一下,漂亮的堆栈就出来

漂亮的堆栈会说话

rc.png

这个堆栈告诉我们,重点怀疑对象是 NativeBds.dae1

,从名字和外形上看,它大概率是个Native函数。

但是后面的堆栈告诉我们一个好消息,虽然运算过程在Native里面,但是它居然回调了javax.crypto来做加解密,也太敷衍老板了,这在我司是要被扣工资的。

先不管了,终于找到你了,hook之

    var  DecodeCls = Java.use('com.baidu.searchbox.NativeBds');

    DecodeCls.dae1.implementation = function(a,b){

        var rc = this.dae1(a,b);


        var StrCls = Java.use('java.lang.String');

        var inStr = StrCls.$new(rc);

        console.log(inStr);

        return rc;

    }

跑一下,没问题,明文出来了,收工,下雨了,没法上鲜啤了。

三、总结

不要嫌打印的数据太多,大海捞针也是考验你火眼金睛的时候。

对常见加解密算法要敏感,要成为条件反射。看到iv就要想到aes,看到32位就要想到md5,看到64位就要怀疑sha256。看到太阳就要想到鲜啤,看到飞哥的文章就要想到转发

ffshow.jpg

新一代的财富都是通过代码或者媒体创造的 --- 纳瓦尔

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 212,185评论 6 493
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 90,445评论 3 385
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 157,684评论 0 348
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 56,564评论 1 284
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 65,681评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 49,874评论 1 290
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,025评论 3 408
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,761评论 0 268
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,217评论 1 303
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,545评论 2 327
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,694评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,351评论 4 332
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 39,988评论 3 315
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,778评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,007评论 1 266
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,427评论 2 360
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,580评论 2 349

推荐阅读更多精彩内容