Форум программистов, компьютерный форум CyberForum.ru

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

Войти
Регистрация
Восстановить пароль
 
ThePanix
0 / 0 / 0
Регистрация: 20.06.2014
Сообщений: 55
#1

Запись из внедренной dll в другую dll этого процесса - C++

28.06.2015, 05:56. Просмотров 369. Ответов 1
Метки нет (Все метки)

main.cpp
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
#include <Windows.h>
 
extern int writeprocess();
 
DWORD WINAPI MainThread(LPVOID lpParam)
{
 
    writeprocess();
    return S_OK;
}
 
BOOL APIENTRY DllMain(HANDLE hModule, DWORD _reason, LPVOID lpReserved)
{
    if (_reason == DLL_PROCESS_ATTACH)
    {
        CreateThread(NULL, NULL, &MainThread, NULL, NULL, NULL);
    }
 
    return true;
}
write.cpp
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
#include <Windows.h>
 
DWORD FindDmaAddy(int pointerLevel, DWORD offsets[], DWORD BaseAddress);
void WriteToMemory(DWORD addressToWrite, char* valueToWrite, int byteNum);
 
 
int writeprocess()
{
 
    //Ammo vars
    BYTE WriteValue[] = { 0xFF, 0xFF, 0x0, 0x0 };
    DWORD WriteHackAddress = { 0x538730 };
    DWORD WriteHackAddressOffsets[] = { 0x0, 0x0, 0x0 };
 
    DWORD WallHackAddr = FindDmaAddy(0, WriteHackAddressOffsets, WriteHackAddress);
 
 
    while (true)
    {
        if (WallHackAddr)
            WriteToMemory(WallHackAddr, (char*)WriteValue, 4);
        Sleep(10);
    }
}
 
DWORD FindDmaAddy(int pointerLevel, DWORD offsets[], DWORD BaseAddress)
{
    DWORD Ptr = *(DWORD*)(BaseAddress);
 
    if (Ptr == 0) return NULL;
    for (int i = 0; i < pointerLevel; i++)
    {
        if (i == pointerLevel - 1)
        {
            Ptr = (DWORD)(Ptr + offsets[i]);
            if (Ptr == 0) return NULL;
            return Ptr;
        }
        else
        {
            Ptr = *(DWORD*)(Ptr + offsets[i]);
            if (Ptr == 0) return NULL;
        }
    }
 
    return Ptr;
}
void WriteToMemory(DWORD addressToWrite, char* valueToWrite, int byteNum)
{
    unsigned long OldProtection;
    VirtualProtect((LPVOID)(addressToWrite), byteNum, PAGE_EXECUTE_READWRITE, &OldProtection);
    memcpy((LPVOID)addressToWrite, valueToWrite, byteNum);
    VirtualProtect((LPVOID)(addressToWrite), byteNum, OldProtection, NULL);
}
Как сделать чтобы писать из этой dll в другую dll этого процесса??
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
28.06.2015, 05:56     Запись из внедренной dll в другую dll этого процесса
Посмотрите здесь:

Добавление своей dll в список dll подгружаемых процессом чужого процесса - C++
Вообще вопрос такой,как можно внедрить свою dll в список Import чужого не запущенного процесса?Не изменяя структуры файла.

Выгрузить DLL из процесса. - C++
Извиняюсь если не туда..но если можно помогите) есть хак простой при влючении загружается в память war3.exe dll'ка ..хак этот не...

Выгрузка dll из процесса - C++
Здраствуйте. DLL подключается к процессу при его старте, и мне нужно чтобы при определенном условии он сам выгружался. Делаю это так: ...

Выгрузка DLL из стороннего процесса - C++
Как возможно выгрузить DLL из стороннего процесса, желательно пару примеров.

Dll файл в exe файле. Вшить dll libcurl - C++
Проблема такая что приходится таскать всегда libcurl.dll с собой. Надо все носить в одном exe. Enigma Virtual Box использовать нельзя,...

DLL VC++, права доступа на запись и удаление файлов - C++
Есть DLL, написанная на VC++. Она занимается тем, что удаляет, создает .txt-файлы и пишет лог в .txt-файл, а также переписывает таблицы в...

Подгрузка dll через dll - C++
Доброго времени суток! Около двух часов потратил на поиски нужной информации, но так ничего и не нашёл. Возможно, плохо искал. Вообщем...

dLL - C++
Мужики, помогите, нигде не могу найти. есть у меня dLL вот его cpp // Главный DLL-файл. #include &quot;stdafx.h&quot; #include...

dll - C++
1. Можно ли использовать DLL, созданную на одном языке программирования в программе на другом языке? 2. Я так понял, DLL работает только...

DLL на C++ - C++
Доброго времени суток, уважаемые форумчани! У меня собственно такой вопрос: Не могли бы Вы написать код для DLL на C++ который нужен...


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

Или воспользуйтесь поиском по форуму:
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
Убежденный
Системный программист
Эксперт С++
15247 / 6879 / 1092
Регистрация: 02.05.2013
Сообщений: 11,256
Завершенные тесты: 1
28.06.2015, 16:14     Запись из внедренной dll в другую dll этого процесса #2
Цитата Сообщение от ThePanix Посмотреть сообщение
Как сделать чтобы писать из этой dll в другую dll этого процесса??
dll тут вообще никаким боком.
Запись в память чужого процесса: VirtualProtectEx, если нужно, затем
WriteProcessMemory, затем восстанавливающий VirtualProtectEx. Запись в
память своего процесса такая же, только вместо WriteProcessMemory
используется прямой доступ к памяти - memcpy и т.п.
Yandex
Объявления
28.06.2015, 16:14     Запись из внедренной dll в другую dll этого процесса
Ответ Создать тему
Опции темы

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