HARCODING ISSUES 2 - SHARED OBJECT FILES
- Layout for this exercise:
data:image/s3,"s3://crabby-images/25dbf/25dbf5e40a197f43620a26ad2792e3b9c5621175" alt=""
- Connecting from Santoku to Nexus 5 with ADB:
data:image/s3,"s3://crabby-images/af15d/af15dac2b37d586fc8efc9120d93b15c822f51a1" alt=""
- Launching the application:
data:image/s3,"s3://crabby-images/c3f28/c3f2886851dac2b54795feadd45cf0e594145cf7" alt=""
- Clicking the tab for challenge 12:
data:image/s3,"s3://crabby-images/e3ac2/e3ac2c1270711ac0ec7f23c8cc98816cd3b266ef" alt=""
- The application prompts the user for a key. Introducing an invalid key the access is denied:
data:image/s3,"s3://crabby-images/b53d1/b53d1c2de8569781e079eebdc136bdf7227bfc61" alt=""
- Let's have a look to the Java source code of this challenge, Hardcode2Activity.java:
data:image/s3,"s3://crabby-images/4cf2e/4cf2e19b185716b276e4216eb000fc26a77aa07a" alt=""
- First, it is important to notice that in this activity the JNI (Java Native Interface) is used to validate the access.
- Java Native Interface is a programming framework that enables Java code running in a Java Virtual Machine (JVM) to call and be called by applications and libraries written in other languages such as C, C++ and Assembly.
data:image/s3,"s3://crabby-images/fd2ef/fd2efcbe51bb9d80a65f96bb81d01d0cf416d105" alt=""
data:image/s3,"s3://crabby-images/4428a/4428a89aa54c4d2233e306e288c19194a9bf5e0e" alt=""
- The access method gets a text using JNI and checks whether the text entered by the user matches or not the valid key.
data:image/s3,"s3://crabby-images/2e0b1/2e0b1034e2fcfbba6356fa9a419445b8f0db2399" alt=""
- Also, it is interesting to see the source code for DivaJni.java:
data:image/s3,"s3://crabby-images/bf6e5/bf6e5028f07e32ea84e088525e1be74d556c53bb" alt=""
data:image/s3,"s3://crabby-images/075bc/075bc1483ae48b8bb29e08101c9bd250b5e2db44" alt=""
data:image/s3,"s3://crabby-images/0e0f5/0e0f5379360b5361da1c11432e8e0df99faa0e76" alt=""
- Going into the application data directory, there is a lib directory:
data:image/s3,"s3://crabby-images/b4281/b42818f6e8b1af0048ff97164c1b8ed50b0ab2c2" alt=""
data:image/s3,"s3://crabby-images/ce99a/ce99a9b64f741d88ceb83ccc5414af3115670c70" alt=""
- Inside the lib directory there is a libdivajni.so file:
data:image/s3,"s3://crabby-images/c206f/c206f2ecab280d71b5b0ebd5edae6e21d75970c1" alt=""
- .so (shared object) files are a type of dynamic libraries used with Unix systems (similar to .DLL's for Windows). Code stored inside a .so file is not embedded in a binary. Instead it's just referenced, so the executable will depend on it and the code from the .so file is just added/loaded at runtime.
- .so files are usually written according to the ELF (Executable and Linkable Format) standard.
- In order to analyze the file, we can pull it out from the mobile device to Santoku:
data:image/s3,"s3://crabby-images/4dff4/4dff41142553f4f4d459d6cd51a1e9f2be03bf93" alt=""
- Now, the file is available to be opened at Santoku:
data:image/s3,"s3://crabby-images/41799/417994fea4b6f88eb06177fd8ec944bd452c5f5d" alt=""
- Either objdump or readelf can be used to disassemble the file, and look up into the .rodata segment (read only data, storings constant data) of the program with similar results:
data:image/s3,"s3://crabby-images/293db/293dbf9c3f2c7d91a11f57e5167637bd872a146c" alt=""
data:image/s3,"s3://crabby-images/2e1d2/2e1d25f2f55d0d2c3f8a0fe5a9f40c13e9e5b8b3" alt=""
- Both outputs indicate the presence of a "suspicious" string ... maybe the secret key?
data:image/s3,"s3://crabby-images/07399/0739972891bdf40b628f7d4d5f35c4bc40b5e75c" alt=""
- Running strings command over the file libdivajni.so, the string olsdfgad;lh appears again:
data:image/s3,"s3://crabby-images/f9bb0/f9bb098b1da818aaa25449ff4de326befdc91656" alt=""
- Finally, checking the source code of the application, the C program divajni.c holds the original C language program where the vendor key was stored as a constant (#define VENDORKEY "olsdfgad;lh"), and later compared with the function strncmp:
data:image/s3,"s3://crabby-images/2b1cc/2b1cc7e85bbc84a24d8678df32a7596148f0dad4" alt=""
data:image/s3,"s3://crabby-images/daa64/daa648e48b08fbaa6e1817fd023c15fbe52e7c5d" alt=""
data:image/s3,"s3://crabby-images/e0cb9/e0cb91db54fbc1db339d93ef7f19edafdf47c08c" alt=""
data:image/s3,"s3://crabby-images/ec706/ec706dedc3ebac5858323ec6236e65a9184758a0" alt=""
- The most important conclusion from this exercise would be to remember that developers often hardcode keys into .so files.
- To test the validity of the research, using the previous string the access is actually granted:
data:image/s3,"s3://crabby-images/9c3c2/9c3c26beed5a7247e447d704922c64c2ded67754" alt=""