返回顶部
首页 > 资讯 > 精选 >【安卓逆向】APK修改与反编译回编译
  • 595
分享到

【安卓逆向】APK修改与反编译回编译

androidandroidstudiojava 2023-08-19 08:08:55 595人浏览 薄情痞子
摘要

【安卓逆向】反编译修改APK回编译 使用工具流程步骤Apktool相关安装与使用常用命令备查APK签名命令备查 实战练习反编译查看修改的地方使用Apktool反编译得到产物文件夹并进行修改回编APK 实用场景

在日常开发我们可能需要替换某些资源或者修改某些代码,但是我们没有源码环境只有一个APK或者想通过编写一些工具,实现重打包,这时我们可以使用apktool 进行对APK包的修改以及重打包

使用工具

工具功能
jadx-gui反编译查看源码
apktool反编译/回编 APK
Android sdk进行APK签名

流程步骤

  1. 使用jadx-gui反编译查看源码,确定要修改的点
  2. apktool 反编译出smail文件
  3. 修改smail文件
  4. 使用apktool 回编APK
  5. 重签名

Apktool相关

安装与使用

@echo offsetlocalset BASENAME=apktool_chcp 65001 2>nul >nulrem Find the highest version .jar available in the same directory as the scriptsetlocal EnableDelayedExpansionpushd "%~dp0"if exist apktool.jar (set BASENAME=apktoolGoto skipversioned)set max=0for /f "tokens=1* delims=-_.0" %%A in ('dir /b /a-d %BASENAME%*.jar') do if %%~B gtr !max! set max=%%~nB:skipversionedpopdsetlocal DisableDelayedExpansionrem Find out if the commandline is a parameterless .jar or directory, for fast unpack/repackif "%~1"=="" goto loadif not "%~2"=="" goto loadset ATTR=%~a1if "%ATTR:~0,1%"=="d" (rem Directory, rebuildset fastCommand=b)if "%ATTR:~0,1%"=="-" if "%~x1"==".apk" (rem APK file, unpackset fastCommand=d):loadjava -jar -Duser.language=en -Dfile.encoding=UTF8 "%~dp0%BASENAME%%max%.jar" %fastCommand% %*rem Pause when ran non interactivelyfor /f "tokens=2" %%# in ("%cmdcmdline%") do if /i "%%#" equ "/c" pause

常用命令备查

  • 反编译
apktool  d -o <output_dir> test.apk
  • 回编
apktool b <input_dir> -o result.apk

APK签名命令备查

[安装的sdk路径]\build-tools[SDK版本号]\apksigner.bat

  • v1 jarsigner 签名
jarsigner -verbose -keystore F:\test123456.jks -signedjar F:\test\signed.apk F:\test\unsign.apk  [别名]
  • apksigner 签名
apksigner sign --ks F:\test123456.jks --ks-key-alias test123456 --out F:\test\signed-motifyapp.apk F:\test\motified-app.apk
  • 签名验证
apksigner verify -v F:\test\signed-motifyapp.apk

实战练习

写一个简单的demo,点击hello Word 会变成 其他文本,目标是修改文本内容

反编译查看修改的地方

因为是自己写的,所以直接找到要修改的类
在这里插入图片描述

使用Apktool反编译得到产物文件夹并进行修改

  • 输入命令apktool d -o test app-release.apk得到产物
  • 得到产物后,根据Jadx反编译的路径找到对应的smail文件,直接用文本工具打开查看smail语句,修改对应的点,这里修改很简单,就是把点击后的修改的文本,改为"changed click text",然后保存文件
  • 实际修改可以查看smail语句的语法或者自己写一段代码,复制对应的smail语句,再替换到所在的地方

在这里插入图片描述
在这里插入图片描述

回编APK

  • 输入命令apktool b test -o changed.apk得到未签名的APK
  • 使用 apksigner 进行重签名 apksigner sign --ks E:\apktools\test.jks --ks-key-alias test --out E:\apktools\signed-changed.apk E:\apktools\changed.apk
  • 安装验证修改成功

实用场景

  • 多渠道出包
  • 资源替换重打包工具

来源地址:https://blog.csdn.net/weixin_41802023/article/details/129112476

--结束END--

本文标题: 【安卓逆向】APK修改与反编译回编译

本文链接: https://lsjlt.com/news/375232.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

猜你喜欢
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作