Android Reverse Engineering and Decompilation

Reverse engineering of android java app using apktool, dex2jar, jd-gui to convert .apk file to .java.

By reverse engineering of android app (.apk file) we can get following :

  • understand how a particular UI in an App is constructed
  • reading AndroidManifest.xml – permissions, activities, intents etc in the App
  • native libraries and images used in that App
  • obsfucated code ( android SDK, by default, uses ProGuard tool which shrinks, optimizes, and obfuscates your code by removing unused code and renaming classes, fields, and methods with semantically obscure names.

 

Required Tools :

Download the followings first.

Using ApkTool

- to extract AndroidManifest.xml and everything in res folder(layout xml files, images, htmls used on webview etc..)

Run the following command :

>apktool.bat d sampleApp.apk

It also extracts the .smali file of all .class files, but which is difficult to read.

##You can achieve this by using zip utility like 7-zip.

Using dex2jar

- to generate .jar file from .apk file, we need JD-GUI to view the source code from this .jar.

Run the following command :

 >dex2jar sampleApp.apk

Decompiling .jar JD-GUI

- it decompiles the .class files (obsfucated- in case of android app, but readable original code is obtained in case of other .jar file). i.e., we get .java back from the application.

Just Run the

jd-gui.exe and File->Open to view java code from .jar or .class file.

You May Also Like -

 
Reference: Android Reverse Engineering – decompile .apk-.dex-.jar-.java from our JCG partner Ganesh Tiwari at the GT’s Blog blog.

Do you want to know how to develop your skillset to become a Java Rockstar?

Subscribe to our newsletter to start Rocking right now!

To get you started we give you two of our best selling eBooks for FREE!

JPA Mini Book

Learn how to leverage the power of JPA in order to create robust and flexible Java applications. With this Mini Book, you will get introduced to JPA and smoothly transition to more advanced concepts.

JVM Troubleshooting Guide

The Java virtual machine is really the foundation of any Java EE platform. Learn how to master it with this advanced guide!

Given email address is already subscribed, thank you!
Oops. Something went wrong. Please try again later.
Please provide a valid email address.
Thank you, your sign-up request was successful! Please check your e-mail inbox.
Please complete the CAPTCHA.
Please fill in the required fields.

5 Responses to "Android Reverse Engineering and Decompilation"

  1. With AndroChef Java Decompiler you can decompile apk., dex, jar and java class-files. It’s simple and easy. http://www.androiddecompiler.com/

  2. Freeman Mobile says:

    This way is just fine!
    But JD-GUI homepage has changed!
    Follow this tutorial to get updated link of JD-GUI
    How to decompile Android APK file

  3. Venkatesan says:

    Hi,

    I am very much eager to become a very good Android Development Engineer.I need one help from you.Currently I am having Source files,fully layout file and a manifest file.Will u go through it and compile it and help me.This project will help me out to become a very good Android Engineer.please help me.

    Thanks and Regards,
    Venkatesan.R

  4. Hey Ganesh says:

    Is is possible to get native libraries using APK file, Thank you!

  5. How to retrieve native libraries from apk file.

Leave a Reply


× 2 = six



Java Code Geeks and all content copyright © 2010-2014, Exelixis Media Ltd | Terms of Use | Privacy Policy | Contact
All trademarks and registered trademarks appearing on Java Code Geeks are the property of their respective owners.
Java is a trademark or registered trademark of Oracle Corporation in the United States and other countries.
Java Code Geeks is not connected to Oracle Corporation and is not sponsored by Oracle Corporation.
Do you want to know how to develop your skillset and become a ...
Java Rockstar?

Subscribe to our newsletter to start Rocking right now!

To get you started we give you two of our best selling eBooks for FREE!

Get ready to Rock!
You can download the complementary eBooks using the links below:
Close