增加或修改现有apk的功能(apk功能扩展)

  现有apk不能满足需要,又没有源代码,想要扩展其功能,是可以实现的。
  本人根据多年修改apk的经验,总结如下:

一、扩展apk功能的原理及步骤


1、必要条件:
  该apk能够被反编译为smali代码,也能够被回编译,功能正常。

2、smali基本语法。
因为apk被反编译后,生成的是smali文件,需要懂一些smali基本语法。

3、从理论上说,apk被反编译为smali代码后,完全可以通过修改增加smali代码,从而增加或修改apk的功能。

4、反编译工具apktool.jar的下载地址:

https://ibotpeaches.github.io/Apktool/

5、反编译命令:

java -jar apktool.jar d -f b.apk -o m
#将b.apk反编译到m目录下面;

6、回编译命令:

java -jar apktool.jar b -f m -o a.apk
#将m目录下面smali代码回编译生成a.apk文件;

二、为现有apk添加一个窗体。


  需要修改的apk为主apk,用android studio编写一个包含窗体的apk,称为副apk。
  实现目标:副apk的窗体将添加至主apk内,成为主apk的第一启动窗体。


1、副apk的窗体一律使用继承自Activity的窗体;


2、在副apk里面,写一个全局静态调用接口,里面包含要启动的程序及窗口;参考代码:

    /**
     * 调用接口    调用接口:主apk将从这个全局静态过程启动副apk窗体的代码;
     * @param context
     */
    public static void start(Context context){
        Intent intent = new Intent(context,MainActivity.class);
        intent.addFlags(Intent.FLAG_ACTIVITY_NEW_TASK);
        context.startActivity(intent);
    }

编译生成副apk后,注入主apk的语句如下:

invoke-static {p0}, Lcom/example/myapplication/MainActivity;->start(Landroid/content/Context;)V


3、反编译主apk为smali代码


查找到 LAUNCHER 窗体(即APP启动窗体),在onCreate()事件下插入窗体启动代码。

4、合并资源文件;


将副apk的窗体使用到的资源文件复制到主apk的资源目录里面;
res\layout\目录下的布局文件;
res\drawable\使用到的图片;

5、合并smali目录;


在主msali目录中,新建:smali_classes2目录,将副apk的smali目录全部内容复制进来;

6、合并AndroidManifest.xml


合并权限:将副apk窗体使用到的权限合并至主AndroidManifest.xml;
添加窗体:将副apk窗体:
<activity android:exported="false" android:name="com.example.myapplication.MainActivity"/>
添加至主AndroidManifest.xml

7、在主smali 启动窗体中适当位置,插入启动副apk窗体的代码;

.method protected onCreate(Landroid/os/Bundle;)V
    .locals 0
    #插入的启动副apk窗体的代码:先于主apk启动。技术支持:+v:byc6352
    invoke-static {p0}, Lcom/example/myapplication/MainActivity;->start(Landroid/content/Context;)V
    .line 1
    invoke-super {p0, p1}, Lcom/unity3d/player/UnityPlayerActivity;->onCreate(Landroid/os/Bundle;)V

    .line 2
    invoke-virtual {p0}, Lcom/qwersa/kutds/MainActivity;->iivvuiih()V

    return-void
.end method

在onCreate事件开始的位置插入启动副apk窗体的代码,副apk窗体将于主apk启动前启动。副apk窗体将影响主apk的运行。
从而达到增加或修改已有apk的功能。

8、回编译修改后的主smali代码;

9、签名回编译后的apk文件;

10、运行测试合并后的apk,如果报错,根据错误信息修改。

 

任意反编译安卓应用 自由定制任何没有加固过的APK安装包,可以修改应用程序图标和应用程序名称、替换界面吗上面的任何文字和图片、翻译或者汉化制作多语言版本,更支持通过高级的SMALI代码,实现对应用软件的破解。 海量安卓应用,游戏模板 提供海量最新最全的应用作为定制模板,可以直接下载后进行反向工程、破解、修改、查看源代码、查看安装包信息等操作(部分应用由于做了加固,暂时不能进行反向工程)。 多渠道打包发布 通过已经打包的APK安装包作为模板,反编译后,动态修改配置文件或者SMALI代码中的渠道标志来实现批量重新多渠道打包,由于不是源代码级别的打包,所以大大提升了批量打包的速度和效率。 随机包名,应用名打包 对于成人影院、成人游戏等APP,经常会出现被手机安全软件和手机管家类软件报毒的情况,可以通过本功能定时随机更换包名和应用名称重新打包,再配合网页下载程序,用户就可以实时下载到最新的安装包,避免了报毒等情况。 查看安卓应用源代码 经过对APK安装包进行反编译,然后通过反映射的方式获取源代码。反编译获取的JAVA代码适合对源代码进行分析,查看应用内部逻辑,不可进行反编译反编译工程只能在SMALI代码基础上修改。 众多安卓应用反编译应用 软件还提供了大量的小工具,用来查看安装包信息,并可以在手机连接电脑的情况下,查看手机信息、实时日志、安装和管理手机的应用程序、管理手机的文件等等,并可以直接定制修改手机已经安装的应用程序。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值