标题:c++写挂新人求助
只看楼主
qq1990086708
Rank: 1
等 级:新手上路
帖 子:11
专家分:0
注 册:2016-4-4
结帖率:100%
已结贴  问题点数:20 回复次数:7 
c++写挂新人求助
我这里面的内存地址不是基址,游戏一关内存地址就发生改变然而就失效了!我找到基址了,有偏移不知道怎么加入到这里面求大神啊!!这个问题困扰我好几天了本人qq1990086708;谢谢!!

代码如下:
#include<iostream>
#include<windows.h>
using namespace std;//命名空间
int main()
{
    HWND hwnd = FindWindow(L"MainWindow", L"植物大战僵尸中文版");//取句柄
    if (hwnd != 0)//判断
    {
        std::cout << "句柄已经得到!"<<endl;//输出提示
        DWORD pid;
        GetWindowThreadProcessId(hwnd, &pid);//取进程id,取到之后放入pid
        if (pid != 0)
        {
            std::cout << "游戏进程ID已经获得!" << endl;//输出提示
            HANDLE hp=OpenProcess(PROCESS_ALL_ACCESS, FALSE, pid);//打使用之前取到的pid打开进程.
            if (hp != 0)
            {
                std::cout << "打开游戏进程成功!" << endl;
                DWORD dz = 0x11FE4CF8;//游戏内存地址
                DWORD yg;
                while (1)
                {

                    std::cout << "输入你想修改的数值:";//输出提示
                    std::cin >> yg;//输入要修改的数值
                    DWORD d = WriteProcessMemory(hp, (LPVOID)dz, &yg, 4, 0);//写入内存数据
                    if (d != 0)
                    {
                        std::cout << "修改成功!" << endl;//输出提示
                    }
                    else std::cout << "修改失败!" << endl;//输出提示

                }
               

            }
            else std::cout << "打开游戏进程失败!" << endl;//输出提示





        }
        else std::cout << "ID未得到" << endl;//输出提示
    }
    else std::cout << "请打开游戏!";//输出提示
   
   
   
    return 0;//返回0
}
搜索更多相关主题的帖子: 植物大战 include 中文版 僵尸 空间 
2016-04-04 22:22
qq1990086708
Rank: 1
等 级:新手上路
帖 子:11
专家分:0
注 册:2016-4-4
得分:0 
别沉
2016-04-04 22:22
rjsp
Rank: 20Rank: 20Rank: 20Rank: 20Rank: 20
等 级:版主
威 望:507
帖 子:8890
专家分:53117
注 册:2011-1-18
得分:10 
有用的就“我找到基址了,有偏移不知道怎么”这一句,但说得含糊,不知道是啥个基址和偏移?
2016-04-05 08:28
qq1990086708
Rank: 1
等 级:新手上路
帖 子:11
专家分:0
注 册:2016-4-4
得分:0 
回复 3楼 rjsp
噢,= =我的意思是,基址和偏移怎么写入这个程序内,要不然每次关闭游戏内存地址都会变.
2016-04-05 14:58
qq1990086708
Rank: 1
等 级:新手上路
帖 子:11
专家分:0
注 册:2016-4-4
得分:0 
回复 3楼 rjsp
就是这里,那个是个内存地址而不是基址,可是基址又带偏移,要怎么写啊.
2016-04-05 15:03
qq1990086708
Rank: 1
等 级:新手上路
帖 子:11
专家分:0
注 册:2016-4-4
得分:0 
通过别人的列子自己理解了下,成功了= =不过也要谢谢版主!!
代码如下:
#include<iostream>
#include<windows.h>
using namespace std;//命名空间
int main()
{
    HWND hwnd = FindWindow(L"MainWindow", L"植物大战僵尸中文版");//取句柄
    if (hwnd != 0)//判断
    {
        std::cout << "句柄已经得到!" << endl;//输出提示
        DWORD pid;
        GetWindowThreadProcessId(hwnd, &pid);//取进程id,取到之后放入pid
        if (pid != 0)
        {
            std::cout << "游戏进程ID已经获得!" << endl;//输出提示
            HANDLE hp = OpenProcess(PROCESS_ALL_ACCESS, FALSE, pid);//打使用之前取到的pid打开进程.
            if (hp != 0)
            {
                DWORD l1, l2;
                DWORD M = 0x006A9EC0;
                ReadProcessMemory(hp,(LPCVOID) M, (LPVOID)&l1, 4, 0);
                ReadProcessMemory(hp,(LPCVOID)(l1+0x768),(LPVOID)&l2, 4, 0);
                std::cout << "打开游戏进程成功!" << endl;
                DWORD yg;
                std::cout << "输入你想修改的数值:";//输出提示
                std::cin >> yg;//输入要修改的数值
                DWORD d = WriteProcessMemory(hp, (LPVOID)(l2+0x5560), &yg, 4, 0);//写入内存数据
                if (d != 0)
                {
                    std::cout << "修改成功!" << endl;//输出提示
                }
                else std::cout << "修改失败!" << endl;//输出提示



            }
            else std::cout << "打开游戏进程失败!" << endl;//输出提示





        }
        else std::cout << "ID未得到" << endl;//输出提示
    }
    else std::cout << "请打开游戏!";//输出提示



    return 0;//返回0
}
2016-04-05 16:14
yangfrancis
Rank: 16Rank: 16Rank: 16Rank: 16
等 级:贵宾
威 望:141
帖 子:1510
专家分:7661
注 册:2014-5-19
得分:10 
有几个函数功能好厉害,学习学习。
2016-04-05 18:34
qq1990086708
Rank: 1
等 级:新手上路
帖 子:11
专家分:0
注 册:2016-4-4
得分:0 
回复 7楼 yangfrancis
你qq多少= =
2016-04-05 20:59



参与讨论请移步原网站贴子:https://bbs.bccn.net/thread-463257-1-1.html




关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.022200 second(s), 8 queries.
Copyright©2004-2024, BCCN.NET, All Rights Reserved