A buffer overflow, is a common software coding mistake that an attacker could exploit to gain access to your system.
Definition of a Buffer Overflow
- A buffer overflow occurs when more data is put into a fixed-length buffer than the buffer can handle.
- The extra data, that should go somewhere, can overflow into adjacent memory space, corrupting or overwriting the data held in that space.
- This overflow usually results in a system crash, but it also creates the opportunity for an attacker to run arbitrary code or manipulate the coding errors to prompt malicious actions.
- Many programming languages are vulnerable to buffer overflow attacks.
- However, the extent of such attacks varies depending on the language used to write the vulnerable program.
For example, code written in JavaScript and Perl is generally not susceptible to buffer overflows.
However, a buffer overflow in a program written in C, C++, Assembly or Fortran could allow the attacker to fully compromise the targeted system.
Key Concepts of Buffer Overflow
- This error occurs when there is more data in a buffer than it can handle, causing data to overflow into adjacent storage.
- This vulnerability can cause a system crash or, worse, create an entry point for a cyberattack.
- C and C++ are more vulnerable to buffer overflow.
- Secure development practices ought to embody regular testing to observe and fix buffer overflows.
- These practices include automatic protection at the language level and bounds-checking at run-time.
Executing a Buffer Overflow Attack
- Cybercriminals exploit buffer overflow issues to change the execution path of the applying by overwriting elements of its memory.
- The extra data may contain code designed to trigger specific actions — in effect sending new instructions to the attacked application that could result in unauthorized access to the system.
Buffer Overflow Causes
- Coding errors square measure usually the reason for buffer overflow.
- Common application development mistakes that can lead to buffer overflow include failing to allocate large enough buffers and neglecting to check for overflow problems.
- These mistakes are especially problematic with C/C++, which does not have built-in protection against buffer overflows.
- Consequently, C/C++ applications square measure typically targets of buffer overflow attacks.
Example: Buffer Overflow Attack
[Reference from “Buffer Overflow Attack Explained with a C Program Example,” Himanshu Arora, June 4, 2013, The Geek Stuff]
In some cases, an attacker injects malicious code into the memory that has been corrupted by the overflow. In other cases, the attacker simply takes advantage of the overflow and its corruption of the adjacent memory. For example, consider a program that requests a user password in order to grant the user access to the system. In the code below, the correct password grants the user root privileges. If the password is incorrect, the program will not grant the user privileges.
printf ("\n Correct Password \n");
pass = 1;
}
if(pass)
{
/* Give admin or root rights to user*/
printf ("\n Root privileges given to user \n");
}
return 0;
However, there's a possibility of buffer overflow during this program as a result of the gets() operate doesn't check the array bounds.
Here is an example of what an attacker could do with this coding error:
$ ./bfrovrflw
Enter the password :
hhhhhhhhhhhhhhhhhhhh
Wrong Password
Root privileges given to the user
In the above example, the program gives the user root privileges, even though the user entered an incorrect password. In this case, attacker gives an input with a length greater than the buffer can hold, creating buffer overflow, which overwrote the memory of integer “pass.”
Therefore, despite the incorrect password, the value of “pass” became non zero, and the attacker receives root privileges.
Preventing Buffer Overflows
By Following these step we can prevent Buffer Overflow:
1) Use safer versions of functions: Safer alternatives square measure obtainable for all the standard functions beset by buffer overflows.
For instance, strncpy and snprintf are safer than the older strcpy and sprint.
When new applications square measure being developed, make sure that solely the safer variants square measure used.
2) Dynamic runtime protection: Buffer overflow conditions square measure detected throughout the particular running of the program during this technique, and an attack thwarted.
Different techniques of dynamic runtime analysis are:
Memory Access checking: Here, verification code is added to the binary when the program is compiled. It checks access violations in real time.
Tools like Purify supply this protection with very little impact on performance.
Canary: once a call is formed, a "canary" is added to the return address; if a buffer overflow occurs, the canary will be corrupted.
So, before returning to the parent operate, the "canary" is checked again to see if it has been modified.
Stack Guard uses this system by implementing it as a patch to the GCC complier; this causes minimum performance delays.
Free BSD conjointly incorporates a patch obtainable to try and do this.
Array bounds Checking: once Associate in Nursing array is scan from or written to, this system double-checks whether or not the boundaries square measure being desecrated.
Jones & Kelly‘s GCC & Compaq C Complier patch perform array bounds checking, but at the cost of considerable performance degradation.
Copying come back Address: during this technique, the address is saved separately; thus even once a buffer overflow exploit overwrites the address on the stack, it's set back
to the original value when the function returns. Stack Shield - a development tool that uses this technique - works as an assembler file processor and is supported by GCC/G++ front ends.
Stack protect but, protects against solely overwriting of the address.
3) Non-executable stack: during this technique the stack is organized to not hold any possible code.
Kernel patches square measure obtainable for each UNIX and Solaris for configuring a non-executable stack.
Data execution hindrance in Windows XP and 2003 conjointly defend the stack against buffer overflow.
This method protects against stack-based buffer overflow attacks.
Heap-based overflows and static knowledge section overflows cannot, however, be prevented by this technique.
4)Static Analysis: In static analysis the ASCII text file is parsed for dangerous library calls and race conditions to notice potential buffer overflows.
Functions like strcpy and sprintf square measure liable to buffer overflows, so source code scanners are used to look for incorrect use of these functions.
RATS and SPLINT square measure 2 such tools; but static analysis is riddled with false positives.
Buffer Overflow Attack And its Prevention Techniques
TAGS: #Buffer Overflow, #Preventing Buffer Overflow,#Overflow prevention,#Buffer Overflow Mitigation, #What is Buffer Overflow,#cypheradda, #Prevention from buffer overflow
Hi
ReplyDeleteI visited your blog you have shared amazing information, i really like the information provided by you, You have done a great work. I hope you will share some more information regarding Cyber Security. I appreciate your work.
Thanks
Have a Great Day