Dex to Java decompiler
Clone or download
Permalink
Failed to load latest commit information.
gradle/wrapper update gradle wrapper and dependencies Jul 28, 2018
jadx-cli core: show all decompilation errors in code comments (#313) Aug 23, 2018
jadx-core fix: lower regions count limit (#354) Sep 8, 2018
jadx-gui fix(gui): make correct size truncate for recent files list Sep 8, 2018
jadx-samples build jadx-gui.exe Mar 27, 2018
jadx-test-app build: remove sonar plugin from gradle config (fix #140) Dec 5, 2016
scripts feat(build): use semantic-release for automatic release publishing Aug 26, 2018
.codecov.yml build: disable codecov pull request report Feb 13, 2018
.gitignore feat(build): use semantic-release for automatic release publishing Aug 26, 2018
.gitlab-ci.yml build: fix gitlab config Sep 8, 2018
.gitmodules test: added module for check recompilation of test app Oct 10, 2015
.releaserc.yml chore: don't use labels for artifacts in github release Aug 26, 2018
.travis.yml build: skip gradle assemble before build Sep 1, 2018
CONTRIBUTING.md Create CONTRIBUTING.md Feb 2, 2018
LICENSE add full license text file Mar 14, 2015
NOTICE gui: support images view/unpack Mar 26, 2016
README.md feat(build): use semantic-release for automatic release publishing Aug 26, 2018
build.gradle feat(build): use semantic-release for automatic release publishing Aug 26, 2018
gradle.properties gui: fix build for java 10 and update dependencies (#291) Jun 2, 2018
gradlew update gradle wrapper to version 4.4.1 Jan 2, 2018
gradlew.bat update gradle wrapper to version 4.4.1 Jan 2, 2018
settings.gradle test: added module for check recompilation of test app Oct 10, 2015

README.md

JADX

Build Status Code Coverage SonarQube Bugs License semantic-release

jadx - Dex to Java decompiler

Command line and GUI tools for produce Java source code from Android Dex and Apk files

jadx-gui screenshot

Downloads

After download unpack zip file go to bin directory and run:

  • jadx - command line version
  • jadx-gui - graphical version

On Windows run .bat files with double-click
Note: ensure you have installed Java 8 64-bit version

Building from source

Java 8 JDK or higher must be installed:

git clone https://github.com/skylot/jadx.git
cd jadx
./gradlew dist

(on Windows, use gradlew.bat instead of ./gradlew)

Scripts for run jadx will be placed in build/jadx/bin and also packed to build/jadx-<version>.zip

Run

Run jadx on itself:

cd build/jadx/
bin/jadx -d out lib/jadx-core-*.jar
# or
bin/jadx-gui lib/jadx-core-*.jar

Usage

jadx[-gui] [options] <input file> (.dex, .apk, .jar or .class)
options:
 -d,  --output-dir           - output directory
 -ds, --output-dir-src       - output directory for sources
 -dr, --output-dir-res       - output directory for resources
 -j,  --threads-count        - processing threads count
 -r,  --no-res               - do not decode resources
 -s,  --no-src               - do not decompile source code
 -e,  --export-gradle        - save as android gradle project
      --show-bad-code        - show inconsistent code (incorrectly decompiled)
      --no-imports           - disable use of imports, always write entire package name
      --no-replace-consts    - don't replace constant value with matching constant field
      --escape-unicode       - escape non latin characters in strings (with \u)
      --deobf                - activate deobfuscation
      --deobf-min            - min length of name
      --deobf-max            - max length of name
      --deobf-rewrite-cfg    - force to save deobfuscation map
      --deobf-use-sourcename - use source file name as class name alias
      --cfg                  - save methods control flow graph to dot file
      --raw-cfg              - save methods control flow graph (use raw instructions)
 -f,  --fallback             - make simple dump (using goto instead of 'if', 'for', etc)
 -v,  --verbose              - verbose output
 -h,  --help                 - print this help
Example:
 jadx -d out classes.dex

These options also worked on jadx-gui running from command line and override options from preferences dialog

Troubleshooting

Out of memory error:
  • Reduce processing threads count (-j option)
  • Increase maximum java heap size:
    • command line (example for linux): JAVA_OPTS="-Xmx4G" jadx -j 1 some.apk
    • edit 'jadx' script (jadx.bat on Windows) and setup bigger heap size: DEFAULT_JVM_OPTS="-Xmx2500M"

Licensed under the Apache 2.0 License

Copyright 2018 by Skylot