|
wl00560
银牌会员
积分 1384
发帖 709
注册 2005-10-29
状态 离线
|
『楼 主』:
如何判断内存中有某个程序?
DOS的批处理……
比如说,如果内存中有CCDOS,则执行某一程序……
如果内存中没有CCDOS,则不执行……
|
|
2010-4-17 02:17 |
|
|
wl00560
银牌会员
积分 1384
发帖 709
注册 2005-10-29
状态 离线
|
|
2010-4-18 18:59 |
|
|
rs369007
初级用户
积分 147
发帖 131
注册 2008-9-22
状态 离线
|
『第
3 楼』:
api 获取进程快照 进行遍历
|
freedom! |
|
2010-4-18 19:50 |
|
|
rs369007
初级用户
积分 147
发帖 131
注册 2008-9-22
状态 离线
|
『第
4 楼』:
用 %errorlevel% 或&& 、|| 等就可以获得程序的运行成功或失败
//code by 森仔 2010.4.18
#include<windows.h>
#include<stdio.h>
#include <tlhelp32.h>
unsigned long judge_process(char *img_name);
int help_info();
int main(int argc,char *argv[])
{
char imagename[20]={0};
int flag;
if(argc!=2) return 0;
if(0==(strcmp(argv[1],"-h")))
{
help_info();
return 0;
}
flag=judge_process(argv[1]);
if(flag==-1)
{
printf("%s 没被加载运行!",imagename);
return -1;
}
else
{
printf("%s 已被加载运行!",imagename);
return 0;
}
}
unsigned long judge_process(char *img_name)
{
HANDLE process_snap =
CreateToolhelp32Snapshot(TH32CS_SNAPPROCESS, 0);
if(process_snap == (HANDLE)-1)
return -1;
PROCESSENTRY32 process_enter;
process_enter.dwSize = sizeof(PROCESSENTRY32);
if(!Process32First(process_snap,&process_enter))
return -1;
do {
if(0 == strcmpi(img_name, process_enter.szExeFile))
return 0;
}while (Process32Next(process_snap,&process_enter));
if(NULL != process_snap)
CloseHandle(process_snap);
return -1;
}
int help_info()
{
char help_info[]=
"用法示例:\n"
"-h 显示此信息\n"
"prodetect qq.exe";
puts(help_info);
return 0;
} [ Last edited by rs369007 on 2010-5-2 at 16:10 ]
附件
1: prodetect.rar (2010-4-18 20:35, 5.24 K,下载次数: 2)
|
freedom! |
|
2010-4-18 20:33 |
|
|
rs369007
初级用户
积分 147
发帖 131
注册 2008-9-22
状态 离线
|
『第
5 楼』:
例如在批处理中:写如下语句
prodetect qq.exe&&echo prodetect work well!
1,如果qq.exe 正在运行后面echo prodetect work well!会被执行
2,如果qq.exe 没有被加载到内存运行,则不会执行
还可以通过 执行prodetect后马上 用
if %errorlevel% EQU -1 ---------表示没在内存
if %errorlevel% EQU 0 ---------表示正在运行
|
freedom! |
|
2010-4-18 20:41 |
|
|
wl00560
银牌会员
积分 1384
发帖 709
注册 2005-10-29
状态 离线
|
『第
6 楼』:
谢谢啦,不过你这个好像不能在DOS(纯DOS)下运行呢,说是要Windows支持,呵呵。
|
|
2010-4-18 21:21 |
|
|
exzzz
初级用户
游手好闲 + 无所事事 ..
积分 194
发帖 167
注册 2007-4-30
状态 离线
|
『第
7 楼』:
wmic可以做到
@echo off&cls
set /p appname=请输入要检查的进程名:
wmic process list brief | findstr /i /c:"%appname%"
if %errorlevel% equ 0 echo "%appname% exist!"
if %errorlevel% equ 1 echo "%appname% not exist!"
pause
|
|
|
2010-4-18 23:45 |
|
|
wl00560
银牌会员
积分 1384
发帖 709
注册 2005-10-29
状态 离线
|
|
2010-4-19 00:17 |
|
|
jawbin
高级用户
积分 994
发帖 444
注册 2005-1-29
状态 离线
|
『第
9 楼』:
一些汉字系统好像是做标志的,通过中断检测。
如果 ccdos 没有的话,就搜索内存找标志吧。
[ Last edited by jawbin on 2010-4-19 at 12:00 ]
|
|
2010-4-19 11:57 |
|
|
rs369007
初级用户
积分 147
发帖 131
注册 2008-9-22
状态 离线
|
『第
10 楼』:
通过汇编 ?
|
freedom! |
|
2010-4-19 14:43 |
|
|
wl00560
银牌会员
积分 1384
发帖 709
注册 2005-10-29
状态 离线
|
『第
11 楼』:
哎,不要说汇编什么了,我只是个菜鸟啊,哪儿懂那些?呵呵……
如果没什么不太复杂的方法,就算了……
|
|
2010-4-19 14:48 |
|
|
wl00560
银牌会员
积分 1384
发帖 709
注册 2005-10-29
状态 离线
|
『第
12 楼』:
如果通过 mem /c |find /c "CCDOS"(要注意大小写),可以出现1(存在CCDOS)或0(不存在CCDOS),不知有没有可能用if来判断这种情况。
|
|
2010-4-19 14:53 |
|
|
wangka
初级用户
积分 27
发帖 19
注册 2009-11-26
状态 离线
|
|
2010-4-20 15:15 |
|
|
wl00560
银牌会员
积分 1384
发帖 709
注册 2005-10-29
状态 离线
|
『第
14 楼』:
实在不知要如何抓执行之后的0和1,高手来出点主意吧,谢谢啦……
|
|
2010-4-21 01:53 |
|