• Android逆向学习(番外一)smali2java部分文件无法反编译的bug与修复方法


    Android逆向学习(番外一)smali2java部分文件无法反编译的bug与修复方法

    一、前言

    昨天我和往常一样准备着android逆向(四)的博客,结果发现smali2java对某些文件无法进行逆向,我不知道windows会不会产生这个bug,但是ubuntu产生了这种情况,作为一个喜欢多了解的人,我就探究了一下这个bug并且找到了原因并且给出了修复的方法,目前我已经联系了原作者,期待smali2java能够尽快的对这个进行更新

    下面我会简单介绍一下这个bug产生的原因与修复的方法,如果大家比较赶时间的话可以直接看修复的方法

    二、bug的介绍

    我在对一些带有$$文件名的smali文件进行逆向会出现这种情况的bug

    20230905125635

    这就很奇怪了,$$文件是因为使用java lambda表达式产生的一个smali代码,虽然这种代码一般非常简单,不需要逆向直接看smali代码就可以,但是作为一名有着大志向的菜狗,我最看不得电脑报错了,所以就打算直接修复这个bug

    下面我们就开始分析这个bug是怎么产生的以及如何修复这个东西,通过查看报错我们发现是一行命令没有正确的运行,我们直接在命令行运行一下这个命令,发现报错如下

    20230905130122

    文件没有找到,然后机智的我发现这个文件名字上下怎么对不上了,会不会是没有转义的事情,加上转义符号我们再试一下

    20230905125749

    果然是这个原因,既然已经知道bug产生的原因了,简单修复一下就好了

    三、修复方法

    我们首先要找到这个插件的位置,这个vscode的插件都是javascript或者typescript写的,我是写过与发布过javascript脚本的,所以修改脚本对我来说不是难事情,一般来说vscode的配置文件都是在主目录下的.vscode目录里面,我们直接去找就可以了,记得打开隐藏目录

    20230905125846

    smali2java的脚本目录我们就这样找到了

    然后打开文件夹,我们只需要修改两个文件

    在里面的out文件夹下有个decompiler文件夹,里面有两个JadxDecompiler.js文件,一个在decompiler里一个在里面的impl文件夹里面,然后我们对这两个文件夹进行如下的修改

    20230905163734

    20230905163529

    就是在指定位置加上下面个代码,这个是利用正则表达式进行替换

    .replace(/\$/g,"\\\$")
    
    • 1

    这个代码的意思就是运行命令的时候,在文件名上加上转义,这样就能正确运行了

    对了,当你修改之后,你的vscode还是没有办法运行,这时候就ctrl+shift+p打开vscode命令面板,然后reload window,就可以重新加载插件,然后你就发现这个程序可以正确运行了

    20230905130016

    最后还是虎哥镇楼

    20230905130334

  • 相关阅读:
    Node.js【使用 Express 写接口】
    B+树结构与索引<一> _ 结构与索引
    springboot线程池创建与使用
    软件测试需要学习什么?好学吗?需要学多久?到底是报班好还是自学好?
    Towards Interpretable Video Anomaly Detection 论文阅读
    解决webstrom ERROR in [eslint] ESLint is not a constructor
    已更新 联通 电信 tiny模式
    图机器学习在蚂蚁集团推荐业务中的应用
    Promise小结
    软考52-上午题-【数据库】-关系模式2
  • 原文地址:https://blog.csdn.net/qq_52380836/article/details/132689737