• python修改内存,(修改植物大战僵尸)


    import win32process # 进程模块
    import win32con # 系统定义
    import win32api # 调用系统模块
    import ctypes # c语言类型
    import win32gui #界面
    import time
    
    # 系统常量,标识最高权限打开一个进程
    PROCESS_ALL_ACCESS = (0x000F0000|0x00100000|0xFFF) # |位运算, 0x 十六进制
    
    window = win32gui.FindWindow("MainWindow","植物大战僵尸中文版") # 查找窗体
    
    # 根据窗体抓取进程编号(pid 是进程编号 hid和pid一般描述一个进程信息)
    hid,pid = win32process.GetWindowThreadProcessId(window)
    
    # phand 打开一个进程(参数意思是使用最高权限非安全打这个进程)
    phand = win32api.OpenProcess(PROCESS_ALL_ACCESS,False,pid)
    print(phand)
    # c语言整数类型,读取数据
    date = ctypes.c_long()
    
    # 调用系统内核模块(Kerne123.dll windows内核)
    mydll = ctypes.windll.LoadLibrary("C:\Windows\System32\kernel32.dll")
    
    
    while True:
        # 读取内存(“4”表示占4个字节,types.byref(date)表示转递地址信息,写入的结果到date中)
        # int(phand)打开的进程编号   “244866760”需要读取的内存的地址
        mydll.ReadProcessMemory(int(phand), 0x411410192, ctypes.byref(date), 4, None)
    
        # 读内存 (可以获取内存中对应的数据)
        print(date.value)
    
        if date.value <2450:
    
    
            newdata = ctypes.c_long(2450) # 设定修改的数据
            mydll.WriteProcessMemory(int(phand), 0x411410192, ctypes.byref(newdata), 4, None)
        time.sleep(1)

    utf-8

    import win32process
    import win32con
    import win32api 
    import ctypes 
    import win32gui
    import time
    
    PROCESS_ALL_ACCESS = (0x000F0000|0x00100000|0xFFF)
    
    window = win32gui.FindWindow("MainWindow","植物大战僵尸中文版")
    
    
    hid,pid = win32process.GetWindowThreadProcessId(window)
    print(pid)
    
    phand = win32api.OpenProcess(PROCESS_ALL_ACCESS,False,pid)
    print(phand)
    
    date = ctypes.c_long()
    
    mydll = ctypes.windll.LoadLibrary("C:\Windows\System32\kernel32.dll")
    
    while True:
        mydll.ReadProcessMemory(int(phand), 0x12ED28D0, ctypes.byref(date), 4, None)
        print(date.value)
    
        if date.value <2450:
            print("modify")
            newdata = ctypes.c_long(2450)
            mydll.WriteProcessMemory(int(phand), 0x12ED28D0, ctypes.byref(newdata), 4, None)
        time.sleep(5)
  • 相关阅读:
    关于Linux_CentOS8.0安装软件时遇到的坑
    Docker基本命令
    mobilenetV2 +ssd相关文章梳理汇总
    FCN.py语义分割脚本代码小白级注释
    剑指 Offer 09. 用两个栈实现队列
    剑指 Offer 05. 替换空格
    剑指 Offer 04. 二维数组中的查找
    剑指 Offer 10 I. 斐波那契数列
    剑指 Offer 30. 包含min函数的栈
    剑指 Offer 06. 从尾到头打印链表
  • 原文地址:https://www.cnblogs.com/sea-stream/p/10804187.html
Copyright © 2020-2023  润新知