进程与线程(一):一些关于进程的r3级API操作(1)

2023-12-03 00:38
文章标签 线程 操作 进程 api r3

本文主要是介绍进程与线程(一):一些关于进程的r3级API操作(1),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

   最近研究进程与线程,用reactos走了2遍内核executive层面的进程管理代码,看着真晕,为了缓解下大脑,看一点ring3的东西,《windows via c/c++》第四章,记下笔记。

很无聊的代码,就是试试几个API,无技术含量,无返回值判断,无实际功能的三无代码。

如果有人无聊要编译的话,不通过是很正常的,include 和 lib 还有一个函数没贴出来 

    1 int _tmain(int argc, TCHAR* argv[], TCHAR* envp[]) 2 { 3     _tsetlocale(LC_ALL,_T("chs") );  4     ::system("title ReturnsMe的win32api测试程序"); 5 6     //2009年8月19日 windows via c/c++ 第四章 读书笔记 7 8 9     //1.关于实例句柄 10     HMODULE hmodule =GetModuleHandle(_T("NTDLL.DLL")); 11          12     TCHAR szFilePath[MAX_PATH+1]; 13 14     //winmain中的hInstance 是应用程序独一无二的实例句柄,我们通过这个实例句柄得到文件的完整路径.由于我们这个是控制台程序 15     //所以先用GetModuleHandle(NULL)得到这个hInstance,hInstance与hmodule是一回事儿。 16     //如果我们这里传入一个文件名,比如NTDLL.DLL,就可以得到这个文件的相关信息 17 18     GetModuleFileName(hmodule,szFilePath,sizeof(szFilePath)/sizeof(szFilePath[0])); 19 20     wprintf(_T("path:  %s \n"),szFilePath); 21     wprintf(_T("ImageBase:  0x%x \n"),hmodule); 22      23     //2.得到命令行参数 24     //GetCommandLine()获取命令行参数,然后可以调用CommandLineToArgvW()转换,这里先不做相信描述,用到再说吧。 25      26 27     //3.得到进程所在驱动器和目录 28     TCHAR szBuff[MAX_PATH+1]; 29     GetCurrentDirectory(MAX_PATH+1,szBuff); 30     wprintf(_T("mydir:  %s \n"),szBuff); 31 32     //4.GetFullPathName 与3处理方法类似 33 34     //5,得到系统版本,搞不懂为什么osinfo要强制转换成LPOSVERSIONINFO才能编译通过, 35     //可能是声明的问题。。。是否是EX,要api根据sizeof的大小判断 36 37     OSVERSIONINFOEX osinfo; 38     osinfo.dwOSVersionInfoSize = sizeof(OSVERSIONINFOEX); 39     GetVersionEx((LPOSVERSIONINFO)&osinfo); 40     wprintf(_T("osinfo:  %d.%d sp%d.%d \n"),osinfo.dwMajorVersion,osinfo.dwMinorVersion,osinfo.wServicePackMajor,osinfo.wServicePackMinor); 41      42     //6 CreateProcess 创建进程,ExitProcess结束自身进程,TerminateProcess 结束其他进程 43     STARTUPINFO si = {sizeof(si)}; 44     PROCESS_INFORMATION pi; 45     TCHAR szExeName[ ]= _T("E:\\Work\\Code\\Mydriver\\WIN32API\\Debug\\rm.exe"); 46      47     //WaitForSingleObject的作用是等待子进程处理结束才继续 48     CreateProcess(szExeName,NULL,NULL,NULL,FALSE,NULL,NULL,NULL,&si,&pi); 49     WaitForSingleObject(pi.hProcess,INFINITE); 50 51     //7.PEB的操作有很多,文章也不少了,这里弄一个无聊的。获取某个进程的peb地址,在vista中,peb是动态的,不能通过硬编码获得。 52 53     CString  strAppName; 54     DWORD dwAppPID; 55     wchar_t wcTemp[260]; 56 57     wprintf(_T("请输入程序名:\n")); 58     wscanf(L"%s",wcTemp); 59     strAppName.Format(L"%s",wcTemp); 60 61     dwAppPID = GetProcessIdFromName(strAppName); 62 63     if (-2 == dwAppPID) 64     { 65         wprintf(_T("无此进程\n")); 66     } 67 68     HANDLE hProc = OpenProcess(PROCESS_ALL_ACCESS,FALSE,dwAppPID); 69 70     PROCESS_BASIC_INFORMATION  proinfo; 71     ZwQueryInformationProcess(hProc,ProcessBasicInformation,(PVOID)&proinfo,sizeof(proinfo),NULL); 72     PPEB PEBaddr = proinfo.PebBaseAddress; 73     wprintf(_T("PEB:  0x%x \n"),PEBaddr); 74 75      76 77      78 79     ::system("pause"); 80 81     return 0; 82 }


这篇关于进程与线程(一):一些关于进程的r3级API操作(1)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/447455

相关文章

springboot项目中常用的工具类和api详解

《springboot项目中常用的工具类和api详解》在SpringBoot项目中,开发者通常会依赖一些工具类和API来简化开发、提高效率,以下是一些常用的工具类及其典型应用场景,涵盖Spring原生... 目录1. Spring Framework 自带工具类(1) StringUtils(2) Coll

Python 中的 with open文件操作的最佳实践

《Python中的withopen文件操作的最佳实践》在Python中,withopen()提供了一个简洁而安全的方式来处理文件操作,它不仅能确保文件在操作完成后自动关闭,还能处理文件操作中的异... 目录什么是 with open()?为什么使用 with open()?使用 with open() 进行

Linux ls命令操作详解

《Linuxls命令操作详解》通过ls命令,我们可以查看指定目录下的文件和子目录,并结合不同的选项获取详细的文件信息,如权限、大小、修改时间等,:本文主要介绍Linuxls命令详解,需要的朋友可... 目录1. 命令简介2. 命令的基本语法和用法2.1 语法格式2.2 使用示例2.2.1 列出当前目录下的文

Mysql表的简单操作(基本技能)

《Mysql表的简单操作(基本技能)》在数据库中,表的操作主要包括表的创建、查看、修改、删除等,了解如何操作这些表是数据库管理和开发的基本技能,本文给大家介绍Mysql表的简单操作,感兴趣的朋友一起看... 目录3.1 创建表 3.2 查看表结构3.3 修改表3.4 实践案例:修改表在数据库中,表的操作主要

C# WinForms存储过程操作数据库的实例讲解

《C#WinForms存储过程操作数据库的实例讲解》:本文主要介绍C#WinForms存储过程操作数据库的实例,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、存储过程基础二、C# 调用流程1. 数据库连接配置2. 执行存储过程(增删改)3. 查询数据三、事务处

Java使用Curator进行ZooKeeper操作的详细教程

《Java使用Curator进行ZooKeeper操作的详细教程》ApacheCurator是一个基于ZooKeeper的Java客户端库,它极大地简化了使用ZooKeeper的开发工作,在分布式系统... 目录1、简述2、核心功能2.1 CuratorFramework2.2 Recipes3、示例实践3

Java利用JSONPath操作JSON数据的技术指南

《Java利用JSONPath操作JSON数据的技术指南》JSONPath是一种强大的工具,用于查询和操作JSON数据,类似于SQL的语法,它为处理复杂的JSON数据结构提供了简单且高效... 目录1、简述2、什么是 jsONPath?3、Java 示例3.1 基本查询3.2 过滤查询3.3 递归搜索3.4

Spring Boot3虚拟线程的使用步骤详解

《SpringBoot3虚拟线程的使用步骤详解》虚拟线程是Java19中引入的一个新特性,旨在通过简化线程管理来提升应用程序的并发性能,:本文主要介绍SpringBoot3虚拟线程的使用步骤,... 目录问题根源分析解决方案验证验证实验实验1:未启用keep-alive实验2:启用keep-alive扩展建

基于Flask框架添加多个AI模型的API并进行交互

《基于Flask框架添加多个AI模型的API并进行交互》:本文主要介绍如何基于Flask框架开发AI模型API管理系统,允许用户添加、删除不同AI模型的API密钥,感兴趣的可以了解下... 目录1. 概述2. 后端代码说明2.1 依赖库导入2.2 应用初始化2.3 API 存储字典2.4 路由函数2.5 应

Python使用DrissionPage中ChromiumPage进行自动化网页操作

《Python使用DrissionPage中ChromiumPage进行自动化网页操作》DrissionPage作为一款轻量级且功能强大的浏览器自动化库,为开发者提供了丰富的功能支持,本文将使用Dri... 目录前言一、ChromiumPage基础操作1.初始化Drission 和 ChromiumPage