Android 反编译apk,并修改代码后重新签名打包

本文详细介绍如何使用工具反编译APK文件,修改smali代码,并重新签名打包。包括工具下载、反编译过程、代码修改技巧及重新打包流程。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

本文简单介绍apk是如何反编译,然后如何修改smali(java2smali),然后重新签名打包的过程。

一、工具

工欲善其事,必先利其器。好的工具决定做起事来事半功倍。

工具下载链接:https://download.youkuaiyun.com/download/abner_crazy/11088776

二、实现需求:在图1中通过反编译apk将按钮1改为按钮2,并实现跳转到第二个Activity。见下图

     

                 图1                                                                                                    图2                          

三、反编译apk,查看内部如何代码是如何实现的,如下图:

逻辑比较简单,主界面有一个按钮1,跳转到Button1Activity。

四、如何修改apk,并重新签名打包

1、将目标APK 拷贝到 Apktool文件夹里  ,然后按住shift键 并右键 -- 在此处打开命令窗口,输入以下命令:

      apktool -f [待反编译的apk] -o [反编译之后存放文件夹]       例:apktool.bat d -f test.apk -o test

2、成功后会生成一个文件夹,如下图:

3、点开test文件夹找到其中smali文件夹并点击,选择MainActivity.smali文件,右键已文本文档的形式打开

4、打开后你会发现,代码完全开不懂,如何进行修改呢?

    不要着急,将第一步工具下载下来,接下来要做的是在AndroidStudio中导入java转smali的工具,具体步骤如下:

As下左上角找到File -->Settings -->Plugins --> Install Plugin from disk -->选择第一步下载的工具里面的 “ java2smali-1.6.zip ” 并导入 ,见下图:

5、编写MainActivity.java,并将其转换为MainActivity.smali

6.转换成功后,替换第3步里面的MainActivity.smali ,还有新增Button2Activity.smali (先写好java文件,然后转换得到)。

通过比较反编译文件,实现上述功能我们对应的只需要改onclick里面的方法,所以我们只替换MainActivity.smali里面onclick方法的部分:

7.替换布局文件layout见下图:test -- res -- layout 新增Button2Activity的布局文件activity_button2.xml,替换activity_main.xml

因为activity_button2.xml是我们新加入到layout内部的没有对应的id值,接下来我们要为activity_button2.xml添加id:见下图:

8.重新打包apk  在  Apktool 文件夹下(确保test在Apktool目录下),然后按住shift键 并右键 -- 在此处打开命令窗口,输入以下命令:apktool.bat b test (反编译之后存放的文件夹),成功后test文件夹下多了个dist文件夹,里面的apk文件就是重新打包的文件。如下图:

9.需要对重新打包的apk进行签名,将dist文件夹里的apk文件拷贝到工具:autosign 目录下,见下图:

10.在autosign目录下,然后按住shift键 并右键 -- 在此处打开命令窗口,输入以下命令:

java -jar signapk.jar testkey.x509.pem testkey.pk8 test.apk test_signed.apk

成功后会在autosign目录下多出一个test_signed.apk,这个文件就是签名后的文件,接下来安装,验证是否实现我们的功能。

 

以上只是反编译重新打包的简单应用,这个demo仅仅只是个入门,写的不好的地方还请大神们多多指教。

1 . 把apk拷到apktool根目录下,执行:./apktool d xxx.apk,会生成xxx目录,里面有res目录(各种资源文件),smali目录(类似src目录,里面文件的语法不一样)及AndroidManifest.xml。 [*.apk->*.jar: sh ./dex2jar/dex2jar.sh xxx.apk,生成xxx_dex2jar.jar通过jd-linux看源码] 2 . 什么apk汉化啊,就到res/values里string.xml里修改字符串,或者拷贝一份values目录改为values-zh-rCN,再去里面修改string.xml里英文字符串改为中文,所谓的汉化就是这么简单。另外,有些图片里不是中文的得去改图片,那得用Photoshop了,图片也不能乱改,格式,图片大小(尺寸)得原来的。 3 . 修改smali文件,这个有些难度。比如有些apk安装了后要积分什么的,比如大于100才可以用的,其实这个值是用SharedPreference存放的,也就是存在xml里,,位置:/data/data/[包名]/shared_prefs的某个xml里,文件不多肯定是可以找到的。另外一种方法就是修改.smali文件也可以达到这目的,软件实现肯定是读取积分那个值给它修改一下就可以了,例如 const/16 v0 100 (其实就是 v0 = 100)这个语法有点像汇编,觉得还是比汇编简单,v0 v1 ...是寄存器,之前会跟变量关联的。具体的还是自己看看smali语法。 4 . 打包生成apk,执行:./apktool b xxx,会在xxx里面生成,一个dist目录,里面就是xxx.apk,但不能安装滴,提示(Failure [INSTALL_PARSE_FAILED_NO_CERTIFICATES]),没有给这个apk签名, 5 . 签名,执行:sh ./dex2jar/d2j-apk-sign.sh ./xxx/dist/xxx.apk 就是给刚才那个apk签名,生成的文件还是xxx.apkapktool根目录下。这样就大功告成啦。 [请看:http://blog.youkuaiyun.com/zhouyuanjing/article/details/7446988]
评论 13
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

等风起了

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值