【工具评测】Batch Apktool 3.8.0十周年纪念版:一站式安卓逆向与汉化实战指南

1. 从命令行到图形化:为什么你需要Batch Apktool?

如果你曾经对某个安卓应用的功能感到好奇,或者想为某个小众应用制作一个中文版本,那你很可能听说过“反编译”这个词。在安卓逆向的世界里,Apktool 就像是一把瑞士军刀,几乎无人不知。但说实话,我第一次接触命令行版的 Apktool 时,感觉就像在学一门新的外语。你得记住各种命令参数,比如 apktool d your_app.apk -o output_folder 来反编译,再用 apktool b output_folder -o new_app.apk 来重新打包。这还没完,打包完还得找签名工具,一套流程下来,新手早就晕头转向了。

这就是 Batch Apktool 诞生的意义。它不是要取代经典的 Apktool,而是为它穿上了一件极其友好的“图形化外衣”。你可以把它理解为一个“逆向工程工作台”或者“一站式管理平台”。作者 BurSoft 将这个工具维护了十年,最新的 3.8.0 版本更是被命名为“十周年纪念版”,其稳定性和功能集已经达到了一个非常成熟的高度。

我自己的体验是,以前用命令行工具,经常因为一个参数写错,或者资源文件处理不当,导致反编译失败或者重新打包后应用闪退。而 Batch Apktool 把所有这些容易出错的步骤都封装成了图形界面上的一个个按钮和选项。你不需要知道 aapt2aapt 的区别(至少一开始不需要),也不用担心签名流程,因为它把 apksignerzipalign 都集成好了。对于绝大多数以学习、研究、本地化(比如我们常说的汉化)为目的的用户来说,它极大地降低了门槛,让你能把精力集中在“修改什么”上,而不是纠结于“怎么才能开始修改”。

2. 十周年纪念版究竟更新了什么?

这次更新的 3.8.0 版本,版本号本身可能看起来变化不大,但内容却是实实在在的“干货”堆砌。作为十周年纪念版,它集成了截至发布时最新、最稳定的工具链,并且加入了一些思考了很久的实用功能。

Batch Apktool 3.7.5 by Bursoft Batch Apktool是一个强大的shell,它结合了多个工具来处理APK文件。 允许批量解码、解码、修改资源和SMALI代码、重新编译、签名、对齐(Zipalign)APK、ZIP、JAR文件。 此外,您还可以连接插件、查看Apk、Jar和Dex源代码、通过ADB使用设备等。 工作准备: 解压档案。在实用程序路径和正在处理的文件名中,避免长路径、特殊字符(感叹号!,利息、马车等)和俄语字母。 1.脱氧: 1.1将固件/系统文件夹的所有内容放入实用程序的\u系统文件夹中。您可以直接从设备上合并文件,请参阅P。3.4。 1.2指定Android脱氧固件版本相对应的API级别(菜单项[84])。如果\u system文件夹中有build.prop文件,则将自动定义级别API。 1.3选择SMALI版本(菜单[83]),使用该版本进行脱模。SMALI-1.4.2仅适用于API级别<=17。 1.4选择菜单项[01]。文件将直接在\u system文件夹中脱氧。此文件夹的内容已准备好固件到设备。 1.5如果固件中有Simlinki,则它们将显示在解码日志的末尾。 1.6要复制脱氧APK或JAR文件进行进一步处理,请单击菜单[02]或[03]。文件将分别复制到\u input\u apk或\u input\u jar文件夹。 2.分解和重组: 2.1将要处理的文件放入\u input\u apk文件夹。 2.2如果您正在从固件中解析系统文件,请将该固件的System/Framework文件夹中的所有APK文件放入\u Framework实用程序文件夹中;否则,将\u framework文件夹留空。 2.3选择菜单项[1]。在\u input\u apk文件夹中,将出现拆分的应用程序。 2.4进行必要的更改。 2.5如果您正在解析系统文件,请禁用[89]选项-这将保留系统APK的原始签名。如果启用[89]选项,则在重新编译过程中,应用程序将使用[90]中选择的密钥签名。 2.6选择[3]。重新包装、签名(如果启用)和对齐的APK将位于\u out\u APK文件夹中。 3.ADB: 允许您通过Android调试桥设备一起工作。要使ADB正常工作,必须: 在PC上: -为您的设备安装ADB驱动程序。 在设备上: -启用开发人员设置。要做到这一点,请转到“设置”->“关于手机”,并多次单击“构建号”。 -在“设置”中,为开发人员启用调试模式,在“超级用户模式”中,选择“应用程序和ADB”。 3.1第[10]段应从ADB开始。可能有两种连接选项: -通过USB连接并显示连接的设备。当第一次连接到设备上的弹出窗口时,必须在设备上放置“始终允许从该计算机进行调试”框。 -Wi-Fi连接。模式需要客户端来运行,例如,https://play.google.com/store/apps/details?id=com.ttxapps.wifiadb 3.2第[11]-在设备上安装APK3.3第[12]-请求ADB的超级用户权限并重新安装/System文件夹进行记录。 3.4项目[13]-将手机上相应文件夹中的文件复制到系统实用程序文件夹中。 3.5项目[14]-将文件复制到手机上的相应文件夹。 第[1]项直接通过ADB推送复制文件,为此,必须通过第[12]项安装/System文件夹进行记录。如果项目[12]不能挂载要写入的文件夹/系统(ADBD错误无法在生产构建中作为根目录运行等),则必须使用[2]项中的复制。 [2]使用另一种方法使用SU二进制复制(必须为ADB shell授予超级用户权限)。 3.6项目[15]-将屏幕截图保存到项目文件夹中(需要Android 4.0或更高版本)。 3.7项目[16]-从屏幕录制视频并将其保存到项目文件夹(需要Android 4.4或更高版本)。 3.8第[17]-设备终端。 3.9项目[18]-输出关键系统日志(logcat(main、radio、events)、dmesg和bugreport)并将其保存到项目文件夹中的文件中。 [6]项的目的是保存内联固件方法表。如果固件不是用标准方法脱氧(仅适用于Android<5.0),这可能会有所帮助。 3.10第[19]-不同的重新启动选项。 3.11项目[20]-有关Android版本和文件系统的摘要。 3.12[21]-正确关闭ADB服务器。此命令必须终止ADB,否则安全设备检索将失败。 4.附加功能: 4.1项目[04]、[05]、[06]和[07]用于使用Baksmali Smali解压缩和重新编译AP
APK软件汉化教程 (转载请注明来自藕粉网www.Allphone.com.cn的Smwenzi,谢谢) 随着Android手机种类的不断丰富,各种应用软件也开始遍地开花,Android用起来也越来越爽了……不过有很多软件都是老外编的,虽然英文界面也能用,但是毕竟不如咱们中文看着舒服,特别是一些功能相对比较复杂的软件,中文界面还是很有必要的。因此,本人综合网上多位前辈大侠的教程,加上自己的一点心得,对如何汉化APK软件,进行简要说明。由于我也是个新手,很多地方也许会不完善甚至存在错误,请各位兄弟不吝赐教。 一、概述 目前,网上常用的APK汉化方法有三种: 一是使用Hex Worksho,这种方法操作繁琐、费时费力,而且经常出现搜不到想要修改的字符的情况; 二是使用汉化浪子大侠的Android ResEdit(目前最新版本AndroidResEdit v1.5),这个软件使用简单直观,但是对不在资源文件中的词条无能为力,只能用于简单的汉化; 第三种就是我在这里要向大家推荐的APKTOOL,他的原理是把APK进行反编译,生成程序的源代码和图片、XML配置、语言资源等文件。我们秩序对有关图片和语言资源等文件进行修改,再编译打包成APK并签名,就可以得到汉化版的APK软件了。 二、搭建汉化环境 由于APKTOOL工具是用Java编制的,因此需要电脑中安装了JRE或者JDK(JAVA工具,用JRE即可)。 下载地址:………… 接下来就是我们要用到的关键工具——APKTOOL。这个是我在其他论坛找到的leasea大侠集成的一个批处理,可以省去自己输入指令的麻烦,实现解包、打包、签名自动处理,我自己也作了一点小小的修改,在此谢谢leasea大侠。 下载地址:………… 还有一个辅助工具Notepad++,这是一个功能强大的文本编辑软件,可以在指定文件夹中搜索字符串,对于在不在资源文件中的词条汉化,用这个可以极大减少工作量。 下载地址:………… 安装的步骤很简单了,下载上面三个文件,安装JRE和Notepad++,将APKTool压缩包解压到任意位置,就OK了。 另外,为了调试方便,推荐安装Android相应版本的SDK(或OMS),并建立虚拟机运行环境。当然用手机调试也可以,但是没那么方便而且容易发生不可预料的问题。关于虚拟机环境搭建请参考其他资料。 三、解包软件 将你需要汉化APK文件,放到APKTOOL文件夹下面,双击运行“解包软件.BAT”,批处理会自动识别APK文件并开始解包,在这里我用FlipSilent(一个翻转静音工具)作为示例。 解包出来的资源存储在“汉化中的资源”文件夹中,原始的APK文件则被备份到“原始软件备份”文件夹中。 打开解包的资源文件,里面有两个文件夹:Res存储的各种资源文件;Smail:存储的是反编译的程序代码。至此解包操作完成。 四、初步汉化 汉化的第一步,是汉化res文件夹里面的程序界面资源。一般来说,这个文件夹里面会包含以下文件夹: Drawable:程序调用的图标以及各种图片; layout-land:竖版界面xml描述文件; layout-port:横版界面xml描述文件; menu:菜单布局xml描述文件; values:字符串资源定义,我们要汉化的绝大部分工作就在这里面; xml:其他不再详细分类的布局xml描述文件。 根据软件的不同,文件夹可能会多些也可能会少些,具体内容大家打开一看就大概能知道是什么了。这里FlipSilent软件相对比较简单,所以只有三个文件夹,如下图: 在values文件夹下的文件: 一般来说,汉化需要处理是arrays.xml和strings.xml这两个文件。如何判断哪些是需要我们翻译的词条呢?有三种方法,综合起来一般就差不离了: 第一个当然是在使用软件中界面出现的词条,这个可以用手机仔细查看,当然有一部分可能很少出现的提示会有遗漏; 第二个凡是一对tag里面的,一般情况下就是需要翻译的英文字符串。格式一般为:<item>*******</item> ,或<string name="****">****</string> 第三个是以大写字母开头的词条,一般都是需要汉化的。 注意:这三条要综合起来运用,特别是在比较大型的软件中,情况会比较复杂,需要自己不断摸索。 在解包FlipSilent软件中,没有arrays.xml文件,因此我们的对象就是strings.xml了。用记事本打开strings.xml文件,内容如下: 对比一下FlipSilent软件运行界面,一切都就都明白了…… 接下来的工作,就是考验各位的英语水准了…… 上面就是我翻译的结果了,水平不行,大家见笑…… 修改完毕了,保存退出。 五、打包签名 改完了strings.xml,下面就是打包看看效果了……有了leasea大侠的批处理,就很简单了,什么都不用管,双击运行“打包签名.BAT”就可以了。 如果出现的是上面的信息,那么恭喜你,过关了…… 如果有多余的信息,并提示你找不到“已汉化签名的软件”文件夹,那么说明你修改不该修改的词条,好好找找吧,这个就没办法一概而论了。 在弹出的资源管理器窗口里面,你就可以看到汉化后的软件了。现在试验一下吧。 注意:试验之前,要删除安装的原版软件,否则会安装失败的。 基本就搞定了……等等,怎么那个About按钮还是英文啊,对于追求完美的人,这是绝对不用需的。 可是在语言资源文件里面,就是找不到这个词啊。接着就是下一节了…… 六、深度汉化 先解释一下为什么还有一些词条没有汉化的原因。 一般而言,一个编写规范的Android程序,会把所有字符串资源都分离出来,放在values的strings.xml文件中,values目录中存放的是默认语言字符串资源(一般为英文)。APK程序在处理字符串资源时会先判断语言环境,然后自己调用对应语言的。可是,有的程序员会自觉不自觉地,将部分文字内容写到程序代码里面,因此就出现了在资源文件中找不到的词条了。 对这部分词条的修改,相对就比较复杂一些了,幸好我们有神兵利器:Notepad++。 打开Notepad++软件,选择菜单中的“搜索”—“在文件中查找”,查找目标中输入要查找的字符串,这里为“About”,在目录中,选择解包后的“汉化中的资源”文件夹中的“smali”文件夹,一定要勾选“包含子目录”选项。 选定后,点击“全部查找”按钮,NotePad++会将这个文件夹中所有包含“About”字符的地方给你列出来。 这里一共找到了6个,很明显前面的几个开头字符都是小写,不符合我们的要求,那么必然就是最后一个了,双击最后一行直接定位,修改为“关于软件”,然后保存…… 注意: 1.进行这部分修改的时候,不要在修改内容里面包含空格,否则极有可能在重新编译打包的时候出错; 2.在示例中需要修改的词条很简单,也很好找,但是实际操作中,可能会比这个复杂很多,尤其是可能搜索出很多一样的结果,究竟哪些能改,在这里的只有一个大致的判断方法,那就是只能修改const-string v* “***”  引号中的字符。 3.在同时出现多个重复的关键字时,请谨慎修改,有些可能是定义函数的, 具体参考http://code.google.com/p/smali/source/browse/#svn/dalvik-docs/opcodes 4.保存时的文本编码要设置为ANSI格式,具体操作在菜单栏的“格式”中。打包前确定classes 文件夹下没有其他无用文件,如notepad++的备份文件(为避免这种情况,请确认在菜单栏“设置”—“首选项”—“备份自动完成”中,禁用自动备份功能)。 现在再打包签名,安装试验看看效果。 已经改过了吧,现在就可以收工了…… 七、修改图标 软件的内容汉化完成了,应该说就搞定了,不过,软件的图标往往会手机的主题风格不一致,不够美观,甚至有的软件作者主要精力都在编程序上面,用的就是标准的小绿人,看不出来软件的功能。因此,对图标的美化也是有必要的。接下来我们对图标开刀。 还是在解包后的汉化资源中,这次我们的目标是res\Drawable下面的图片。原始图片是这样的: 我们要修改的是icon.png,注意左边“详细信息”里面的内容,显示该图像尺寸是48 x 48像素。剩下的就是用自己喜欢的图像替换它就可以了。我这里用的图像是藕粉网风格的,顺手把那个通知图标也换了,这个是24 x 24像素的,呵呵: 换完的效果就不单独上图了。 注意:编辑png图像,推荐使用Photoshop软件,兼容性好。这里我给大家附上一个藕粉风格图标的模板,希望大家能帮忙推广藕粉网。 图标模板下载地址:………… 八、其他 (一)一些软件中界面没有使用文字,而是调用的图片(这在游戏软件中更多见),对于此类界面的汉化,请参考替换图标,直接用同尺寸的图片替换就可以了。 (二)有的软件本身支持多语种,这样可能会在res文件夹下会出现多个以values开头的文件夹,对于这类软件,汉化也有两种做法: 一种是按照上面的方法,直接把默认语言文件夹values里面的资源都汉化掉,干脆利落,不过这样到了英文系统里面也显示汉字。 第二种方法,就在res目录里面建立对应的语言资源文件夹(简体中文资源的目录名是values-zh-rCN,繁体中文是values-zh-rTW),将英文资源values里面的arrays.xml和strings.xml复制到新目录里面进行汉化,让Android系统自己识别语种调用,从而达到在对应的语言环境中显示对应的界面。不过,如果软件的作者将一些词条放到了代码里面的话,这样汉化也就没什么必要了,因为代码中的词条是不会自己更换的,呵呵。 能把加密的XML文档转化为可见可编辑的形式。 打开google code发现Apktool更新了,居然支持win了。。。。 那本文就是一篇介绍在windows环境下使用Apktool的笔记。 安装 1.先装JAVA环境,JDK/JRE都行,官网下载 装过的就跳过吧 2.下载apktool.jar及相关文件,这里下apktool-1.0.0.tar.bz2 和apktool-install-windows-2.1_r01-1.zip 3.解压apktool.jar到 C:\Windows 解压apktool-install-windows.zip到任意文件夹(例如E盘根目录) 4.Win+R 运行CMD,用cd命令转到apktool-install-windows所在文件夹,输入apktool看看。会列出一些帮助的话就成功了。Apktool 命令 apktool d XXX.apk ABC 反编译XXX.apk到文件夹ABC apktool b ABC 从文件夹ABC重建APK,输出到ABC\dist\out.apk 然后我们反编译一枚软件玩玩… AutoMemoryManager的免费版底部有一条广告,去掉它吧。 把com.lim.android.automemman.apk放到同文件夹(我的就是E盘根目录) Win+R 运行CMD E:<回车> E:\>apktool d com.lim.android.automemman.apk AMM <回车> I: Baksmaling… I: Decoding resource table… I: Decoding resources… I: Copying assets and libs… 现在文件被decode到E:\AMM了,打开E:\AMM\res\layout\main.xml看,所有都可见了吧~ 编辑第59行 <com.admob.android.ads.AdView android:id=”@id/ad” android:layout_width=”fill_parent” android:layout_height=”wrap_content” admobsdk:backgroundColor=”#ff000000″ admobsdk:textColor=”#ffffffff” admobsdk:keywords=”Android application” /> 改为 <com.admob.android.ads.AdView android:id=”@id/ad” android:layout_width=”0.0dip” android:layout_height=”0.0dip” admobsdk:backgroundColor=”#ff000000″ admobsdk:textColor=”#ffffffff” admobsdk:keywords=”Android application” /> 然后CMD输入 E:\>apktool b AMM I: Checking whether sources has changed… I: Smaling… I: Checking whether resources has changed… I: Building resources… I: Building apk file… 用Auto-sign签名E:\AMM\dist\out.apk 安装 这样广告就不见了 再看,嘿嘿~很帅吧… 这其实就是改了AndroidManifest.xml里的ADmob广告ID罢了 Settings.Secure.setLocationProviderEnabled(getContentResolver(),LocationManager.NETWORK_PROVIDER, mNetwork.isChecked()); 根据mNetwork这个控件是否选中决定是否打开基站定位,mNetwork就是界面那个选择框
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值