COMMAND INJECTION

Command Injection is a vulnerability (Also known as Remote Code Execution(RCE)) where an attacker is able to execute commands through an application that will execute on a target machine on the operating system, using the privileges that the application is running with. For example, achieving command injection on a web server running as root will execute commands on the target with root privileges. Command Injection vulnerabilities are dangerous because they give an attacker the ability to directly interact with a vulnerable system, allowing the attacker to access sensitive data. 

Discovering Command Injections

The Command Injection vulnerability exists because applications use functions in programming languages to pass data to and to make system calls on the machines OS. For example, the below code takes data from a user in an input field named $title to search a directory for a song title.


  1. The application stores MP3 files in a directory contained on the OS.
  2. The user inputs the title they wise to search for and it's stored in the $title variable.
  3. The data within the $title variable is passed to the command grep to search a text file named songtitle.txt .
  4. The output of this search of songtitle.txt will inform the use whether this song exists or not. 
An attacker could instead abuse this application by injecting their own commands for the application to execute. Rather than using grep to search for a song title, they could try and read sensitive data. 

Discovering a Command Injection

Command injection can be detected in mostly one of two ways:
  • Blind Command Injection: There is no output from the application when testing payloads. An attacker will have to investigate the behaviours of an application to determine if a payload was successful.
  • Verbose Command injection: There is direct feedback from the application once a payload is tested.

Detecting Blind Command Injection
With Blind Command Injection, we cannot confirm a successful vulnerability by simply viewing the output from an application. Instead we can use the ping or sleep commands. For example, using ping , the application will hang for x seconds in relation to how many pings specified. 

Another method of detecting blind command injection is by forcing some output. This can be done by using redirection operators such as > . For example, we can execute whoami , redirect to a file and cat to read the contents of a file.

Testing command injection this way is often complex and requires experimentation, especially as Linux and Windows commands are different. 

The curl command can be used to test for command injection by using curl to deliver data to and from an application in a payload. For example, the below code snippet.
curl http://example.app/process.php%3Fsearch%3DThe%20Beatles%3B%20whoami .

Detecting Verbose Command Injection
Detecting Verbose Command Inject is potentially easier than detecting Blind Command Injection. Verbose Command Injection is when the application gives feedback or output as to what is happening or being executed. 


Useful Payloads for Linux:
  • whoami: See which user is running the application.
  • ls: Lists content of current directory.
  • ping: This command will invoke the application to hang.
  • sleep: This command will invoke the application to sleep, useful when the machine does not have sleep installed.
  • nc: Netcat can be used to spawn a reverse shell on the target machine.

Useful Payloads for Windows
  • whoami: See which user is running the application.
  • dir: Lists content of current directory.
  • ping: This command will invoke the application to hang.
  • timeout: This command will invoke the application to sleep, useful when the machine does not have sleep installed.

Remediating Command Injection

Command injection can be prevented in numerous ways. Everything from minimal use of potentially dangerous functions or libraries in programming languages, to filtering users input.

Vulnerable Functions
In PHP, many functions interact with the OS to execute commands via shell, these include:
  • exec() : Calling a system command
  • system() : Executing a system command and immediately displaying the output
  • passthru() : Executing a system command which we want the raw return form, normally binary.

This below snippet of PHP code only accepts input that is numerical:
  1. Only allows a specific pattern of characters (digits 0-9).
  2. The application will only then execute numerical data.


Input sanitisation
Input sanitisation is when an application specifies the formats or types of data a user can input. For example, an application may exclude certain file types or characters such as > , & and / .

The below code snippet uses the filter_input function to check whether any data submitted via an input form is a number or not. It must be a number to be considered valid input.




Bypassing Filters
One method of bypassing these filters is by using the hexadecimal values of the characters we wish to use as part of our payload. See here for examples.


Command Injection Practical

First we test the input box with an intended input (127.0.0.1) and we can see that the web server is responding with a ping to that IP adgress. We then append && whoami to create our payload. We are then shown which user is logged in to the machine.


Same command as above, but instead looking for flag.txt



Comments

Popular posts from this blog

BURPSUITE IN-DEPTH

FILE INCLUSION

PASSIVE AND ACTIVE RECONNAISSANCE