A tool for reverse engineering Android apk files
Go to file
Connor Tumbleson 79cfdd179c
Correct Attribute Resolution (#3123)
* refactor: rename package_ to pkgId

* refactor: ResAttrDecoder takes ResTable

* fix: fallback on attr decoding to proper prefix

* fix: reverse order of processing to trust string pool 2nd

Android prefers the resource map value over what the String block has.
This can be seen quite often in obfuscated apps where values such as:
 <item android:state_enabled="true" app:state_collapsed="false" app:state_collapsible="true">
Are improperly decoded when trusting the String block.
Leveraging the resource map allows us to get the proper value.
 <item android:state_enabled="true" app:d2="false" app:d3="true">

* refactor: set default value if no string/res value
2023-07-04 12:06:53 -04:00
.github build(deps): bump gradle/gradle-build-action from 2.4.2 to 2.5.1 (#3119) 2023-07-03 05:47:33 -04:00
brut.apktool Correct Attribute Resolution (#3123) 2023-07-04 12:06:53 -04:00
brut.j.common build: include bleeding edge smali from source via jitpack (#2941) 2022-11-24 06:15:41 -05:00
brut.j.dir refactor: Replace to nio & apply CS inspection skips (#3055) 2023-05-13 06:12:22 -04:00
brut.j.util Correct aapt/aapt2 waiting too long on execution output (#3071) 2023-05-20 14:01:03 -04:00
gradle feat: Upgrade gradle to v8.2 (#3111) 2023-07-02 05:55:28 -04:00
scripts Revert "Update apktool.bat (#2930)" (#2931) 2022-11-12 11:35:40 -05:00
.editorconfig Add .editorconfig rules 2021-08-27 01:20:06 +08:00
.gitattributes fix: treat aapt binaries as binary 2021-08-28 14:34:13 -04:00
.gitignore build: ignore gradle.properties 2021-03-07 15:03:11 -05:00
.jitpack.yml feat: commit broken jitpack file to stop that service 2020-11-28 18:07:25 -05:00
build.gradle build(deps): bump com.google.guava:guava from 32.0.0-jre to 32.0.1-jre (#3092) 2023-06-12 06:18:45 -04:00
CONTRIBUTORS.md Move to official Google smali fork (#3051) 2023-04-28 19:30:06 -04:00
gradlew feat: Upgrade gradle to v8.2 (#3111) 2023-07-02 05:55:28 -04:00
gradlew.bat Upgrade Gradle version to 8.0.2 (#3016) 2023-03-05 10:55:09 -05:00
INTERNAL.md Binaries: aapt/aapt2 updates (July 5, 2022) (#2846) 2022-07-10 07:21:24 -04:00
LICENSE.md refactor: change license to markdown iteration (still apache2.0) 2021-09-01 07:33:02 -04:00
README.md docs: fix broken workflow CI image badge 2021-08-26 07:55:42 -04:00
ROADMAP.md docs: add note about dummy resources to roadmap 2022-09-20 07:24:55 -04:00
SECURITY.md build: add SECURITY.md 2019-07-14 08:09:21 -04:00
settings.gradle add application plugin to the apktool-cli (#3070) 2023-05-20 13:53:29 -04:00

Apktool

This is the repository for Apktool. If you are looking for the Apktool website. Click here.

Join the chat at https://gitter.im/iBotPeaches/Apktool CI Software License

It is a tool for reverse engineering 3rd party, closed, binary Android apps. It can decode resources to nearly original form and rebuild them after making some modifications; it makes possible to debug smali code step by step. Also it makes working with app easier because of project-like files structure and automation of some repetitive tasks like building apk, etc.

It is NOT intended for piracy and other non-legal uses. It could be used for localizing, adding some features or support for custom platforms and other GOOD purposes. Just try to be fair with authors of an app, that you use and probably like.

Support

Sponsored by

  • Sourcetoad - helping with a weekly sponsorship for continued improvement and maintenance of the project.

IDE of Choice

Security Vulnerabilities

If you discover a security vulnerability within Apktool, please send an e-mail to Connor Tumbleson at connor.tumbleson(at)gmail.com. All security vulnerabilities will be promptly addressed.