Форум программистов, компьютерный форум, киберфорум
Наши страницы

С++ для начинающих

Войти
Регистрация
Восстановить пароль
 
PlayaRC
5 / 5 / 0
Регистрация: 10.03.2012
Сообщений: 121
#1

Не получается сделать переполнение буфера - C++

09.06.2014, 01:58. Просмотров 289. Ответов 2
Метки нет (Все метки)

Всем привет! Нужно сделать переполнение буфера и подменить адрес функции на другой.

Если делаю так:
C++
1
2
3
4
5
6
7
    
void overflow(char *ptr)
{
    char buffer[2];
 
    strcpy(buffer, ptr);
}
то все работает, затирает адресс в eip, подменяет и вызывается другая функция, а вот если вот так:

C++
1
2
3
4
5
6
void overflow(char *ptr)
{
    char *buffer = (char *)malloc(2);
 
    strcpy(buffer, ptr);
}
то уже не работает, адрес не подменяет и программа просто закрывается без всяких ошибок\екзепшенов. В чем проблема? Прошу помощи, заранее спасибо!
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
09.06.2014, 01:58
Здравствуйте! Я подобрал для вас темы с ответами на вопрос Не получается сделать переполнение буфера (C++):

Переполнение буфера - C++
Добрый день! В общем: #include "stdafx.h" #include <iostream> using namespace std; int main(int argc, char* argv) { ...

Переполнение буфера - C++
В программе имеется форма и записывается текстовые файлы. Когда она запускается всё работает нормально, ProgressBar доходит до...

переполнение буфера - C++
Что такое переполнение буфера?

Переполнение буфера - C++
Не могу найти, где у меня ошибка, выдает переполнение буфера, подскажите пожалуйста. Здесь реализуется связный список #include...

Переполнение буфера - C++
Подскажите, пожалуйста кто-нибудь, в чем беда... Во время выполения программы пишет, что буфер переполнен, что точка останова смещена и...

Переполнение буфера - C++
Объясните почему вылетает ошибка и помогите исправить. Зарание спасибо возникло переполнение буфера, что привело к повреждению...

2
Croessmah
Ушел
Эксперт CЭксперт С++
13553 / 7704 / 872
Регистрация: 27.09.2012
Сообщений: 19,006
Записей в блоге: 3
Завершенные тесты: 1
09.06.2014, 02:03 #2
Цитата Сообщение от PlayaRC Посмотреть сообщение
В чем проблема?
в том, что эта память:
C++
1
char buffer[2];
выделена на стеке функции, там же, где и адрес возврата(который, кстати, может быть защищен и тогда так просто его не перезаписать).
А эта память:
C++
1
char *buffer = (char *)malloc(2);
где-то в куче. Как вариант, брать адрес самого указателя, кастовать его к char* и уже от него отталкиваться.
1
PlayaRC
5 / 5 / 0
Регистрация: 10.03.2012
Сообщений: 121
09.06.2014, 10:36  [ТС] #3
Цитата Сообщение от Croessmah Посмотреть сообщение
Как вариант, брать адрес самого указателя, кастовать его к char* и уже от него отталкиваться.
можно подробнее, пожалуйста? очень нужно сделать это именно через malloc, желательно с легким примером

Добавлено через 8 часов 20 минут
и уже от него отталкиваться
в какую сторону хотя бы отталкиваться?
0
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
09.06.2014, 10:36
Привет! Вот еще темы с ответами:

Переполнение буфера! (наверное) - C++
Идет открытие порта звуковой карты, получение битов, запись битов в буфер и дальнейшие манипуляции с ним (пока только вывод в текстовый...

Переполнение буфера, адрес возврата - C++
Подскажите пожалуйста, где можно найти адрес возврата при переполнении буфера. Visual Studio 2012 windows 8.1

Переполнение буфера и его эксплойты - C++
Добрый вечер) Есть такая прога, которая выглядит следующим образом: #include <cstdio> int checkCredentials() //performs credentials...

Переполнение буфера . Что делать ? - C++
#include "stdafx.h" #include <conio.h> #include <stdio.h> #include <string.h> int main() { char in; /* строка...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
3
Ответ Создать тему
Опции темы

КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.
Рейтинг@Mail.ru