ID与句柄

如果我们成功创建一个进程,CreateProcess函数会给我们返回一个结构体,包括四个数

据:进程编号(ID)、进程句柄、线程编号(ID)、线程句柄.

进程ID其实我们早见过了,通常我们称之为PID



句柄每一个进程都有一张自己的私有的表,而操作系统也有一份句柄表,我们称为全局句柄表,这张表存储着私有的内核对象.

系统句柄表



PID我们就可以理解为全局句柄表中的一个索引,那么PID和句柄的区别就很容易看出来了,PID是全局的,在任何进程中都有意义,都可以使用,而句柄则是句柄的、私有的;PID是唯一的,绝对不可能出现重复的存在,但是当进程消失,那么这个PID就有可能会分给另一个进程。(PID不是句柄,但是可以通过PID获取得到全局句柄表中对应的句柄)

TerminateProcess函数

BOOL TerminateProcess(
HANDLE hProcess, // handle to the process 句柄
UINT uExitCode // exit code for the process 退出代码
;

1.创建一个进程A



2.使用B进程来结束A



TerminateProcess函数是用来终止进程的,具体的可以参考MSDN Library,在这里我们很清楚的可以看见终止

进程失败了,这个错误编号的意思就是句柄无效,那么就论证了句柄是私有的,其他进程无法根据这个句柄来

终止进程,但是我们想要真正的关闭这个进程,那就需要借助PID来获取句柄了,具体细节如下。

openProcess

Opens an existing local process object.
HANDLE WINAPI OpenProcess(
DWORD dwDesiredAccess,//打开进程的的权限问题 access flag 你希望的访问权限
BOOL bInheritHandle,//允不允许子进程继承呢
DWORD dwProcessId //全局PID 进程ID
);

我通过PID打开进程(OpenProcess函数),拥有所有权,不继承句柄表当前OpenProess函数执行完之后,我就获得一个句柄,通过这个句柄我就可以终止进程

HANDLE hProcess;
hProcess = OpenProcess(PROCESS_ALL_ACCESS, FALSE, 0x524);
if(!TerminateProcess(hProcess, 0)) {
printf("终止进程失败:%d \n", GetLastError());
}

以挂起的形式创建进程

Creates a new process and its primary thread. The new process runs in the security context of the calling process.

创建一个新进程和它的主要线程。这个新进程跑再一个安全正在调用的进程上下文中

第六个参数DWORD dwCreationFlags

BOOL WINAPI CreateProcess(
LPCTSTR lpApplicationName,
LPTSTR lpCommandLine,
LPSECURITY_ATTRIBUTES lpProcessAttributes,
LPSECURITY_ATTRIBUTES lpThreadAttributes,
BOOL bInheritHandles,
DWORD dwCreationFlags,//创建一个新的控制台
LPVOID lpEnvironment,
LPCTSTR lpCurrentDirectory,
LPSTARTUPINFO lpStartupInfo,
LPPROCESS_INFORMATION lpProcessInformation
);

当我们创建一个控制台进程时,会发现子进程和父进程都在都一个命令控制台中

而如果我们想要区分的话就需要借助dwCreationFlags这个参数,将其修改为CREATE_NEW_CONSOLE即可:但是这个并不是我们最重要的,或者说不是其真正有意义的参数,有意义的事参数值为CREATE_SUSPEND,也就是以挂起的形式创建进程。

回顾

1.进程的创建

我们需要知道任何进程都是别的进程创建的,当我们在Windows下双击一个文件,实际上就是explore.exe这个进程创建我们打开文件的进程,其使用的方法就是:CreateProcess()

  1. 任何进程都是别的进程创建的:CreateProcess()

  2. 进程创建过程

1.映射EXE文件 (低2G)

2.创建内核对象EPROCESS (高2G)

3.映射系统DLL (ntdll.dll)

4.创建线程内核对象RTHREAD(高2G)

5.系统启动线程

映射DLL(ntdll.KdrInitialize Thunk)

线程开始执行

2.进程的创建

1.映射EXE文件

2.创建内核对象EPROCESS

3.映射系统DLL(ntdll.dll)

4.创建线程内核对象ETHREAD

5.如果是挂起的方式创建的:

.....

6.恢复以后再继续执行

1.映射DLL(ntdll.KdrInitializeThunk)

  2.线程开始执行

那也就说明了一点,挂起本质上挂起的是线程,进程还是会创建的,所以,最终如果想恢复的话也是恢复线程

模块与工作目录

GetModuleFileNameGetCurrentDirectory函数可以分别获得当前模块目录和当前工作目录:

char strModule[256];

GetModuleFileName(NULL,strModule,256);//得到当前模块目录,当前exe所在的路径,包含exe文件名

char strWork[1000];

int i = 1000;

GetCurrentDirectory(1000,buf);//获取当前工作目录

printf("某块目录:%s\n 工作目录:%s\n",strModule,strWork);

GetModuleFileName

获取当前模块的路径

获取现有目录

GetCurrentDirectory需要注意的是工作目录是可以修改的,我们可以通过CreateProcess函数来创建一个进程,并且修改其工作目录,这是CreateProcess函数的第8个参数LPCTSTR lpCurrentDirectory.

其他相关API

  • 获取进程PID

    GetCurrentProcessId
  • 获取进程句柄

    GetCurrentProcess
  • 获取命令行

    GetCommandLine
  • 获取启动信息

    GetStartupinfo
  • 遍历进程ID

    EnumProcesses
  • 快照

    CreateToolhelp32napshot

进程相关API的更多相关文章

  1. 进程相关的API函数

    0x01. ID与句柄 如果我们成功创建一个进程之后,CreateProcess会返回四个数据,id和句柄 句柄的话就是 当前进程私有的句柄表索引(这是当前进程,给别进程也没用) 每个进程都有一张自己 ...

  2. OC中并发编程的相关API和面临的挑战

    OC中并发编程的相关API和面临的挑战(1) 小引 http://www.objc.io/站点主要以杂志的形式,深入挖掘在OC中的最佳编程实践和高级技术,每个月探讨一个主题,每个主题都会有几篇相关的文 ...

  3. 恶意软件开发——内存相关API

    一.前言 Windows操作系统的内存有三种属性,分别为:可读.可写.可执行,并且操作系统将每个进程的内存都隔离开来,当进程运行时,创建一个虚拟的内存空间,系统的内存管理器将虚拟内存空间映射到物理内存 ...

  4. OpenGL FrameBufferCopy相关Api比较(glCopyPixels,glReadPixels,glCopyTexImage2D,glFramebufferTexture2D)

    OpenGL FrameBufferCopy相关Api比较 glCopyPixels,glReadPixels,glCopyTexImage2D,glFramebufferTexture2D 标题所述 ...

  5. QQ音乐的各种相关API

    QQ音乐的各种相关API 分类: oc2014-01-29 15:34 2676人阅读 评论(2) 收藏 举报 基本上论坛里做在线音乐的都在用百度的API,进来发现百度的API不仅歌曲的质量不可以保证 ...

  6. addChildViewController相关api深入剖析

    注:本文根据个人的实践和理解写成,若有不当之处欢迎斧正和探讨! addChildViewController是一个从iOS5开始支持的api接口,相关的一系列的接口是用来处理viewcontrolle ...

  7. [原创]java WEB学习笔记44:Filter 简介,模型,创建,工作原理,相关API,过滤器的部署及映射的方式,Demo

    本博客为原创:综合 尚硅谷(http://www.atguigu.com)的系统教程(深表感谢)和 网络上的现有资源(博客,文档,图书等),资源的出处我会标明 本博客的目的:①总结自己的学习过程,相当 ...

  8. linux内核数据结构--进程相关

    linux里面,有一个结构体task_struct,也叫“进程描述符”的数据结构,它包含了与进程相关的所有信息,它非常复杂,每一个字段都可能与一个功能相关,所以大部分细节不在我的研究范围之内,在这篇文 ...

  9. Linux2.6内核--VFS层中和进程相关的数据结构

          系统中的每一个进程都有自己的一组打开的文件,像根文件系统,当前工作目录,安装点等.有三个数据结构将 VFS 层和系统的进程紧密的联系在一起,它们分别是: file_struct,fs_st ...

  10. 使用 c# 调用进程相关开发

    最近在维护公司的以前项目中发现,使用到了进程相关知识.现在将此总结,以备后面查看复习. 一.进程查看器     程序在运行的时候,操作系统就会为其分配一个进程.那么进程到底是什么东西呢? 实际上,进程 ...

随机推荐

  1. 33-module

    const { resolve } = require('path') const HtmlWebpackPlugin = require('html-webpack-plugin') module. ...

  2. JS逆向实战13——某市公共资源交易中心Cookie混淆加密

    "本文地址:https://www.cnblogs.com/zichliang/p/17346860.html 目标网站 aHR0cDovL2xkZ2d6eS5obmxvdWRpLmdvdi ...

  3. 本地socket通讯

    本地socket通讯        虽然学过网络socket,但是对于本地socket通讯却不是很熟悉,刚在项目中看到,所以在网上找了一篇介绍的比较详细的,mark下!!!        socket ...

  4. Mac + IOS + Safari 抓取网络请求

    第一步:打开苹果手机 设置>Safari浏览器>高级>网页检查器 第二步:打开 Mac 上的Safari浏览器>偏好设置>高级>在菜单栏中显示"开发&qu ...

  5. 虚拟dom中key的作用以及用index作为key引发的问题

  6. Selenium Grid入门详解

    一.简介 Selenium是Selenium套件的一部分,它专门用于并行运行多个测试用例在不同的浏览器.操作系统和机器上 Selenium Grid主要使用 master-slaves或者hub-no ...

  7. 快速傅里叶变换FFT学习笔记

    点值表示法 我们正常表示一个多项式的方式,形如 \(A(x)=a_0+a_1x+a_2x^2+...+a_nx^n\),这是正常人容易看懂的,但是,我们还有一种表示法. 我们知道,\(n+1\)个点可 ...

  8. 2015年5月最新win7纯净版系统(32位)补丁最新

    下载地址: http://yunpan.cn/cVN9e679hZ2Pe   访问密码 203a 一.系统安装工具 √ 自由天空最新万能驱动 √ 一键GHOST备份还原系统 √ 硬盘安装系统安装器,增 ...

  9. 2022-12-16:给你一个长度为n的数组,并询问q次 每次询问区间[l,r]之间是否存在小于等于k个数的和大于等于x 每条查询返回true或者false。 1 <= n, q <= 10^5 k

    2022-12-16:给你一个长度为n的数组,并询问q次 每次询问区间[l,r]之间是否存在小于等于k个数的和大于等于x 每条查询返回true或者false. 1 <= n, q <= 1 ...

  10. 2021-03-25:如何把长url转换为短url?

    2021-03-25:如何把长url转换为短url? 福大大 答案2021-03-25: 1.长url和短url一一映射.想采用某种算法,把长url和短url做一一映射.后来发现,这种方法是行不通的. ...