
03.04.2024, 06:36
|
|
Познавший АНТИЧАТ
Регистрация: 29.09.2018
Сообщений: 1,292
С нами:
4012500
Репутация:
138
|
|
Сообщение от skrrt
как можно реализовать привязку сервера, например если подключаешься на IP 127.0.0.1:7777, то будет выводиться определенная функция, а если на другой IP то ничего не будет
gethostbyname проще всего хукнуть
|
|
|

23.04.2024, 12:09
|
|
Новичок
Регистрация: 16.01.2022
Сообщений: 28
С нами:
2276608
Репутация:
8
|
|
Сообщение от skrrt
как можно реализовать привязку сервера, например если подключаешься на IP 127.0.0.1:7777, то будет выводиться определенная функция, а если на другой IP то ничего не будет
При загрузке плагина добавь проверку наличия "ключа" в строке запуска сампа, при наличии твоего IP будет выполнятся функция, если же его не будет то самп запустится как обычно.
с++:
Код:
BOOL APIENTRY
DllEntryPoint
(
HMODULE hModule
,
DWORD dwReasonForCall
,
LPVOID lpReserved
)
{
if
(
dwReasonForCall
==
DLL_PROCESS_ATTACH
)
{
DisableThreadLibraryCalls
(
hModule
)
;
TCHAR
*
cmdline
=
GetCommandLine
(
)
;
if
(
StrStr
(
cmdline
,
"127.0.0.1:7777"
)
)
{
// ТУТ ТВОЙ КОД
}
}
return
TRUE
;
LoadLibrary
(
"samp.dll"
)
;
}
|
|
|

23.04.2024, 17:14
|
|
Флудер
Регистрация: 19.06.2022
Сообщений: 2,997
С нами:
2055431
Репутация:
3
|
|
Сообщение от skrrt
как можно реализовать привязку сервера, например если подключаешься на IP 127.0.0.1:7777, то будет выводиться определенная функция, а если на другой IP то ничего не будет
Сообщение от writeline
При загрузке плагина добавь проверку наличия "ключа" в строке запуска сампа, при наличии твоего IP будет выполнятся функция, если же его не будет то самп запустится как обычно.
с++:
Код:
BOOL APIENTRY
DllEntryPoint
(
HMODULE hModule
,
DWORD dwReasonForCall
,
LPVOID lpReserved
)
{
if
(
dwReasonForCall
==
DLL_PROCESS_ATTACH
)
{
DisableThreadLibraryCalls
(
hModule
)
;
TCHAR
*
cmdline
=
GetCommandLine
(
)
;
if
(
StrStr
(
cmdline
,
"127.0.0.1:7777"
)
)
{
// ТУТ ТВОЙ КОД
}
}
return
TRUE
;
LoadLibrary
(
"samp.dll"
)
;
}
Можно хукнуть метод RakClient, отвечающий за подключение к серверу
C++:
Код:
#include "kthook/kthook.hpp"
using
RakClientConnect_t
=
bool
(
__thiscall
*
)
(
void
*
pRakClient
,
const
char
*
host
,
unsigned
short
serverPort
,
unsigned
short
clientPort
,
unsigned
int
depreciated
,
int
threadSleepTimer
)
;
kthook
::
kthook_simple
(
RakClientConnectHook
)
;
bool
RakClientConnectHooked
(
const
decltype
(
RakClientConnectHook
)
&
hook
,
void
*
pRakClient
,
const
char
*
host
,
unsigned
short
serverPort
,
unsigned
short
clientPort
,
unsigned
int
depreciated
,
int
threadSleepTimer
)
{
if
(
strcmp
(
host
,
"127.0.0.1"
)
==
0
)
)
std
::
cout
(
GetModuleHandle
(
"samp.dll"
)
)
;
RakClientConnectHook
.
set_cb
(
&
RakClientHooked
)
;
RakClientConnectHook
.
set_dest
(
SAMPHandle
+
0x339F0
)
;
// R3
RakClientConnectHook
.
install
(
)
;
Еще к примеру можно хукать какую-нибудь функцию из winsock (получать адрес экпортируемой функции из Ws2_32.dll), но тогда есть вероятность. то функция вызвана не из samp.dll, а например из какого-то плагина
|
|
|

25.04.2024, 18:47
|
|
Постоянный
Регистрация: 15.09.2021
Сообщений: 396
С нами:
2453766
Репутация:
68
|
|
Сообщение от why ega
Можно хукнуть метод RakClient, отвечающий за подключение к серверу
C++:
Код:
#include "kthook/kthook.hpp"
using
RakClientConnect_t
=
bool
(
__thiscall
*
)
(
void
*
pRakClient
,
const
char
*
host
,
unsigned
short
serverPort
,
unsigned
short
clientPort
,
unsigned
int
depreciated
,
int
threadSleepTimer
)
;
kthook
::
kthook_simple
(
RakClientConnectHook
)
;
bool
RakClientConnectHooked
(
const
decltype
(
RakClientConnectHook
)
&
hook
,
void
*
pRakClient
,
const
char
*
host
,
unsigned
short
serverPort
,
unsigned
short
clientPort
,
unsigned
int
depreciated
,
int
threadSleepTimer
)
{
if
(
strcmp
(
host
,
"127.0.0.1"
)
==
0
)
)
std
::
cout
(
GetModuleHandle
(
"samp.dll"
)
)
;
RakClientConnectHook
.
set_cb
(
&
RakClientHooked
)
;
RakClientConnectHook
.
set_dest
(
SAMPHandle
+
0x339F0
)
;
// R3
RakClientConnectHook
.
install
(
)
;
Еще к примеру можно хукать какую-нибудь функцию из winsock (получать адрес экпортируемой функции из Ws2_32.dll), но тогда есть вероятность. то функция вызвана не из samp.dll, а например из какого-то плагина
а через rakclient можно создать коннект на другой айпи ?
|
|
|

25.04.2024, 18:54
|
|
Новичок
Регистрация: 21.03.2006
Сообщений: 17
С нами:
10600540
Репутация:
7
|
|
Сообщение от skrrt
а через rakclient можно создать коннект на другой айпи ?
на любой можно
|
|
|

25.04.2024, 18:59
|
|
Постоянный
Регистрация: 15.09.2021
Сообщений: 396
С нами:
2453766
Репутация:
68
|
|
Сообщение от 0xFF
на любой можно
а можно пример?
|
|
|

28.04.2024, 11:03
|
|
Флудер
Регистрация: 19.06.2022
Сообщений: 2,997
С нами:
2055431
Репутация:
3
|
|
Сообщение от skrrt
а через rakclient можно создать коннект на другой айпи ?
Если я правильно понимаю, ты хочешь изменить айпи при подключении в сампе?
Тогда ты можешь делать что-то типа такого
C++:
Код:
using
NetGameConnect_t
=
int
(
__thiscall
*
)
(
std
::
uintptr_t
*
netgame
)
;
kthook
::
kthook_simple
NetGameConnectHook
;
// r3
NetGameConnectHook
.
set_dest
(
reinterpret_cast
(
GetModuleHandleA
(
"samp.dll"
)
)
+
0x85D0
)
;
NetGameConnectHook
.
set_cb
(
[
]
(
const
decltype
(
NetGameConnectHook
)
&
hook
,
std
::
uintptr_t
*
netgame
)
{
char
*
host
=
reinterpret_cast
(
*
netgame
+
0x30
)
;
strcpy
(
host
,
"127.0.0.1"
)
;
*
reinterpret_cast
(
*
netgame
+
0x235
)
=
7777
;
return
hook
.
get_trampoline
(
)
(
netgame
)
;
}
)
;
NetGameConnectHook
.
install
(
)
;
|
|
|

28.04.2024, 12:07
|
|
Постоянный
Регистрация: 15.09.2021
Сообщений: 396
С нами:
2453766
Репутация:
68
|
|
Сообщение от why ega
Если я правильно понимаю, ты хочешь изменить айпи при подключении в сампе?
Тогда ты можешь делать что-то типа такого
C++:
Код:
using
NetGameConnect_t
=
int
(
__thiscall
*
)
(
std
::
uintptr_t
*
netgame
)
;
kthook
::
kthook_simple
NetGameConnectHook
;
// r3
NetGameConnectHook
.
set_dest
(
reinterpret_cast
(
GetModuleHandleA
(
"samp.dll"
)
)
+
0x85D0
)
;
NetGameConnectHook
.
set_cb
(
[
]
(
const
decltype
(
NetGameConnectHook
)
&
hook
,
std
::
uintptr_t
*
netgame
)
{
char
*
host
=
reinterpret_cast
(
*
netgame
+
0x30
)
;
strcpy
(
host
,
"127.0.0.1"
)
;
*
reinterpret_cast
(
*
netgame
+
0x235
)
=
7777
;
return
hook
.
get_trampoline
(
)
(
netgame
)
;
}
)
;
NetGameConnectHook
.
install
(
)
;
крашит, при попытке подключения
|
|
|

03.04.2024, 14:24
|
|
Постоянный
Регистрация: 15.09.2021
Сообщений: 396
С нами:
2453766
Репутация:
68
|
|
каким образом можно сделать наложение обводки на радар?
|
|
|

14.04.2024, 20:07
|
|
Новичок
Регистрация: 14.04.2024
Сообщений: 1
С нами:
1097180
Репутация:
1
|
|
Как можно отрисовать imgui меню на android без хука egl swap buffer?
|
|
|
|
 |
|
|
Здесь присутствуют: 1 (пользователей: 0 , гостей: 1)
|
|
|
|