大坡3D软件开发

关注3D软件技术

蔡军生ID:caimouse
1064569次访问,排名22好友197人,关注者223
C++,3D,VC++软件开发,写技术文章,操作系统开发
[加为好友] [即时聊天] [发私信]
caimouse的文章
原创 572 篇
翻译 0 篇
转载 41 篇
评论 702 篇
蔡军生的公告

点击这里给我发消息

MSN: caimouse1976 at sina.com

最近评论
ASP_lover:

www.soAsp.net编程技术资料网很不错,
对我的技术提高很大!推荐给大家!















ASP_lover:www.soAsp.net编程技术资料网很不错,
对我的技术提高很大!推荐给大家!
thezoner:不错,学习到东西了

QQ日志
csdas22as:蔡军生先生才对。
csdas22as:蔡军生,对不起呀,名字写错了。
文章分类
收藏
相册
3D引擎
第二人生
开发板
历史回忆
常用连接
C++大师Stan Lippman(RSS)
MCU连接(RSS)
REACTOS开发网(中国)
人生历程
存档
软件项目交易
订阅我的博客
XML聚合  FeedSky

原创 Windows API一日一练(89)OpenProcess函数收藏

新一篇: Windows API一日一练(90)GetGlyphOutline函数 | 旧一篇: Windows API一日一练(88)EnumProcesses函数

这一年来流氓软件特别多,面对这种非常恶心的软件,让大家非常痛苦。正是在这种环境之下,众多客户需要强大查杀这种流氓软件的工具。如果让你来开发一个查杀这种病毒的软件,你会怎么做呢?当然是先把电脑里所有进程遍历出来,然后把每个进程的详细信息显示给用户,让用户决定自己那些进程可以运行,那些不可以运行。或者根据当前进程的信息,再跟根据病毒库里的特征码进行比较,就可以标识那些是可疑的病毒了。下面就来演示用函数OpenProcess怎么打开进程并获取进程的名称。
 
函数OpenProcess声明如下:
 
WINBASEAPI
__out
HANDLE
WINAPI
OpenProcess(
    __in DWORD dwDesiredAccess,
    __in BOOL bInheritHandle,
    __in DWORD dwProcessId
    );
dwDesiredAccess是访问进程的权限。
bInheritHandle是句柄是否继承进程属性。
dwProcessId是进程ID。
 
调用函数的例子如下:
#001 //获取进程的信息。
#002  //蔡军生 2007/12/13 QQ:9073204 深圳
#003  void TestOpenProcesses(void)
#004  {
#005         //
#006         const int nBufSize = 512;
#007         TCHAR chBuf[nBufSize];
#008         ZeroMemory(chBuf,nBufSize);
#009 
#010         //
#011         DWORD dwProcs[1024];
#012         DWORD dwNeeded;
#013 
#014         //枚举所有进程ID
#015         if ( !EnumProcesses( dwProcs, sizeof(dwProcs), &dwNeeded ) )
#016         {
#017               //输出出错信息。
#018               wsprintf(chBuf,_T("EnumProcesses failed (%d).\n"), GetLastError() );
#019               OutputDebugString(chBuf);
#020 
#021               return;
#022         }   
#023 
#024         // 计算有多少个进程ID
#025         DWORD dwProcCount = dwNeeded / sizeof(DWORD);
#026 
#027         wsprintf(chBuf,_T("EnumProcesses Count(%d).\n"), dwProcCount );
#028         OutputDebugString(chBuf);
#029 
#030         //遍历所有进程ID,打开进程。
#031         for (DWORD i = 0; i < dwProcCount; i++)
#032         {
#033               wsprintf(chBuf,_T("EnumProcesses (%d).\r\n"), dwProcs[i] );
#034             OutputDebugString(chBuf);
#035 
#036               //根据进程ID打开进程。
#037              HANDLE hProcess = OpenProcess( PROCESS_QUERY_INFORMATION |
#038                   PROCESS_VM_READ,
#039                   FALSE, dwProcs[i] );           
#040 
#041               if (hProcess)
#042               {
#043                    HMODULE hMod;
#044                    DWORD cbNeeded;
#045 
#046                    //获取进程第一个模块的句柄。
#047                    if ( EnumProcessModules( hProcess, &hMod, sizeof(hMod),
#048                          &cbNeeded) )
#049                    {
#050                          //
#051                          ZeroMemory(chBuf,nBufSize);
#052 
#053                          //获取进程第一个模块的名称。
#054                        if (::GetModuleBaseName(hProcess,hMod,chBuf,nBufSize))
#055                          {
#056                               //
#057                               OutputDebugString(chBuf);
#058                               OutputDebugString(_T("\r\n"));
#059                          }
#060                    }                    
#061               }
#062         }        
#063 
#064  }
 

发表于 @ 2007年12月13日 20:34:00|评论(loading...)|编辑

新一篇: Windows API一日一练(90)GetGlyphOutline函数 | 旧一篇: Windows API一日一练(88)EnumProcesses函数

评论

#shadowblue11 发表于2007-12-14 14:26:58  IP: 124.114.93.*
听说有牛人在写WINDOWS API一日一练,我这种菜鸟就来了。楼主加油啊!!!
#shadowblue11 发表于2007-12-14 14:43:16  IP: 124.114.93.*
想问个问题,在VS2005下写WONDOWS程序,到底应该怎样来使用字符和宽字符,我对WINDOWS的各种数据类型很迷惑,程序老是在这方面出问题。书上讲的好像也不多,应该怎么办?
2007-12-16 14:58:07作者回复
在WINDOWS里,主要有ANSI与UNICODE的区别。现在基本上都要使用UNICODE了。
#sinhi 发表于2007-12-16 22:07:14  IP: 222.183.10.*
不错啊,今天才发现这好东西,对我们新手来讲用处不小啊。
#netfirstman 发表于2007-12-16 22:12:29  IP: 10.10.4.86, 202.*
这个API我在编写自己的任务管理器时用过,主要就是通过进程的ID来获取进程的句柄。
#ggggqqqqihc 发表于2007-12-17 21:10:52  IP: 121.23.154.*
请问用OpenProcess打开进程后有什么办法能得到进程所使用的内存大小?
2007-12-18 21:05:09作者回复
看最新的BLOG。
#ribut9225 发表于2008-02-23 20:14:47  IP: 218.74.165.*
up
发表评论  


当前用户设置只有注册用户才能发表评论。如果你没有登录,请点击登录
Csdn Blog version 3.1a
Copyright © 蔡军生