wisemonkeys logo
FeedNotificationProfileManage Forms
FeedNotificationSearchSign in
wisemonkeys logo

Blogs

Explaining Buffer Overflow with Example

profile
Genius Ape
Dec 01, 2018
0 Likes
0 Discussions
573 Reads
Firdous Shaikh       Author : Firdous Shaikh     

Let’s understand Buffer Overflow

A buffer is a temporary area for data storage (also used for storing program code). When more data (than was originally allocated to be stored) gets placed by a program or system process, the extra data overflows. It causes some of that data to leak out into other buffers, which can corrupt or overwrite whatever data they were holding. If this overwrites adjacent data or executable code, this may result in wrong program behaviour, including memory access errors, incorrect results, and crashes. Exploiting the behaviour of a buffer overflow is a well-known security exploit. On many systems, the memory layout of a program, or the system as a whole, is well defined. By sending in data designed to cause a buffer overflow, it is possible to write into areas known to hold executable code and replace it with malicious code.

The Buffer Overflow attack example

C and C++ programming languages provide no built-in protection against accessing or overwriting data in any part of memory and do not automatically check, whether the data written in the data-type is within its boundaries. So here, we use an array which is a built-in buffer data type, that can intake inputs for our demo. The program works perfect when the inputs are inside the range, but when value size increases the range, the access violation, segmentation fault error is encountered by the user, given by the system:  

***stack smashing detected***: [execution] terminated

Aborted (core dumped)

  Our program is prototype to a larger and more diverse attack consequence, and much fierce attacks can take down entire RAM capacities to crash (also traits of a Denial of Service attack).   The Program… Explained!  
  1. The program starts with creating a character buffer, in which we will pass a string to test its range.
  2. The buffer (array) here, is 5 bytes plus the terminating NULL.
  3. Thus Maximum allocation can be 2 double words, i.e. we need to input more than 8 bytes for the buffer overflow to take place.
  4. That the user does not provide a value, the program handles that by terminating.
  5. If there is an input, the strcpy() copies the user input to the buffer, without any bound checking.
  6. Finally, the output is according to the input range.
        The Program
#include <stdio.h> #include <string.h> #include <stdlib.h> int main(int argc, char *argv[]) { char buffer[5]; if (argc < 2) { printf("strcpy() NOT executed....\n"); printf("Syntax: %s <characters>\n", argv[0]); exit(0); } strcpy(buffer, argv[1]); printf("buffer content= %s\n", buffer); // you may want to try strcpy_s() printf("strcpy() executed...\n"); return 0; }  
  Steps for execution (The C program can be run in its compiler, over all platforms. Here we have used Ubuntu Linux).  
  1. Save the program in any editor with the extension .cpp (blowfish.cpp)
  2. Make sure you have the compiler, interpreter installed. In the terminal, type the following.

sudo apt-get install g++

sudo apt-get update

 
  1. To compile the program, type:

g++ -g3 –ggdb -o0 –Wall –Wextra –unused –o BufferOverFlowOP bufferoverflow.cpp   –lcryptopp

 
  1. To run the program, type:

./BlowfishOP [input range]

      The Output: Buffer Overflow with Example

Comments ()


Sign in

Read Next

The Power of Forensic Watermarking in the Fight Against Content Piracy

Blog banner

Fault Tolerance

Blog banner

38_Exploring The Honeynet Project

Blog banner

Proof-of-Stake (PoS)

Blog banner

Linux Memory Management

Blog banner

INTRODUCTION TO C#

Blog banner

Evolution of Operating system

Blog banner

The Features of Blockchain

Blog banner

Session Hijacking

Blog banner

Swiggi

Blog banner

Deadlock

Blog banner

How covid-19 impacted Social media ad spend forecast globally

Blog banner

MODERN OPERATING SYSTEMS

Blog banner

Patola Outfits for the Modern Wardrobe: Reviving Indian Handloom in Style

Blog banner

Data is an asset and it is your responsibility!

Blog banner

File system implementation

Blog banner

PYTHON

Blog banner

Gamer life

Blog banner

The Peephole

Blog banner

Modern Operating System

Blog banner

10 Amazing facts about Tokyo Ghoul

Blog banner

How to Grow Your Brand on YouTube Without a Big Budget

Blog banner

Memory Management in Operating System

Blog banner

How return on investment is defined in IT services

Blog banner

Supervised and Unsupervised Learning

Blog banner

Go Daddy

Blog banner

QUANTUM COMPUTING IN SECURITY:A GAME CHANGER IN DIGITAL WORLD

Blog banner

VIRUS

Blog banner

Capacity management in ITSM

Blog banner

RAID - LEVELS OF RAID

Blog banner

semaphores

Blog banner

How Harshad Valia International School is nurturing India’s Young Minds?

Blog banner

GIS info about Bermuda Triangle

Blog banner

TOGETHER WE CAN CONQUER #team

Blog banner

Which Smartphone Company Has the Largest Market Share in India?

Blog banner

Types of Threads

Blog banner

Can a Water Flosser Replace Manual Flossing? Here’s What Dentists Say

Blog banner

Security and E-mail

Blog banner

Why You Need 2FA (Two-Factor Authentication) On Your Email And Other Online Accounts

Blog banner

Importance of Education

Blog banner

Electronic Evidence in Cyber Forensics

Blog banner

Threat from Inside: Educating the Employees Against Cyber Threats

Blog banner