INPUT VALIDATION ISSUES 3 - BUFFER OVERFLOW
- 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 13:
data:image/s3,"s3://crabby-images/ba7ff/ba7ffe8b63aafa1a1c673aee18a9ff3a1065c1e3" alt=""
- The applications prompts the user to enter any input able to crash the app.
- Entering 1111 the application just answers "Access denied!":
data:image/s3,"s3://crabby-images/4f557/4f5572ecadb57259c3b291cccd72c7fddde4fe4c" alt=""
- However, entering a long string of characters, let's say a string of 30 "1"s, the app stops after crashing:
data:image/s3,"s3://crabby-images/ea70b/ea70b07f35ca561d3e2ffb74d6148bb025b0f7f8" alt=""
data:image/s3,"s3://crabby-images/018cb/018cbb4b366db198657d3d5399edfdc8dfc33a30" alt=""
- To understand what has happened inside the app, it is very convenient to examine the log generated by the command logcat.
- We see a fatal signal (SIGSEGV = segmentation fault, or segmentation violation), because the operating system considers protected the memory address 0x31313131 (0x31 is the ASCII code for character "1"):
data:image/s3,"s3://crabby-images/0597b/0597bd6806f445180509d565e5543606490130d9" alt=""
data:image/s3,"s3://crabby-images/89231/8923146260260c5fcdad630c03de7a62362fc5b4" alt=""
- Looking up into the Java source code of the challenge, InputValidation3Activity.java:
data:image/s3,"s3://crabby-images/a241e/a241e7945bb68cd10fe4413c6b4b8922e85c1b87" alt=""
- The application is using JNI (Java Native Interface), what suggests that the method DivaJni is related to a program written in other language:
data:image/s3,"s3://crabby-images/47ab0/47ab0a05ab2747219b187711c38b9956e01d4f54" alt=""
data:image/s3,"s3://crabby-images/93150/93150ea1f7bcd967e4380e46caee421985f3e365" alt=""
- Going to the source code of the applications, there is a program divajni.c written in language C:
data:image/s3,"s3://crabby-images/d4074/d40746d8ce86768f6259be06d9bbae62faf0df3d" alt=""
- Opening divajni.c, there is a constant (#define CODESIZEMAX 20) defining a maximum value of 20, later used to determine the size of the string code:
data:image/s3,"s3://crabby-images/f0c9e/f0c9eeb694da7afa2781e8186c011ed073c83e74" alt=""
data:image/s3,"s3://crabby-images/4bb94/4bb94e44c5a91c96a604368b51fc6adbc532d879" alt=""
- Also, the function strcpy copies the string entered by the user over the variable code:
data:image/s3,"s3://crabby-images/d0e3e/d0e3e66660777ddb8adc845868b42b9faa5f54d8" alt=""
- The problem is that the function strcpy does not check whether the size of the destination's buffer is large enough to hold the source parameter.
- A consequence of function strcpy bad usage is the corruption of memory or buffer overflow, and eventually the crash of the application.