您当前的位置: 首页 > 

顺其自然~

暂无认证

  • 1浏览

    0关注

    1317博文

    0收益

  • 0浏览

    0点赞

    0打赏

    0留言

私信
关注
热门博文

VirtualAllocEx 跨进程读写数据

顺其自然~ 发布时间:2021-12-17 16:53:56 ,浏览量:1

VirtualAllocEx 函数的作用是在指定进程的虚拟空间保留或提交内存区域,除非指定MEM_RESET参数,否则将该内存区域置0。 

LPVOID VirtualAllocEx( 
   HANDLE hProcess,  //  申请内存所在的进程句柄 
   LPVOID lpAddress,  //  保留页面的内存地址;一般用NULL自动分配 
   SIZE_T dwSize,  //  欲分配的内存大小,字节单位;注意实际分 配的内存大小是页内存大小的整数倍 
   DWORD flAllocationType, 
   DWORD flProtect 
);

flAllocationType,flProtect太多了,参数数值和意思MSDN上都有,不再赘述了. 问题描述:我要选中其他进程的一个ListView窗口中的一个Item,事实上只要发消息就可以了:  SendMessage( hWnd, LVM_SETITEMSTATE, (WPARAM)nItemIndex, (LPARAM)pLVItem );  可是其中的LPARAM要指向一个LVItem的结构,我们知道消息可以跨进程,但目标窗口收到消息时它需要寻址这个结构,而这个结构实际上存储在发送方的地址空间里;所以我们必须把LVItem的内容写入到窗口过程所在的地址空间内,于是便需要VirtualAllocEx和VirtualFreeEx了。  代码如下。 

ListViewOperator::ListViewOperator(HWND hWnd)  //  初始化函数 
{ 
    m_hwnd = NULL; //目标窗口 
    m_hProcess = NULL; //目标进程 
    m_pLVItem = NULL; //写入目标进程的LVITEM结构 
    m_pTextBuffer = NULL; //其他用途 

    m_hwnd = hWnd; 

    DWORD dwProcessId; 
    GetWindowThreadProcessId(hWnd, &dwProcessId); //获取进程ID 

    m_hProcess = OpenProcess(PROCESS_ALL_ACCESS, false, dwProcessId); //打开进程 
    THROW_EXCEPTION((m_hProcess == NULL), "Open process failed"); 

    m_pLVItem = (LVITEMA *)VirtualAllocEx( m_hProcess, NULL, sizeof(LVITEMA),    MEM_COMMIT, PAGE_READWRITE ); 在目标进程空间中获得内存,允许读取和写入。 
    THROW_EXCEPTION( (m_pLVItem == NULL), "Memory alloc failed" ); 
    m_pTextBuffer = (char *)VirtualAllocEx( m_hProcess, NULL, MAX_TEXT_BUFFER_LENGTH,    MEM_COMMIT, PAGE_READWRITE ); 
    THROW_EXCEPTION((m_pTextBuffer == NULL), "Memory alloc failed"); 
}  

void  ListViewOperator::SetItemSelected(int nItemIndex)  // 选中某一个ITEM 
{ 
    LVITEMA lvitem; // 静态结构 

    lvitem.mask = LVIF_STATE; 
    lvitem.iSubItem = 0; 
    lvitem.state = LVIS_SELECTED|LVIS_FOCUSED; 
    lvitem.stateMask = LVIS_SELECTED|LVIS_FOCUSED; 

    int nRet = WriteProcessMemory(m_hProcess, m_pLVItem, &lvitem, sizeof(LVITEM), NULL); // 将本地进程中的结构写入到目标进程 
    THROW_EXCEPTION( (nRet == 0), "Write Process memory failed"); 

    HRESULT hRet = SendMessage(m_hwnd, LVM_SETITEMSTATE, (WPARAM)nItemIndex, (LPARAM)m_pLVItem);//发送消息 
    THROW_EXCEPTION(FAILED(hRet), "Send message failed"); 

    return ; 
}  

关注
打赏
1662339380
查看更多评论
立即登录/注册

微信扫码登录

0.0401s