|
wl00560
银牌会员
    
积分 1384
发帖 709
注册 2005-10-29
状态 离线
|
『楼 主』:
如何判断内存中有某个程序?
使用 LLM 解释/回答一下
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
状态 离线
|
|
2010-4-18 19:50 |
|
|
rs369007
初级用户
 
积分 147
发帖 131
注册 2008-9-22
状态 离线
|
『第 4 楼』:
使用 LLM 解释/回答一下
用 %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={0};
int flag;
if(argc!=2) return 0;
if(0==(strcmp(argv,"-h")))
{
help_info();
return 0;
}
flag=judge_process(argv);
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 KiB,下载次数: 2)
|

freedom! |
|
2010-4-18 20:33 |
|
|
rs369007
初级用户
 
积分 147
发帖 131
注册 2008-9-22
状态 离线
|
『第 5 楼』:
使用 LLM 解释/回答一下
例如在批处理中:写如下语句
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
状态 离线
|
|
2010-4-18 21:21 |
|
|
exzzz
初级用户
  游手好闲 + 无所事事 ..
积分 194
发帖 167
注册 2007-4-30
状态 离线
|
『第 7 楼』:
使用 LLM 解释/回答一下
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 楼』:
使用 LLM 解释/回答一下
一些汉字系统好像是做标志的,通过中断检测。
如果 ccdos 没有的话,就搜索内存找标志吧。
Last edited by jawbin on 2010-4-19 at 12:00 ]
|
|
2010-4-19 11:57 |
|
|
rs369007
初级用户
 
积分 147
发帖 131
注册 2008-9-22
状态 离线
|
|
2010-4-19 14:43 |
|
|
wl00560
银牌会员
    
积分 1384
发帖 709
注册 2005-10-29
状态 离线
|
『第 11 楼』:
使用 LLM 解释/回答一下
哎,不要说汇编什么了,我只是个菜鸟啊,哪儿懂那些?呵呵……
如果没什么不太复杂的方法,就算了……
|
|
2010-4-19 14:48 |
|
|
wl00560
银牌会员
    
积分 1384
发帖 709
注册 2005-10-29
状态 离线
|
『第 12 楼』:
使用 LLM 解释/回答一下
如果通过 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
状态 离线
|
|
2010-4-21 01:53 |
|