开启辅助访问 切换到宽版

精易论坛

 找回密码
 注册

QQ登录

只需一步,快速开始

用微信号发送消息登录论坛

新人指南 邀请好友注册 - 我关注人的新帖 教你赚取精币 - 每日签到


求职/招聘- 论坛接单- 开发者大厅

论坛版规 总版规 - 建议/投诉 - 应聘版主 - 精华帖总集 积分说明 - 禁言标准 - 有奖举报

查看: 12817|回复: 6
收起左侧

[已解决] 易语言获取进程启动参数

[复制链接]
结帖率:50% (2/4)
发表于 2011-10-4 10:02:01 | 显示全部楼层 |阅读模式   黑龙江省绥化市
10精币
本帖最后由 yhon宇少 于 2011-10-4 10:14 编辑

RT
应该是调用API实现、
但是调用的是哪个API呢、、
就像DOS命令wmic process get一样  
求解、、调用的是哪个DLL
-----
我自己找到了....
DLL如下:
[e].版本 2  .DLL命令 OpenProcess_API, 整数型, , "OpenProcess"     .参数 dwDesiredAccess, 整数型     .参数 bInheritHandle, 逻辑型     .参数 dwProcessId, 整数型  .DLL命令 CloseHandle, 逻辑型     .参数 hObject, 整数型  .DLL命令 GetModuleHandleA, 整数型     .参数 lpModuleName, 文本型  .DLL命令 GetProcAddress, 整数型     .参数 hModule, 整数型     .参数 lpProcName, 文本型  .DLL命令 CreateRemoteThread, 整数型     .参数 hProcess, 整数型     .参数 lpThreadAttributes, 整数型     .参数 dwStackSize, 整数型     .参数 lpStartAddress, 整数型     .参数 lpParameter, 整数型     .参数 dwCreationFlags, 整数型     .参数 lpThreadId, 整数型  .DLL命令 GetExitCodeThread, 逻辑型, , "GetExitCodeThread"     .参数 hThread     .参数 lpExitCode, , 传址  .DLL命令 WaitForSingleObject, 整数型     .参数 hHandle, 整数型     .参数 dwMilliseconds, 整数型  .DLL命令 ReadProcessMemory, 逻辑型     .参数 hProcess, 整数型     .参数 lpBaseAddress, 整数型     .参数 lpBuffer, 文本型     .参数 nSize, 整数型     .参数 lpNumberOfBytesRead, 整数型, 传址 [/e]
还有一个类
[e].版本 2  .程序集 CImagePathAndCommandLine, , 公开 .程序集变量 m_hProcess, 整数型  .子程序 _初始化, , , 当基于本类的对象被创建后,此方法会被自动调用    .子程序 _销毁, , , 当基于本类的对象被销毁前,此方法会被自动调用    .子程序 OpenProcess, 逻辑型, 公开, 打开目标进程。成功返回真,失败返回假。备注:若不再操作目标进程,请调用“Close”方法释放资源。 .参数 dwProcessId, 整数型, , 目标进程ID  m_hProcess = OpenProcess_API (位或 (#PROCESS_VM_READ, #PROCESS_DUP_HANDLE, #PROCESS_VM_OPERATION, #PROCESS_CREATE_THREAD, #PROCESS_QUERY_INFORMATION), 假, dwProcessId)  ' 打开目标进程 返回 (m_hProcess ≠ 0)  .子程序 Close, 逻辑型, 公开, 关闭已打开的句柄,释放资源。成功返回真,失败返回假。  .如果真 (m_hProcess ≠ 0)     .如果真 (CloseHandle (m_hProcess))  ' 关闭进程句柄         m_hProcess = 0         返回 (真)     .如果真结束  .如果真结束 返回 (假)  .子程序 SetHandle, , 公开, 置入进程句柄,可通过本类的实例操作目标进程。 .参数 hProcess, 整数型, , 目标进程ID .参数 bCloseOldHandle, 逻辑型, 可空, 是否把已打开的句柄释放。建议该参数为真。否则有可能会导致内存泄漏。  .如果真 (bCloseOldHandle)     CloseHandle (m_hProcess)  ' 关于进程句柄 .如果真结束 m_hProcess = hProcess  .子程序 GetSaveHandle, 整数型, 公开, 获取已保存的句柄  返回 (m_hProcess)  .子程序 GetProcessImagePathAndCommandLine, 逻辑型, 公开, 获取目标进程的映像路径及命令行参数。成功返回真,失败返回假。 .参数 lpstrImagePathAndCommandLine, 文本型, 参考, 用于保存目标进程的映像路径及命令行参数的文本型变量 .局部变量 GetCommandLineA_addr, 整数型, , , GetCommandLineA的地址 .局部变量 hRemoteThread, 整数型, , , 远程线程句柄 .局部变量 lptstr, 整数型, , , 远程进程的映像路径及命令行参数的基址 .局部变量 lstrlenA_addr, 整数型, , , lstrlenA的地址 .局部变量 strlen, 整数型, , , 长度  GetCommandLineA_addr = GetProcAddress (GetModuleHandleA (“Kernel32.dll”), “GetCommandLineA”)  ' 获取 GetCommandLineA 的地址 hRemoteThread = CreateRemoteThread (m_hProcess, 0, 0, GetCommandLineA_addr, 0, 0, 0)  ' 创建远程线程执行 GetCommandLineA 函数,并获取该线程的线程句柄 .如果 (hRemoteThread ≠ 0)     WaitForSingleObject (hRemoteThread, #INFINITE)  ' 等待线程结束     GetExitCodeThread (hRemoteThread, lptstr)  ' 获取线程退出代码     CloseHandle (hRemoteThread)  ' 关闭线程句柄 .否则     返回 (假) .如果结束 lstrlenA_addr = GetProcAddress (GetModuleHandleA (“Kernel32.dll”), “lstrlenA”)  ' 获取 lstrlenA 的地址 hRemoteThread = CreateRemoteThread (m_hProcess, 0, 0, lstrlenA_addr, lptstr, 0, 0)  ' 创建远程线程执行 lstrlenA 函数,并获取该线程的线程句柄 .如果 (hRemoteThread ≠ 0)     WaitForSingleObject (hRemoteThread, #INFINITE)  ' 等待线程结束     GetExitCodeThread (hRemoteThread, strlen)  ' 获取线程退出代码     CloseHandle (hRemoteThread)  ' 关闭线程句柄 .否则     返回 (假) .如果结束 lpstrImagePathAndCommandLine = 取空白文本 (strlen)  ' 申请内存空间,用于保存远程进程的映像路径及命令行参数的基址 .如果真 (ReadProcessMemory (m_hProcess, lptstr, lpstrImagePathAndCommandLine, strlen, 0))  ' 读取远程进程的映像路径及命令行参数     返回 (真) .如果真结束 返回 (假) [/e]

窗口:  超列 按钮[e].版本 2 .支持库 eAPI .支持库 iext  .程序集 窗口程序集1  .子程序 _按钮1_被单击 .局部变量 ipacl, CImagePathAndCommandLine .局部变量 strBuffer, 文本型 .局部变量 ProcessInfo, 进程信息, , "0" .局部变量 n, 整数型 .局部变量 nIndex, 整数型  超级列表框1.全部删除 () ProcessInfo = 取系统进程列表 () .计次循环首 (取数组成员数 (ProcessInfo), n)     nIndex = 超级列表框1.插入表项 (, ProcessInfo [n].进程名称, , , , )     .如果 (ipacl.OpenProcess (ProcessInfo [n].进程标识符))         ipacl.GetProcessImagePathAndCommandLine (strBuffer)         ipacl.Close ()         超级列表框1.置标题 (nIndex, 1, strBuffer)     .否则         超级列表框1.置标题 (nIndex, 1, “打开进程失败,请先提升进程权限。”)     .如果结束  .计次循环尾 ()  [/e]



回答提醒:如果本帖被关闭无法回复,您有更好的答案帮助楼主解决,请发表至 源码区 可获得加分喔。
友情提醒:本版被采纳的主题可在 申请荣誉值 页面申请荣誉值,获得 1点 荣誉值,荣誉值可兑换荣誉会员、终身vip用户组。
快捷通道:申请荣誉值无答案申请取消悬赏投诉有答案未采纳为最佳
结帖率:63% (5/8)

签到天数: 1 天

发表于 2011-10-4 10:50:07 | 显示全部楼层   广东省广州市
用 CreateToolhelp32Snapshot  取进程快照存放到PROCESSENTRY32结构的指针里面,然后再从PROCESSENTRY32结构指针里面调用进程参数。
回复

使用道具 举报

结帖率:100% (1/1)
发表于 2012-8-3 18:16:00 | 显示全部楼层   四川省宜宾市
procedure TForm1.Btn1Click(Sender: TObject);
var
open:Thandle;
hKernel:cardinal;
dwAddr:integer;
tepAddr:integer;
dwRead:cardinal;
p:pointer;
s:Pchar;
begin
Open:=OpenProcess( Process_VM_Read,false,992);
hKernel:=LoadLibrary(Pchar('kernel32.dll'));
dwAddr := integer(GetProcAddress(hKernel, Pchar('GetCommandLineA')))+1;
ReadProcessMemory(open, pointer(dwAddr),@dwAddr,4, dwRead);
ReadProcessMemory(open, pointer(dwAddr),@dwAddr,4, dwRead);
GetMem(p, 512);
if ReadProcessMemory(open, pointer(dwAddr),p,512, dwRead) then
showmessage(Pchar(p));
FreeMem(p);
CloseHandle(Open);
end;
回复

使用道具 举报

发表于 2015-8-18 18:15:31 | 显示全部楼层   河北省承德市
位或 (#PROCESS_VM_READ, #PROCESS_DUP_HANDLE, #PROCESS_VM_OPERATION, #PROCESS_CREATE_THREAD, #PROCESS_QUERY_INFORMATION), 假, dwProcessId)  ' 打开目标进程 返回 (m_hProcess ≠ 0)   这个是#是常量吗???????运行不了啊????求解答
回复

使用道具 举报

结帖率:100% (3/3)
发表于 2015-10-1 10:55:00 | 显示全部楼层   江西省九江市
看不懂,大侠
回复

使用道具 举报

结帖率:100% (3/3)

签到天数: 2 天

发表于 2018-8-30 23:44:49 | 显示全部楼层   湖南省衡阳市
大神厉害
回复

使用道具 举报

发表于 2023-8-5 18:24:40 | 显示全部楼层   广东省东莞市
好乱的的码
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 注册

本版积分规则 致发广告者

发布主题 收藏帖子 返回列表

sitemap| 易语言源码| 易语言教程| 易语言论坛| 易语言模块| 手机版| 广告投放| 精易论坛
拒绝任何人以任何形式在本论坛发表与中华人民共和国法律相抵触的言论,本站内容均为会员发表,并不代表精易立场!
论坛帖子内容仅用于技术交流学习和研究的目的,严禁用于非法目的,否则造成一切后果自负!如帖子内容侵害到你的权益,请联系我们!
防范网络诈骗,远离网络犯罪 违法和不良信息举报电话0663-3422125,QQ: 793400750,邮箱:wp@125.la
Powered by Discuz! X3.4 揭阳市揭东区精易科技有限公司 ( 粤ICP备12094385号-1) 粤公网安备 44522102000125 增值电信业务经营许可证 粤B2-20192173

快速回复 返回顶部 返回列表