Linux Buffer Overflow With Command Injection
This program inputs a name from the user and prints out a "Goodbye" message. It then calls system() to print out the date. It uses two buffers in a subroutine to do that in an unsafe manner, allowing the name buffer to overflow into the command buffer.
When we execute the program we can see that it prints out the location of the name
buffer and the cmd
buffer, says "Goodbye", and executes the command "date", as shown above. We can also notice that the cmd
buffer is stored at a higher memory address.
Now let's try to overflow the program and cause a crash.
By typping 42 A characters, we can see that the program tries to execute "AA" as shown above. This tells us that after the 40th character there is a code injection point. So now we can try to inject a command to be executed instead of date
.
If we want to execute a command that needs a space in between, like for example ls -la
we need to use one of the many methods to escape spaces, since the space will be interpreted as the end of a string. Some of these methods are:
Adding a backslash character,
\
, before the spaceEnclosing the whole string in quotation marks
Using the Inter-Frame Spacing methacharacter,
$IFS
, instead of a space
Last updated