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

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

Восстановить пароль Регистрация
 
ThePanix
0 / 0 / 0
Регистрация: 20.06.2014
Сообщений: 52
28.06.2015, 05:56     Запись из внедренной dll в другую dll этого процесса #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 из процесса. C++
C++ DLL VC++, права доступа на запись и удаление файлов. Помогите новичку!
C++ Загрузка переменной из DLL (GetProcAddress не берет значение переменной из *.dll)
Подгрузка dll через dll C++
C++ Вызов dll ресурсов в dll
C++ Вызов Dll-фий в другой Dll
Как узнать зависимость DLL-ки от других DLL-ек? C++
C++ Как подключить dll на C# к проекту (dll) на С++

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

Или воспользуйтесь поиском по форуму:
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
Убежденный
Системный программист
 Аватар для Убежденный
14188 / 6203 / 984
Регистрация: 02.05.2013
Сообщений: 10,331
Завершенные тесты: 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 этого процесса
Ответ Создать тему
Опции темы

Текущее время: 15:52. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2016, vBulletin Solutions, Inc.
Рейтинг@Mail.ru