好友
阅读权限 10
听众
最后登录 1970-1-1
小青花
发表于 2020-3-12 14:16
#include<string>
#include<vector>
#include<Windows.h>
#include"BaseAddr.h"
using namespace std;
#define Base_NoticeCallAddr 0x002E1F260 //喇叭公告
#define Base_NoticeCallECXAddr 0x0062E04CC // 商店基质
CONST INT 技能CALL = 0x28D9EF0;
void Bulletin(wstring text);
BOOL Writebyte(int Addr, vector<byte> by)
{
int len = by.size();
byte *address = new byte[len];
for (int i = 0; i < len; i++)
{
address[i] = by[i];
}
if (!WriteProcessMemory(GetCurrentProcess(), (LPVOID)Addr, address, len, 0))
{
return FALSE;
}
else
{
return TRUE;
}
}
void 技能Call(int 触发指针, int 代码, int 伤害, int X, int Y, int Z)
{
int 空白地址, 技能结构[25] = { 0 };
技能结构[0] = 触发指针;
技能结构[2] = 代码;
技能结构[3] = 伤害;
技能结构[6] = X;
技能结构[7] = Y;
技能结构[8] = Z;
技能结构[15] = 0;
空白地址 = (int)&技能结构;
__asm
{
mov ecx,空白地址
mov eax,技能CALL
call eax
}
}
INT ReadIit(INT ADDR)
{
INT 结果;
if (!ReadProcessMemory(GetCurrentProcess(), (LPVOID)ADDR, &结果, 4, 0))
return 0;
else
return 结果;
}
void 缓冲Call(int cpy)
{
_asm
{
push cpy
mov ecx, 发包基址
mov ecx, [ecx]
mov eax, 缓冲CALL
call eax
}
}
void 发包Call()
{
__asm
{
mov eax, 发包CALL
call eax
}
}
void 加密Call(int py, int size)
{
int Com;
if (size == 1)
{
Com = 加密包CALL;
}
else if (size == 2)
{
Com = 加密包CALL + 0x30;
}
else if (size == 4)
{
Com = 加密包CALL + 0x60;
}
else if (size == 8)
{
Com = 加密包CALL + 0x90;
}
__asm
{
push py
mov ecx, 发包基址
mov ecx, [ecx]
call Com
}
}
void 剑歌组包拾取(int 物品地址)
{
缓冲Call(43);
加密Call(物品地址, 4);
加密Call(0, 1);
加密Call(0, 1); //(2,1)
加密Call(0, 2);
加密Call(0, 2);
加密Call(0, 2);
加密Call(0, 2);
加密Call(0, 2);
加密Call(0, 2);
加密Call(0, 2);
发包Call();
}
int 剑歌解密(int addr)
{
int eax, esi, edx;
eax = *(int*)addr;
esi = *(int*)解密基址;
edx = eax;
edx >>= 16;
edx = *(int*)(esi + edx * 4 + 36);
eax = eax & 0xffff;
eax = *(int*)(edx + eax * 4 + 8468);
edx = WORD(eax);
esi = edx;
esi <<= 16;
esi = esi ^ edx;
edx = *(int*)(addr + 4);
eax = esi ^ edx;
return eax;
}
int 剑歌汇编加法(int t1, int t2)
{
int sum;
_asm
{
mov eax, t1
mov ebx, t2
add eax, ebx
mov sum, eax
}
return sum;
}
BOOL 是否开门()
{
int 人物指针, sum;
人物指针 = *(int*)人物基址;
sum = *(int*)剑歌汇编加法(人物指针, 地图偏移);
if (剑歌解密(剑歌汇编加法(sum, 280)) == 0)
{
return true;
}
else
{
return false;
}
}
BOOL 是否在城镇()
{
int 人物指针, sum;
人物指针 = *(int*)人物基址;
sum = *(int*)剑歌汇编加法(人物指针, 地图偏移);
if (sum == 0)
{
return true;
}
else
{
return false;
}
}
void 剑歌拾取遍历()
{
int 人物指针, 地图, 首地址1, 尾地址1, 物品数量, 物品计次 = 1, 临时地址, 物品类型, 阵营, 物品ID;
if (是否在城镇() == TRUE)
{
return;
}
人物指针 = *(int*)人物基址;
地图 = *(int*)剑歌汇编加法(人物指针, 地图偏移);
首地址1 = *(int*)剑歌汇编加法(地图, 首地址);
尾地址1 = *(int*)剑歌汇编加法(地图, 尾地址);
物品数量 = (尾地址1 - 首地址1) / 4;
while (物品计次 <= 物品数量)
{
临时地址 = *(int*)剑歌汇编加法(首地址1, 4 * 物品计次);
物品类型 = *(int*)剑歌汇编加法(临时地址, 类型偏移);
阵营 = *(int*)剑歌汇编加法(临时地址, 阵营偏移);
if (物品类型 == 289 && 阵营 == 200)
{
if (人物指针 != 临时地址)
{
物品ID = 剑歌解密(临时地址 + 188);
剑歌组包拾取(物品ID);
}
}
物品计次++;
}
}
void 撿垃圾()
{
if(是否开门()==TRUE)
{
剑歌拾取遍历();
}
}
void Send_发包()
{
_asm
{
mov eax, 发包CALL
call eax
}
}
void Send_加密Call(int 参数, int 长度)
{
int 加密包Call;
if (长度 == 1)
加密包Call = 加密包CALL;
if (长度 == 2)
加密包Call = 加密包CALL + 48;
if (长度 == 3)
加密包Call = 加密包CALL + 96;
if (长度 == 4)
加密包Call = 加密包CALL + 144;
_asm
{
push 参数
mov ecx, 发包基址
mov ecx, [ecx]
mov eax, 加密包Call
call eax
}
}
void Send_缓冲CALL(int 包头)
{
_asm
{ push 0x00000000
push 包头
mov ecx, 发包地址
mov ecx, [ecx]
mov eax, 缓冲CALL
call eax
}
}
void 组包拾取(int 物品地址, int x, int y)
{
int 物品X = x + 7;
int 物品Y = y + 5;
Send_缓冲CALL(43);
Send_加密Call(物品地址, 4);
Send_加密Call(0, 1);
Send_加密Call(2, 1);
Send_加密Call(x, 2);
Send_加密Call(y, 2);
Send_加密Call(0, 2);
Send_加密Call(物品X, 2);
Send_加密Call(物品Y, 2);
Send_加密Call(0, 2);
Send_加密Call(0, 2);
Send_发包();
}
DWORD WINAPI 按键线程(LPVOID Param)
{
int hmodule, Tenrpcs;
INT P;//人物指针
MSG msg = { 0 };
RegisterHotKey(NULL, 0x24, 0, VK_HOME);
RegisterHotKey(NULL, 0x70, 0, VK_F1);
RegisterHotKey(NULL, 0x71, 0, VK_F2);
RegisterHotKey(NULL, 0x72, 0, VK_F3);
RegisterHotKey(NULL, 0x73, 0, VK_F4);
RegisterHotKey(NULL, 0x74, 0, VK_END);
RegisterHotKey(NULL, 0x80, 0, VK_F7);
while (GetMessage(&msg, 0, 0, 0))
{
if (WM_HOTKEY == msg.message)
{
if (VK_HOME == HIWORD(msg.lParam))
{
RegisterHotKey(NULL, 0x74, 0, VK_F5);
RegisterHotKey(NULL, 0x75, 0, VK_F6);
RegisterHotKey(NULL, 0x81, 0, 'V');
Bulletin(L"内心毫无波澜甚至笑出了声");
Bulletin(L"F1 全屏钩子");
Bulletin(L"F2 独家倍功");
Bulletin(L"F3 技能无CD");
Bulletin(L"F4 Hook技能");
Bulletin(L"F6 人物无敌");
Bulletin(L"F7 释放秒杀");
Bulletin(L"End 自動入包");
Bulletin(L"V 直接入包");
Bulletin(L"Hello My Loneliness");
//初始化TenRPCS.dll+1A6E90 - C3 - ret
//TenRPCS.dll+1A6ECB - E9 8D000000 - jmp TenRPCS.dll+1A6F5D
hmodule = (int)GetModuleHandle(L"dnf.exe");
Tenrpcs = (int)GetModuleHandle(L"TenRpcs.dll");
Writebyte(Tenrpcs + 0x1A6E90, { 0xC3 });
Writebyte(Tenrpcs + 0x1A6ECB, { 0xE9,0x8D,0x00,0x00,0x00 });
//Writebyte(hmodule + 0x44B9BD2, {0x90 });//注释一条检测试试。
WritePrivateProfileString(L"剑歌", L"技能代码", L"39002", L"C:\\Users\\Administrator\\Desktop\\剑歌.ini");
}
}
if (VK_END == HIWORD(msg.lParam))
{
SetTimer(NULL, 3, 1000, (TIMERPROC)撿垃圾);
}
if (VK_F1 == HIWORD(msg.lParam))
{
Writebyte(hmodule + 0x4C680, { 0xC3 });
Bulletin(L"全屏攻击 - Open");
}
if (VK_F2 == HIWORD(msg.lParam))
{
Writebyte(hmodule + 0x28286F9, { 0xB8,0x99,0x99,0x99 });//独家伤害基质
Bulletin(L"独家倍功 - Open");
}
if (VK_F3 == HIWORD(msg.lParam))
{
Writebyte(hmodule + 0x27E6F52, { 0xEB,0x33 });
Bulletin(L"技能无CD - Open");
}
if (VK_F4 == HIWORD(msg.lParam))
{
Writebyte(hmodule + 0x32AFC49, { 0xE9,0xB2,0x0B,0xD5,0xFC });
Writebyte(hmodule + 0x32AFC4E, { 0x90 });
Writebyte(hmodule + 0x800, { 0xBA,0xD9,0x11,0x01,0x00 });
Writebyte(hmodule + 0x805, { 0xE9,0x45,0xF4,0x2A,0x03 });
Bulletin(L"HOOK技能 - Open");
}
if (VK_F5 == HIWORD(msg.lParam))
{
}
if (VK_F6 == HIWORD(msg.lParam))
{
P = ReadIit(0x642B240); //人物基质
P += 0xAA4; //无敌偏移
Writebyte(P, { 100 });
Bulletin(L"无敌 - Open");
}
if (VK_F7 == HIWORD(msg.lParam))
{
技能Call(P, GetPrivateProfileInt(L"剑歌", L"技能代码", NULL, L"C:\\Users\\Administrator\\Desktop\\剑歌.ini"), 999999, 200, 500, 0);
Bulletin(L"释放Call - Open");
}
if ('V' == HIWORD(msg.lParam))
{
剑歌拾取遍历();
}
}
return 0;
}
void Bulletin(wstring text)
{
if (text.empty()) {
return;
}
wstring value = L"剑歌:2030757644 ";
value += text;
const TCHAR* txtAdr = value.c_str();
__asm
{
PUSH 0
PUSH 0
PUSH 0
PUSH 0
PUSH 0
PUSH 0x24//喇叭显示的位置
PUSH 0xFFFF00FF;//喇叭颜色
PUSH txtAdr;
MOV ECX, Base_NoticeCallECXAddr//商店基址
MOV ECX, [ECX]
MOV ECX, [ECX + 0x50]
MOV EAX, Base_NoticeCallAddr//喇叭公告
CALL EAX
}
}
HANDLE hThreadapp;
BOOL WINAPI DllMain(HMODULE hModule, DWORD ul_reason_for_call, LPVOID lpReserved)
{
switch (ul_reason_for_call)
{
case DLL_PROCESS_ATTACH:
{
hThreadapp = CreateThread(NULL, NULL, (LPTHREAD_START_ROUTINE)按键线程, 0, 0, 0);
}
//break;
case DLL_THREAD_ATTACH:
//break;
case DLL_THREAD_DETACH:
//break;
case DLL_PROCESS_DETACH:
break;
}
return TRUE;
}