安卓逆向进阶教程第二集

前言:

各位同学大家好,有段时间没有给各位更新文章,具体多久我也不清楚,今天给大家来讲一下安卓逆向进阶教程,那么废话不多说我们正式开始 。

效果图

image.png

image.png
我们查看下面一段代码
package com.example.myapplication;

import androidx.appcompat.app.AppCompatActivity;
import android.os.Bundle;
import android.widget.TextView;

public class MainActivity extends AppCompatActivity {

    private static final String TAG = "-----MainActivity-----";
    private TextView   textView;
    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
        textView.setText("我是徐庆哈哈哈");
    }
}

我们看到日志中报错 报出来空指针异常了,那是因为我们的textview 没有初始化导致的 ,如果说我们只有 apk的情况下如何去修复这个bug 今天我急教大家怎么去处理 。

我们先把有报错的工程打包一下

image.png

image.png
我们把这个apk反编译一下

image.png

我们找到报错的Java代码对应的smali 文件
image.png

image.png

我们在上面的代码里面加上textview 初始化
 textView=findViewById(R.id.textview);
textView.setText("我是徐庆哈哈哈");

我再将这个工程重新打包 ,

image.png

image.png

我们可以观察我们更新后的apk反编译解包出来的mainactivity.smali 文件代码

image.png
我们在对比没有修复错误之前代码
image.png
我们把oncreate 拿部分 smali 直接复制过去复制 覆盖

image.png

我们现在重新回编译我们的代码
image.png

image.png

我们在有报错的反编译目录的dist目录下面找到找到了重新编译的apk 我们重新签名 然后安装
image.png

image.png
我们看到模拟器里面app没有再崩溃了
image.png

为什么要逆向操作

很多时候我们并不一定能拿到源代码,因为我公司是做游戏 我是做手游SDK 我需要将自己的代码打包成aar然后给到 研发的技术进行对接(简化来讲就是我们只负责整个游戏开发的其中的一部分)这个时候如果我们代码有问题 我们是不是通常做法是打包一个新的aar 给到接入方 。这样不仅浪费时间 而且在关键时刻还会出问题

还有一种方式

那就是我们可以直接同名文件覆盖 其实我们刚才的·mainactivity 的代码基本都是一模一样的但是不同的是修复bug的代码里面的多了一行 其实我们仔细想一下 我们将apk反编译之后mainactivity.smali 这个个文件也是相同的 只是里面的方法体里面有不同我们只需要将新的覆盖就旧的就可以 修复成功了。这里我就不展开讲了。原理差不多

最后总结

回到开始话题,为什么教安卓逆向的知识,那是因为在很多的时候我们并没有办法拿到源代码的情况下 我们能通过分析报错 来处理掉一些棘手的BUG 这样就可以神不知鬼不觉的 处理好那些问题 为工资减少损失也可以然我们的项目能够在最短时间正常运作。最后希望我的文章能帮助到各位解决问题 ,以后我还会贡献更多有用的代码分享给大家。各位同学如果觉得文章还不错 ,麻烦给关注和star,小弟在这里谢过啦

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

推荐阅读更多精彩内容