HOOKING WITH ANDBUG
- Layout for this exercise:
- Layout for this exercise:
data:image/s3,"s3://crabby-images/13e36/13e363d5ee27da695a8e6e5a0fdcc6ace30d4592" alt=""
- Connecting Santoku to Nexus 5:
data:image/s3,"s3://crabby-images/452ac/452ac8a8f2f36be3294409226cb26fd02d7f67e4" alt=""
0 - INSECURE BANK
- To illustrate the exercises of this post, it will be used the InsecureBank application, written by Dinesh Shetty.
- InsecureBank is an intentionally vulnerable application used to gain training on different Android platform attacks.
- In this exercise we'll see insecure logging and how to hook the application on the go with the tool AndBug.
data:image/s3,"s3://crabby-images/722e0/722e0c43b635603d3ce1be5f2602cd7edffa1cd4" alt=""
- Installing the application from Santoku to Nexus 5, using ADB:
data:image/s3,"s3://crabby-images/1556d/1556da9b0c3ed2fd82d283f77e49bcd57a507712" alt=""
data:image/s3,"s3://crabby-images/cb547/cb5477c42f4acb60aecf1241666e657338987300" alt=""
- InsecureBank.apk works in a client/server model, so the server runs at Santoku on port 8888 and the client on the mobile device.
- Starting the server on Santoku with the script app.py, located inside the folder AndroLabServer:
data:image/s3,"s3://crabby-images/3b30f/3b30f41272b706f96c82f83ee0471cd2fee4b5d7" alt=""
data:image/s3,"s3://crabby-images/a98ea/a98ead3fac3e3fd8ea69f376b84a89957e0dc9b1" alt=""
- Starting the application at the mobile device:
data:image/s3,"s3://crabby-images/880b6/880b6a3db1729793e30a5fcfd6932c66b637d1b5" alt=""
- Configuring the preferences:
data:image/s3,"s3://crabby-images/4758a/4758a89b522e34dcfe62cae90ad49dea6fc59e40" alt=""
- Serveip is Santoku's IP:
data:image/s3,"s3://crabby-images/67027/67027acead7e896183033e633abcfbad7c4b59f2" alt=""
- Listening port for the server is 8080:
data:image/s3,"s3://crabby-images/d98c2/d98c28b6a2937cdcbffa6b632038d3e6f7e1a13e" alt=""
1 - INSECURE LOGGING
- Once the applications is running, let's detect its PID:
data:image/s3,"s3://crabby-images/f391b/f391ba3a1f1b1d87c6a7d16e49853f3e18be00b9" alt=""
- Logging the application with ADB logcat:
data:image/s3,"s3://crabby-images/ee452/ee4523211ec28e7f59beb03f6c8b49601d9c6a80" alt=""
- Introducing the default credentials and signing in:
username: dinesh
password: dines@123$
data:image/s3,"s3://crabby-images/c35e4/c35e43079c1a65da410b59caaf19140c4929378c" alt=""
- logcat informs immediately about the login trial:
data:image/s3,"s3://crabby-images/de0d7/de0d79bb2c243f980cf5164df3445994de7aa773" alt=""
- Then, performing a transaction of 1 million dollar from Account 1111 to Account 2222:
data:image/s3,"s3://crabby-images/c9ec0/c9ec08a0b9aae397f8f8d3b681fd0664f0614656" alt=""
- Again, the logging debugger logcat informs immediately about the trasaction:
data:image/s3,"s3://crabby-images/be26e/be26e0ddfd5c725c18dded6819a16ad4c185312e" alt=""
data:image/s3,"s3://crabby-images/ae0ba/ae0ba05ea2f10aeeab4a47b519b80d110d63de38" alt=""
2 - HOOKING WITH ANDBUG
- Hooking an application is a very useful technique to analyze and understand on the go how applications work.
- AndBug is a wrapper around the JavaTM Debug Wire Protocol (JDWP), what is the protocol used for communication between a debugger and the Java virtual machine (VM) which it debugs, called the target VM.
- AndBug allows to analyze the methods and the passed arguments while the applications is being run, by setting trace and hookup points on those methods.
- AndBug can be found here:
https://github.com/swdunlop/AndBug
data:image/s3,"s3://crabby-images/1519b/1519b54e85ce55c5fb47f19c5a46d41d5d0ae455" alt=""
- Once AndBug downloaded and installed on Linux Santoku:
data:image/s3,"s3://crabby-images/1466c/1466c2c70ef334cfd9e81339feb4b93ffc7df8ff" alt=""
- Installing the setup.py file:
data:image/s3,"s3://crabby-images/92e7a/92e7a4d020683f7307a85e23bba1921cc94b6a03" alt=""
- Looking up for the PID of the application insecurebank.apk:
data:image/s3,"s3://crabby-images/fe372/fe372052dbd2c4fed72e8f578892a963c01e6d20" alt=""
- Using the command andbug over the PID, and loading the classes for the package of the application:
data:image/s3,"s3://crabby-images/bb4db/bb4db87f9bff3d97d4cc8c440105fb3aebf96e66" alt=""
- Checking what are the methods used by the .RestClient class:
data:image/s3,"s3://crabby-images/53de8/53de8797aa66ca3d0227687dc26a56e0d897db4e" alt=""
- Setting up a hook for the .dotransfer method:
data:image/s3,"s3://crabby-images/8be0c/8be0c107b53bd04a1152ffa188844295ae0e42f8" alt=""
- Performing a transaction with the mobile application:
data:image/s3,"s3://crabby-images/ff99a/ff99a396313b08dc190aa9ed9cb8eef20d0cbfff" alt=""
- When the .dotransfer method is called and the arguments passed to the application, AndBug displays remotely all the details about the transaction:
data:image/s3,"s3://crabby-images/833a6/833a6f2cb59fcc0cacbd0dd948b25cc5496ce662" alt=""