开启辅助访问 切换到宽版

精易论坛

 找回密码
 注册

QQ登录

只需一步,快速开始

用微信号发送消息登录论坛

新人指南 邀请好友注册 - 我关注人的新帖 教你赚取精币 - 每日签到


求职/招聘- 论坛接单- 开发者大厅

论坛版规 总版规 - 建议/投诉 - 应聘版主 - 精华帖总集 积分说明 - 禁言标准 - 有奖举报

12
返回列表 发新帖
楼主: wanglong1
收起左侧

[闲聊] 进程注入DLL的问题,求大佬解惑

[复制链接]

结帖率:100% (11/11)
发表于 昨天 16:25 | 显示全部楼层   浙江省嘉兴市
lzw991104 发表于 2025-6-12 15:20
老哥 看下私信 加不上你 有偿求助

加你也没动静啊
回复 支持 反对

使用道具 举报

结帖率:63% (22/35)

签到天数: 12 天

发表于 昨天 15:34 | 显示全部楼层   广东省汕尾市
qq793359277 发表于 2025-6-12 13:00
散了吧 楼主连发3帖 从不理人

确实,每天得到答案,每天问新的,从不回复也不采纳
回复 支持 反对

使用道具 举报

结帖率:94% (29/31)

签到天数: 6 天

发表于 昨天 15:20 | 显示全部楼层   河南省周口市
qq793359277 发表于 2025-6-12 13:00
散了吧 楼主连发3帖 从不理人

老哥 看下私信 加不上你 有偿求助
回复 支持 反对

使用道具 举报

签到天数: 10 天

发表于 昨天 14:09 | 显示全部楼层   北京市北京市

[c]
#include <windows.h>
#include <tlhelp32.h>
#include <iostream>
#include <vector>

// 线程信息结构体
struct ThreadInfo {
    DWORD threadId;
    HANDLE hThread;
    DWORD startTime;
};

// 获取进程的主线程ID
DWORD GetMainThreadId(DWORD processId) {
    HANDLE hSnapshot = CreateToolhelp32Snapshot(TH32CS_SNAPTHREAD, 0);
    if (hSnapshot == INVALID_HANDLE_VALUE) {
        std::cerr << "CreateToolhelp32Snapshot failed: " << GetLastError() << std::endl;
        return 0;
    }

    THREADENTRY32 te32;
    te32.dwSize = sizeof(THREADENTRY32);

    if (!Thread32First(hSnapshot, &te32)) {
        std::cerr << "Thread32First failed: " << GetLastError() << std::endl;
        CloseHandle(hSnapshot);
        return 0;
    }

    std::vector<ThreadInfo> threads;
    do {
        if (te32.th32OwnerProcessID == processId) {
            HANDLE hThread = OpenThread(THREAD_QUERY_INFORMATION, FALSE, te32.th32ThreadID);
            if (hThread) {
                FILETIME createTime, exitTime, kernelTime, userTime;
                if (GetThreadTimes(hThread, &createTime, &exitTime, &kernelTime, &userTime)) {
                    ULARGE_INTEGER uli;
                    uli.LowPart = createTime.dwLowDateTime;
                    uli.HighPart = createTime.dwHighDateTime;
                    
                    ThreadInfo info;
                    info.threadId = te32.th32ThreadID;
                    info.hThread = hThread;
                    info.startTime = uli.QuadPart;
                    
                    threads.push_back(info);
                }
                else {
                    CloseHandle(hThread);
                }
            }
        }
    } while (Thread32Next(hSnapshot, &te32));

    CloseHandle(hSnapshot);

    // 找到最早创建的线程(主线程)
    DWORD mainThreadId = 0;
    ULARGE_INTEGER earliestTime = {0xFFFFFFFF, 0xFFFFFFFF};
   
    for (const auto& thread : threads) {
        ULARGE_INTEGER threadTime = {thread.startTime, 0};
        if (threadTime.QuadPart < earliestTime.QuadPart) {
            earliestTime = threadTime;
            mainThreadId = thread.threadId;
        }
        CloseHandle(thread.hThread);
    }

    return mainThreadId;
}

// 在目标进程的主线程上下文中执行代码
bool ExecuteOnMainThread(DWORD processId, LPVOID remoteFunction, LPVOID param = NULL) {
    // 获取目标进程句柄
    HANDLE hProcess = OpenProcess(PROCESS_ALL_ACCESS, FALSE, processId);
    if (!hProcess) {
        std::cerr << "OpenProcess failed: " << GetLastError() << std::endl;
        return false;
    }

    // 获取主线程ID
    DWORD mainThreadId = GetMainThreadId(processId);
    if (mainThreadId == 0) {
        std::cerr << "Failed to get main thread ID" << std::endl;
        CloseHandle(hProcess);
        return false;
    }

    // 获取主线程句柄
    HANDLE hThread = OpenThread(THREAD_ALL_ACCESS, FALSE, mainThreadId);
    if (!hThread) {
        std::cerr << "OpenThread failed: " << GetLastError() << std::endl;
        CloseHandle(hProcess);
        return false;
    }

    // 分配远程内存用于存储参数
    LPVOID remoteParam = NULL;
    if (param) {
        remoteParam = VirtualAllocEx(hProcess, NULL, 4096, MEM_COMMIT | MEM_RESERVE, PAGE_READWRITE);
        if (!remoteParam) {
            std::cerr << "VirtualAllocEx failed: " << GetLastError() << std::endl;
            CloseHandle(hThread);
            CloseHandle(hProcess);
            return false;
        }

        if (!WriteProcessMemory(hProcess, remoteParam, param, 4096, NULL)) {
            std::cerr << "WriteProcessMemory failed: " << GetLastError() << std::endl;
            VirtualFreeEx(hProcess, remoteParam, 0, MEM_RELEASE);
            CloseHandle(hThread);
            CloseHandle(hProcess);
            return false;
        }
    }

    // 暂停主线程
    SuspendThread(hThread);

    // 创建远程线程在主线程上下文中执行
    HANDLE hRemoteThread = CreateRemoteThread(
        hProcess,
        NULL,
        0,
        (LPTHREAD_START_ROUTINE)remoteFunction,
        remoteParam,
        0,
        NULL
    );

    if (!hRemoteThread) {
        std::cerr << "CreateRemoteThread failed: " << GetLastError() << std::endl;
        ResumeThread(hThread);
        if (remoteParam) VirtualFreeEx(hProcess, remoteParam, 0, MEM_RELEASE);
        CloseHandle(hThread);
        CloseHandle(hProcess);
        return false;
    }

    // 等待远程线程执行完成
    WaitForSingleObject(hRemoteThread, INFINITE);

    // 清理资源
    CloseHandle(hRemoteThread);
    ResumeThread(hThread);
    if (remoteParam) VirtualFreeEx(hProcess, remoteParam, 0, MEM_RELEASE);
    CloseHandle(hThread);
    CloseHandle(hProcess);

    return true;
}

// 示例使用方法
int main() {
    // 目标游戏进程ID
    DWORD targetProcessId = 1234; // 替换为实际游戏进程ID
   
    // 目标游戏中的函数地址(需要通过分析获取)
    LPVOID targetFunctionAddress = (LPVOID)0x12345678; // 替换为实际函数地址
   
    // 函数参数(如果有)
    struct FunctionParams {
        int param1;
        float param2;
        // 其他参数...
    } params = {123, 4.56f};
   
    // 在主线程上下文中执行目标函数
    if (ExecuteOnMainThread(targetProcessId, targetFunctionAddress, &params)) {
        std::cout << "Function executed successfully on main thread" << std::endl;
    } else {
        std::cerr << "Failed to execute function on main thread" << std::endl;
    }
   
    return 0;
}
[/c]
回复 支持 反对

使用道具 举报

签到天数: 10 天

发表于 昨天 14:07 | 显示全部楼层   北京市北京市
获取主线程 ID:通过创建线程快照并遍历所有线程,找出目标进程中最早创建的线程(通常是主线程)。
内存操作:在目标进程中分配内存并写入参数,以便远程调用时使用。
远程线程执行:暂停目标主线程,然后创建远程线程在其上下文中执行目标函数,完成后恢复主线程。
回复 支持 反对

使用道具 举报

结帖率:95% (37/39)

签到天数: 10 天

发表于 昨天 13:42 | 显示全部楼层   河北省邯郸市
远程绑定主线程调用call调试工具
https://bbs.125.la/forum.php?mod=viewthread&tid=14797171
(出处: 精易论坛)
回复 支持 反对

使用道具 举报

结帖率:100% (11/11)

签到天数: 13 天

发表于 昨天 13:00 | 显示全部楼层   浙江省嘉兴市
散了吧 楼主连发3帖 从不理人
回复 支持 反对

使用道具 举报

结帖率:83% (10/12)

签到天数: 12 天

发表于 昨天 12:46 | 显示全部楼层   重庆市重庆市
注入就直接HOOK,远程就设置主线程上下文修改RIP
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 注册

本版积分规则 致发广告者

发布主题 收藏帖子 返回列表

sitemap| 易语言源码| 易语言教程| 易语言论坛| 易语言模块| 手机版| 广告投放| 精易论坛
拒绝任何人以任何形式在本论坛发表与中华人民共和国法律相抵触的言论,本站内容均为会员发表,并不代表精易立场!
论坛帖子内容仅用于技术交流学习和研究的目的,严禁用于非法目的,否则造成一切后果自负!如帖子内容侵害到你的权益,请联系我们!
防范网络诈骗,远离网络犯罪 违法和不良信息举报电话0663-3422125,QQ: 793400750,邮箱:wp@125.la
网站简介:精易论坛成立于2009年,是一个程序设计学习交流技术论坛,隶属于揭阳市揭东区精易科技有限公司所有。
Powered by Discuz! X3.4 揭阳市揭东区精易科技有限公司 ( 粤ICP备12094385号-1) 粤公网安备 44522102000125 增值电信业务经营许可证 粤B2-20192173

快速回复 返回顶部 返回列表