ANALYSIS WITH ANDROGUARD
- Androguard is an open source framework for iPython designed to analyze and perform reverse engineering with Android applications.
- Some of Androguard's functionalities include automated and scripting analysis of dex, odex, apk and xml binaries files, disassemble, decompiler, malware dissection, ...
- It can be found here:
https://github.com/androguard/androguard
data:image/s3,"s3://crabby-images/c3aeb/c3aeb483dd116d8b1f37fac05b2095a27cb14978" alt=""
- Once downloaded, let's unzip the file:
data:image/s3,"s3://crabby-images/b46e6/b46e6821bc84e9cd68d2ecddb617616b3719942b" alt=""
- The tool androlyze is part of the Androguard platform and allows static analysis of .apk applications:
https://androlyze.readthedocs.io/en/latest/
data:image/s3,"s3://crabby-images/a6537/a6537b1993509814b3fa92a101b3d2a19a3b02c6" alt=""
- Let's take the application box.apk as example. The whole path:
data:image/s3,"s3://crabby-images/7d7ad/7d7ad4e185999083fe2cd56da77e5024ca432218" alt=""
- Getting permissions of the application:
data:image/s3,"s3://crabby-images/c9695/c9695ae202e2eb2f8d9159b395c6efc433d15130" alt=""
- Detailing the permissions, for example .INTERNET is considered "dangerous" because allows full access to the network, for instance creating sockets:
data:image/s3,"s3://crabby-images/135db/135dbea4a7e4782e1d382e9668d409289405166d" alt=""
- Identifying the activities of the application:
data:image/s3,"s3://crabby-images/73aeb/73aeb108ba5262de8bec1c6e1d4345b35df5a724" alt=""
- Services:
data:image/s3,"s3://crabby-images/25506/25506870b61e0497325770c7aadb92740aab280b" alt=""
- Broadcast receivers:
data:image/s3,"s3://crabby-images/cb0d0/cb0d0d70695e131846fa7bdf24c4795a338b6baf" alt=""
- Signature in hexadecimal:
data:image/s3,"s3://crabby-images/5e287/5e287daa1858235aa09af878317dc7db6915e748" alt=""
- The package name:
data:image/s3,"s3://crabby-images/5ed2d/5ed2d0140e0b7eaf10ea20e4d88a44a876a1e90b" alt=""
data:image/s3,"s3://crabby-images/66bdf/66bdf1d464d483462063e4aa1c5b57a4d61f4434" alt=""
- Determining whether the application is valid or not:
data:image/s3,"s3://crabby-images/f560a/f560ad4181c42f322a2ba0a0967ea63b2757f39e" alt=""
- Files:
data:image/s3,"s3://crabby-images/d47d3/d47d33c196e1a67f9a8f0912a020693b1e771cc3" alt=""
data:image/s3,"s3://crabby-images/5e899/5e8998ade9d239e598a54a1b32b0a00a68b68b92" alt=""
- Now, let's retrieve classes and methods from the application:
data:image/s3,"s3://crabby-images/f4ad3/f4ad37f85724d89006d56f898a6479fc83fed9f3" alt=""
data:image/s3,"s3://crabby-images/cf180/cf1800143cafc90f60ce9a21761ec5b0e3d0a3a4" alt=""
- Writing a small script for getting the classes:
data:image/s3,"s3://crabby-images/3929d/3929d40cba4abe5db5fc9e3754f43a2f049889cb" alt=""
data:image/s3,"s3://crabby-images/37693/37693ec4a3251f605c2c7ddebc829b84a8c3b952" alt=""
- Same thing for the methods:
data:image/s3,"s3://crabby-images/5063f/5063f0049f222f0fdee4c30253c1db3040d590b3" alt=""
data:image/s3,"s3://crabby-images/0103e/0103edf870f70ac886e6d2b9ff0d6f92499820a3" alt=""
- The options and the scope of Androguard is immense. So far just a small approach to all the possibilities of this very handy framework for Android analysis.