如何捕捉子进程的输出

上篇文章讲到了如何在Windows服务当中以普通用户启动一个子进程,启动了以后需要跟子进程进行通讯,子进程在获取了一些有用的信息以后需要传递给父进程,Windows进程间通信的方式有很多,但是最适合父子进程之间通信的应该是输入输出重定向的方式,即匿名管道的方式。

在参考了MSDN上的例程以及其他网络上的资料以后,使用如下代码完成父子进程间的通信:

HANDLE hRead = NULL;
	HANDLE hWrite = NULL;
	char szBuffer[1024]={0};
	DWORD dwRead = 0;

	SECURITY_ATTRIBUTES sa;
	sa.nLength = sizeof(SECURITY_ATTRIBUTES);
	sa.lpSecurityDescriptor = NULL;
	// 新创建的进程继承管道读写句柄
	sa.bInheritHandle = TRUE;
	if ( !CreatePipe( &hRead, &hWrite, &sa, 0 ) )  {
	    return ;
	}
	 
	if ( NULL == hRead || NULL == hWrite ) {
	    return;
	}

	char cstrNewDosCmd[] = "childprocess.exe";
	STARTUPINFO si;
	si.cb = sizeof(STARTUPINFO);
	GetStartupInfo(&si);
	si.hStdError = hWrite;            // 把创建进程的标准错误输出重定向到管道输入
	si.hStdOutput = hWrite;           // 把创建进程的标准输出重定向到管道输入
	si.wShowWindow = SW_HIDE;

	si.dwFlags = STARTF_USESHOWWINDOW | STARTF_USESTDHANDLES;
	 
	PROCESS_INFORMATION pi;
	// 启动进程
	DWORD dwCreationFlag = NORMAL_PRIORITY_CLASS|CREATE_UNICODE_ENVIRONMENT|CREATE_NO_WINDOW;
	BOOL bSuc = CreateProcess(NULL, cstrNewDosCmd, NULL, NULL, TRUE, dwCreationFlag, NULL, NULL, &si, &pi);

	//在读取管道内容前,关闭写管道
	if ( NULL != hWrite ) 
	{
	    CloseHandle(hWrite);
	    hWrite = NULL;
	}

	char szFullPath[MAX_PATH]={0};
	//读取管道内的所有内容
	 while(ReadFile( hRead, szBuffer, 1024, &dwRead, NULL ))
	 {
		strcat(szFullPath, szBuffer);
		memset(szBuffer, 0, 1024);
	 }
	 //输出内容
	 cout<<szFullPath<<endl;

	 CloseHandle(hRead);


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值