Pentesting Android Apps-Part 2 -Static Analysis
In this post I am going to detail how to perform static analysion Android apps recieved by developer.
For my example ,I am going to work with a sample apk named Diva
Open the file with Android Studio
data:image/s3,"s3://crabby-images/16afa/16afafec122436cf5b86786e543915c6a7afcbac" alt=""
First thing to start when analyzing an Android app is to see the AndroidManifest.xml file
1)Look for allowBackup attribute :
This attribute if set to true can allow backup of your app and then attackers can get private data
Remediation : allowBackup attribute should be set to False
data:image/s3,"s3://crabby-images/9fafc/9fafc7626c5f88a1063ea7ede52741040ca496a0" alt=""
2) Look for debuggable attribute
This attribute determines whether the app is allowed to be debugged.
Remediation : debuggable attribute should be set to False
data:image/s3,"s3://crabby-images/373dc/373dcebaf1730392cf58802add0e74e2b8a27118" alt=""
3) Check for insecure permissions
Go through the permissions with the developer to identify the purpose of every permission set and remove unnecessary permissions.
Remediation:Remove any unwanted permissions
data:image/s3,"s3://crabby-images/f38aa/f38aa4b129be516e07120e7fb91c906d8b9e4ab9" alt=""
Next we will perform reverse engineer the apk file to see the code
Two tools wouldd be required for that :
Dex2jar
Use the command:
d2j-dex2jar.bat “path to apk file”
data:image/s3,"s3://crabby-images/cc544/cc54401850df3983621b2afc4a7eacefd0a0ba5f" alt=""
You get a jar file as output
Now open jd-gui
data:image/s3,"s3://crabby-images/70a83/70a8382e3a1970a8e42461860629a0843b28642f" alt=""
Open the jar file with jd-gui to see all the classes
data:image/s3,"s3://crabby-images/61ec3/61ec3009130ddbec926271eaa73b2d9e4b434c91" alt=""
Now you can analyze code to find if there are any unwanted data that can be leveraged by attackers.