Hi !!
In the latest commit of androguard, I added a new program to transform dex/class/jar/apk files into an xgmml file, to visualize the control flow graph, or functions call with cytoscape ( to handle large graph ). (All links to images are in an high definition).
So, the first step is to create the xgmml file with your application :
$ ./androxgmml.py -i toto.apk -o toto.xgmml
The option "-i" is for the input file (APK, JAR, DEX, CLASS), and the option "-o" for the output xgmml file. And the option "-f" will add automatically function calls into the graph.
If I try with the following example (source code here), I have the following xgmml. In cytoscape, I can import the xgmml file, and choose the hierachical layout or the spring layout. By default, the edge target arrow are not present, but you can add a shape into VizMapper (in cytoscape).
data:image/s3,"s3://crabby-images/33479/33479c4582465e766671557c28043a685bd6a285" alt=""
data:image/s3,"s3://crabby-images/c1abb/c1abb8a87f90620ce95404242137544305863176" alt=""
I tried to visualize the geinimi trojan, so you can find an export of an original application (xgmml, png) and an infected version (xgmml, png).
data:image/s3,"s3://crabby-images/24993/2499317e17ff6573459908e6bfde3fee2c4ade1c" alt=""
data:image/s3,"s3://crabby-images/fe3e8/fe3e829646c264e1b792f0e060d7ba71d8697cd6" alt=""
In cytoscape, you can for example compare two networks (Plugins -> Network Modifications -> Compare Two Networks). In this case we will see the injected function :
data:image/s3,"s3://crabby-images/110c0/110c013b986d0a5ea7b7e7aca62777759eb3d1a8" alt=""
And of course you can zoom into a particular function with cytoscape :
data:image/s3,"s3://crabby-images/d6cb3/d6cb326c3261064c3fb534385554861cbd157e47" alt=""
Bye !
No comments:
Post a Comment