about ReadProcessMemory

   DWORD dwProcessId;
    HANDLE hProcess;
    SCOPEINFO psi_buffer;
    BOOL fRet = FALSE;

    GetWindowThreadProcessId(hwnd, &dwProcessId);

    if (dwProcessId != GetCurrentProcessId())
    {
        // If the memory is owned by a process other than the current process we
        // need to remote read memory from that process.

        hProcess = OpenProcess(0, FALSE, dwProcessId);

        if(!hProcess)
        {
            fRet = FALSE;
            goto Leave;
        }
        else
        {       
            if(!ReadProcessMemory(hProcess,
                (VOID *) psi,(VOID *) &psi_buffer, sizeof(SCOPEINFO), NULL))
            {
                fRet = FALSE;
                goto Leave;
            }
        }
    }
    else
    {
        psi_buffer = *psi;
    }

    if (psi_buffer.dwSize != sizeof(SCOPEINFO))
    {
        return FALSE;
    }
    UserTakenHereFlag;
    EnterUserMaybe();

    ScopeControl *psc = (ScopeControl *)GetWindowLong(hwnd, 0);
    if (!psc)
    {
        fRet = FALSE;
        goto Leave;
    }   

    if (dwProcessId != GetCurrentProcessId())
    {
       if(!WriteProcessMemory(hProcess, (VOID *) psi,
              (VOID *) &psc->m_si, sizeof(SCOPEINFO), NULL))
       {
            fRet = FALSE;
            goto Leave;
       }
    }
    else
    {
        memcpy(psi, &psc->m_si, sizeof(SCOPEINFO));
    }
    fRet = TRUE;

Leave:
    LeaveUserMaybe();

    if (hProcess)
    {
        CloseHandle(hProcess);
    }

posted on 2010-04-20 16:26  酸辣大白菜  阅读(218)  评论(0编辑  收藏  举报

导航