WIN32创建进程CreateProcess

Posted ganxiang

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了WIN32创建进程CreateProcess相关的知识,希望对你有一定的参考价值。

BOOL CreateProcess(

LPCTSTR 【lpApplicationName】,    //指向可执行模块名称的指针
LPTSTR 【lpCommandLine】,    //指向命令行字符串的指针
LPSECURITY_ATTRIBUTES 【lpProcessAttributes】,    //指向进程安全属性的指针
LPSECURITY_ATTRIBUTES 【lpThreadAttributes】,    //指向线程安全属性的指针
BOOL 【bInheritHandles】,    //处理继承标志
DWORD 【dwCreationFlags】,    //创建标志
LPVOID 【// pointer to new environment block】,    //指向新的环境块
LPCTSTR 【lpCurrentDirectory】,    //指向当前目录名称的指针
LPSTARTUPINFO 【lpStartupInfo】,    //指向STARTUPINFO的指针
LPPROCESS_INFORMATION 【lpProcessInformation】    //指向PROCESS_INFORMATION的指针
);

 

// Process0617.cpp : Defines the entry point for the console application.
//

#include "stdafx.h"
#include <windows.h>

void Getsi()
{
    STARTUPINFO si;
    GetStartupInfo(&si);
    printf("%x %x %x %x %x %x %x %x ",si.dwX,si.dwY,si.dwXCountChars,si.dwYCountChars,si.dwFillAttribute,si.dwXSize,si.dwYSize,si.dwFlags);
}

BOOL CreateProcessFun(PTCHAR szAppName,PTCHAR szCmdLine)
{
    STARTUPINFO si;
    PROCESS_INFORMATION pi;

    ZeroMemory(&si,sizeof(si));
    ZeroMemory(&pi,sizeof(pi));
    //si->cb = sizeof(si);
    si.cb = sizeof(si);


    if (!CreateProcess(szAppName,szCmdLine,NULL,NULL,FALSE,0,NULL,NULL,&si,&pi))
    {
        printf("创建进程失败
");
        return FALSE;
    }
    else
    {
        printf("创建进程成功,进程句柄:%d--进程ID:%d--线程句柄:%d--线程ID:%d
",pi.hProcess,pi.dwProcessId,pi.hThread,pi.dwThreadId);
        return TRUE;
    }
    return TRUE;
    
}

int main(int argc, char* argv[])
{
    TCHAR stcAppName[] = TEXT("C://Program Files//Internet Explorer//iexplore.exe");
    TCHAR stcCmdLine[] = TEXT(" https://www.qq.com/");
    CreateProcessFun(stcAppName,stcCmdLine);
    
    getchar();
    return 0;
}

 

以上是关于WIN32创建进程CreateProcess的主要内容,如果未能解决你的问题,请参考以下文章

动态加载并执行Win32可执行程序

创建进程API

创建进程API

反调试手法之CreateProcess反调试

win32进程概念之句柄表,以及内核对象.

零基础逆向工程39_Win32_13_进程创建_句柄表_挂起方式创建进程