HOME FORUMS MEMBERS RECENT POSTS LOG IN  
× Авторизация
Имя пользователя:
Пароль:
Нет аккаунта? Регистрация
Баннер 1   Баннер 2
НОВЫЕ ТОРГОВАЯ НОВОСТИ ЧАТ
loading...
Скрыть
Вернуться   ANTICHAT > ПРОГРАММИРОВАНИЕ > С/С++, C#, Rust, Swift, Go, Java, Perl, Ruby
   
Ответ
 
Опции темы Поиск в этой теме Опции просмотра

  #1  
Старый 04.08.2020, 17:11
loganhackerdff
Постоянный
Регистрация: 24.07.2017
Сообщений: 867
С нами: 4633764

Репутация: 148


По умолчанию

а зачем
 
Ответить с цитированием

  #2  
Старый 04.08.2020, 17:12
kin4stat
Флудер
Регистрация: 06.11.2017
Сообщений: 2,759
С нами: 4483143

Репутация: 183


По умолчанию

Как сделать нормальный ноп для RPC? В плане как хранить данные о RPC? В собейте я нихера не понял . Я понимаю что нужна структурка RPC, в которой будет ее статус и прочие свойства, но как хранить эти структуры удобно и т.д.?
 
Ответить с цитированием

  #3  
Старый 04.08.2020, 17:38
loganhackerdff
Постоянный
Регистрация: 24.07.2017
Сообщений: 867
С нами: 4633764

Репутация: 148


По умолчанию

Цитата:
Сообщение от KiN4StAt  

Как сделать нормальный ноп для RPC? В плане как хранить данные о RPC? В собейте я нихера не понял . Я понимаю что нужна структурка RPC, в которой будет ее статус и прочие свойства, но как хранить эти структуры удобно и т.д.?
 
Ответить с цитированием

  #4  
Старый 04.08.2020, 17:42
kin4stat
Флудер
Регистрация: 06.11.2017
Сообщений: 2,759
С нами: 4483143

Репутация: 183


По умолчанию

Цитата:
Сообщение от loganhackerdff  
Да не, не то. Мне надо в функции приема RPC, проверять, включено ли оно. Примерно продумал такой ход: Массив, в нем индекс = ID RPC. массив типа struct RPC, в котором два поля: std::string name и bool enabled. Мне теперь надо придумать как это заполнять
 
Ответить с цитированием

  #5  
Старый 05.08.2020, 04:42
Musaigen
Познавший АНТИЧАТ
Регистрация: 01.04.2018
Сообщений: 1,710
С нами: 4272230

Репутация: 183


По умолчанию

Цитата:
Сообщение от KiN4StAt  

Да не, не то. Мне надо в функции приема RPC, проверять, включено ли оно. Примерно продумал такой ход: Массив, в нем индекс = ID RPC. массив типа struct RPC, в котором два поля: std::string name и bool enabled. Мне теперь надо придумать как это заполнять
Используй std::map.

Заполнять через for.
 
Ответить с цитированием

  #6  
Старый 05.08.2020, 13:23
Dark_Knight
Флудер
Регистрация: 18.03.2013
Сообщений: 4,080
С нами: 6921957

Репутация: 183


По умолчанию

Цитата:
Сообщение от Musaigen  

Используй std::map.
Заполнять через for.
Можно спокойной через vector сделать не напрягаясь и юзать std::find_if для поиска любых значений.

map имеет метод find, но позволит искать по первому элементу пары(sld:air)

Ideone.com

Ideone is something more than a pastebin; it's an online compiler and debugging tool which allows to compile and run code online in more than 40 programming languages.

ideone.com
 
Ответить с цитированием

  #7  
Старый 04.08.2020, 23:53
loganhackerdff
Постоянный
Регистрация: 24.07.2017
Сообщений: 867
С нами: 4633764

Репутация: 148


По умолчанию

как через WndProc получить нажатие кнопок на мышке (а именно Средней, X1 и X2)
 
Ответить с цитированием

  #8  
Старый 04.08.2020, 23:55
DarkP1xel
Флудер
Регистрация: 17.06.2013
Сообщений: 3,635
С нами: 6791977

Репутация: 183


По умолчанию

Цитата:
Сообщение от loganhackerdff  

как через WndProc получить нажатие кнопок на мышке (а именно Средней, X1 и X2)
Сведения о сообщениях и очередях сообщений - Win32 apps

В этом разделе рассматриваются сообщения Windows и очереди сообщений.

docs.microsoft.com


Mouse Input Notifications - Win32 apps

Mouse Input Notifications

docs.microsoft.com
 
Ответить с цитированием

  #9  
Старый 05.08.2020, 13:36
manukhov
Участник форума
Регистрация: 14.04.2018
Сообщений: 122
С нами: 4254200

Репутация: 98
По умолчанию

Здравствуйте, опять я со своими цыганскими фокусами по трансформации internal->external, на сей раз Nametag. Подскажите, что неправильно, я так и не нашёл проблему, а работать оно не хочет.

P.S.

1. Интернал точно правильный.

2. Получение адреса samp.dll точно работает

3. Виртал протект делал, не помогает.

Internal:





Код:
Idefine SAMP_INFO  0x21A0F8
#define SAMP_SETTINGS  0x3D5
DWORD* pInfo;
BYTE* ThroughWalls;
BYTE* ShowNameTags;
float* fDistance;
    
    
    DWORD SampDLL = (DWORD)GetModuleHandleA("samp.dll");
    if (SampDLL) {
        pInfo = (DWORD*)(SampDLL + SAMP_INFO);
        while (*pInfo == 0) Sleep(1000);
        while (*(DWORD*)(*pInfo + SAMP_SETTINGS) == 0) Sleep(1000);
        ShowNameTags = (BYTE*)(*(DWORD*)(*pInfo + SAMP_SETTINGS) + 0x38);
        ThroughWalls = (BYTE*)(*(DWORD*)(*pInfo + SAMP_SETTINGS) + 0x2F);
        fDistance = (float*)((DWORD*)(*(DWORD*)(*pInfo + SAMP_SETTINGS) + 0x27));
        for (;;)
        {
            do {
                Sleep(100);
            } while (!KeyPressed(VK_MENU) || !KeyPressed(0x32));
            do {
                Sleep(50);
            } while (KeyPressed(0x32));
            gta_showText("okoboga v2 ~g~Activated", 1000, NULL, NULL);
            *ShowNameTags = 1;
            *ThroughWalls = 0;
            *fDistance = 999.0f;
            do {
                Sleep(100);
            } while (!KeyPressed(VK_MENU) || !KeyPressed(0x32));
            do {
                Sleep(50);
            } while (KeyPressed(0x32));
            gta_showText("okoboga v2 ~r~Deactivated", 1000, NULL, NULL);
            *ShowNameTags = 1;
            *ThroughWalls = 1;
            *fDistance = 0.0f;
        }
    }


External (моё):





Код:
#define SAMP_INFO  0x21A0F8
#define SAMP_SETTINGS  0x3D5

if (checkBox5->Checked)
    {
        DWORD pInfo;
        BYTE ShowNameTags = 1;
        BYTE ThroughWalls = 0;
        float fDistance = 999.0f;

        ReadProcessMemory(hProcess, (LPVOID)(moduleBase + SAMP_INFO), &pInfo, sizeof(pInfo), nullptr);
        WriteProcessMemory(hProcess, (LPVOID)(pInfo + SAMP_SETTINGS + 0x38), &ShowNameTags, sizeof(ShowNameTags), nullptr);
        WriteProcessMemory(hProcess, (LPVOID)(pInfo + SAMP_SETTINGS + 0x2F), &ThroughWalls, sizeof(ThroughWalls), nullptr);
        WriteProcessMemory(hProcess, (LPVOID)(pInfo + SAMP_SETTINGS + 0x27), &fDistance, sizeof(fDistance), nullptr);
    }
    else
    {
        DWORD pInfo;
        BYTE ShowNameTags = 1;
        BYTE ThroughWalls = 1;
        float fDistance = 0.0f;

        ReadProcessMemory(hProcess, (LPVOID)(moduleBase + SAMP_INFO), &pInfo, sizeof(pInfo), nullptr);
        WriteProcessMemory(hProcess, (LPVOID)(pInfo + SAMP_SETTINGS + 0x38), &ShowNameTags, sizeof(ShowNameTags), nullptr);
        WriteProcessMemory(hProcess, (LPVOID)(pInfo + SAMP_SETTINGS + 0x2F), &ThroughWalls, sizeof(ThroughWalls), nullptr);
        WriteProcessMemory(hProcess, (LPVOID)(pInfo + SAMP_SETTINGS + 0x27), &fDistance, sizeof(fDistance), nullptr);
 
Ответить с цитированием

  #10  
Старый 05.08.2020, 14:04
kin4stat
Флудер
Регистрация: 06.11.2017
Сообщений: 2,759
С нами: 4483143

Репутация: 183


По умолчанию

Цитата:
Сообщение от T4yz1e  

Здравствуйте, опять я со своими цыганскими фокусами по трансформации internal->external, на сей раз Nametag. Подскажите, что неправильно, я так и не нашёл проблему, а работать оно не хочет.
Если я все правильно понял, то
Код:
(DWORD*)(*pInfo + SAMP_SETTINGS)
Преобразует *pInfo+SAMP_SETTINGS в DWORD*, после идет +0x27, а из-за арифметики указателей, это получается 0x27 * 4, и потом идет разыменование.

Возможно ты еще с преобразованиями накосячил, пока с телефонам, не совсем удобно смотреть

Также возможно у тебя DWORD задейфанен в 8 байт, а не в 4. Я однажды из-за этого час искал где приколы возникли

нашел где ошибка. Вместо

C++:





Код:
ReadProcessMemory
(
hProcess
,
(
LPVOID
)
(
moduleBase
+
SAMP_INFO
)
,
&
pInfo
,
sizeof
(
pInfo
)
,
nullptr
)
;
WriteProcessMemory
(
hProcess
,
(
LPVOID
)
(
pInfo
+
SAMP_SETTINGS
+
0x38
)
,
&
ShowNameTags
,
sizeof
(
ShowNameTags
)
,
nullptr
)
;
WriteProcessMemory
(
hProcess
,
(
LPVOID
)
(
pInfo
+
SAMP_SETTINGS
+
0x2F
)
,
&
ThroughWalls
,
sizeof
(
ThroughWalls
)
,
nullptr
)
;
WriteProcessMemory
(
hProcess
,
(
LPVOID
)
(
pInfo
+
SAMP_SETTINGS
+
0x27
)
,
&
fDistance
,
sizeof
(
fDistance
)
,
nullptr
)
;


Должно быть что-то типа такого:

C++:





Код:
ReadProcessMemory
(
hProcess
,
(
LPVOID
)
(
moduleBase
+
SAMP_INFO
)
,
&
pInfo
,
sizeof
(
pInfo
)
,
nullptr
)
;
DWORD pSettings
;
ReadProcessMemory
(
hProcess
,
(
LPVOID
)
(
pInfo
+
SAMP_SETTINGS
)
,
&
pSettings
,
sizeof
(
pSettings
)
,
NULL
)
;
WriteProcessMemory
(
hProcess
,
(
LPVOID
)
(
pSettings
+
0x38
)
,
&
ShowNameTags
,
sizeof
(
ShowNameTags
)
,
nullptr
)
;
WriteProcessMemory
(
hProcess
,
(
LPVOID
)
(
pSettings
+
0x2F
)
,
&
ThroughWalls
,
sizeof
(
ThroughWalls
)
,
nullptr
)
;
WriteProcessMemory
(
hProcess
,
(
LPVOID
)
(
pSettings
+
0x27
)
,
&
fDistance
,
sizeof
(
fDistance
)
,
nullptr
)
;
 
Ответить с цитированием
Ответ





Здесь присутствуют: 1 (пользователей: 0 , гостей: 1)
 


Быстрый переход




ANTICHAT ™ © 2001- Antichat Kft.