C++调用外部进程

前段时间遇到一个Qt项目,其中需要调用外部进程文件去解析CAD文件
刚开始使用的Qt的QProcess去调用外部进程,但是在进程启动后waiforFinish直接返回了false程序继续往下执行,造成未等解析完毕就去调用的问题;
后来改用WinExec的方式去解析,存在同样的问题,最后通过<Windows.h> 下的CreateProcess()函数成功解决,故在此记录下
BOOL CreateProcess(
 LPCTSTR lpApplicationName, // 应用程序名称
 LPTSTR lpCommandLine, // 命令行字符串
 LPSECURITY_ATTRIBUTES lpProcessAttributes, // 进程的安全属性
 LPSECURITY_ATTRIBUTES lpThreadAttributes, // 线程的安全属性
 BOOL bInheritHandles, // 是否继承父进程的属性
 DWORD dwCreationFlags, // 创建标志
 LPVOID lpEnvironment, // 指向新的环境块的指针
 LPCTSTR lpCurrentDirectory, // 指向当前目录名的指针
 LPSTARTUPINFO lpStartupInfo, // 传递给新进程的信息
 LPPROCESS_INFORMATION lpProcessInformation // 新进程返回的信息
);

STARTUPINFO si = { sizeof(si) };//0
PROCESS_INFORMATION pi;
_bstr_t bstr(batFile.toStdString().c_str());
LPTSTR szCommandLine = (LPTSTR)bstr;//有权限的都可以打开
BOOL fSuccess = CreateProcess(NULL, szCommandLine, NULL, NULL, FALSE, CREATE_NO_WINDOW, NULL, NULL, &si, &pi);//参数意义
DWORD dwExitCode;
if (fSuccess)//把主进程暂停,等待子进程终止
{

        //暂停主进程的执行,直到child终止,该代码才可以继续运行
        DWORD pro = WaitForSingleObject(pi.hProcess, 5000);
        GetExitCodeProcess(pi.hProcess, &dwExitCode);
        CloseHandle(pi.hProcess);
        CloseHandle(pi.hThread);
    }

其中szCommandLine 为传入的命令 如果传入的为字符串格式,需要进行转化,转化为LPTSTR类型

C++:string转换LPTSTR,const char*

#include
#include <comdef.h>
#include

using namespace std;
int main(int argc, char* argv[])
{
string cCommandline=“hello world!”;

//string转换LPTSTR
_bstr_t bstr(cCommandline.c_str());
LPTSTR lr=(LPTSTR)bstr;

//string转换const char*
const char *p1 = cCommandline.c_str();
const char *p2 = cCommandline.data();
printf("%s %s\n",p1,p2);
cout <<p1 << " "  << p2 << endl;

}

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
//官方网站:www.feiyuol.com //郁金香灬老师 //QQ 150330575 //个人网站:www.yjxsoft.com 进程调用CALL 进程调用带多个的参数CALL // myInject_dll.cpp : 定义控制台应用程序的入口点。 // #include "stdafx.h" #include #include"RWA.h" //PVOID 进程分配内存(WORD nSize ); //1、获取进程句柄 //2、读写 分配内存 创建线程 //3、进程分配内存 void mycall() { PVOID p1=进程分配内存(1000); printf("分配的内存地址=%p\n",p1); printf("按回车键 释放内存\n"); getchar(); 进程释放内存(p1,1000); printf("已经 释放内存\n"); } LPTHREAD_START_ROUTINE a; BOOL 进程调用CALL(PVOID pcall地址,PVOID plst参数 ); //LoadLibraryA(dll名字指针) //MessageBeep(1) void Test远程调用MessageBeep() { 进程调用CALL(MessageBeep,(PVOID)0x12768); } //注入my022MFC.dll到目标进程 void Test3() { char szDllName[]="my022MFC.dll"; //全路径 // char szDllName[]="C:\\Users\\yjxsoft\\Documents\\visual studio 2010\\Projects\\my022\\Debug\\my022MFC.dll"; PVOID p1=进程分配内存(1000); printf("分配的内存地址=%p\n",p1); WN((DWORD)p1,szDllName,sizeof(szDllName));//WriteProcessMemory /*进程调用CALL(LoadLibraryA,(PVOID)szDllName);*/ 进程调用CALL(LoadLibraryA,(PVOID)p1); } void Test4() { // char szDllName[]="my022MFC.dll"; //全路径 char szDllName[]="E:\\1905\\代码\\my022-24\\Debug\\my022MFC.dll"; PVOID p1=进程分配内存(1000); printf("分配的内存地址=%p\n",p1); WN((DWORD)p1,szDllName,sizeof(szDllName));//WriteProcessMemory /*进程调用CALL(LoadLibraryA,(PVOID)szDllName);*/ 进程调用CALL(LoadLibraryA,(PVOID)p1); } int _tmain(int argc, _TCHAR* argv[]) { //mycall(); Test3(); Test4(); return 0; } //作业 //1、练习进程注入DLL //2、进程分配的内存内存 使用完后 用VirtualFreeEx释放掉 //3、进程句柄使用完后用CloseHandle释放句柄资源
可以使用C++中的一些网络编程库来实现监听外部接口的事件。这里介绍一种基于socket的方法。 首先,你需要创建一个socket并绑定到要监听的接口上。可以使用`socket()`函数创建socket,并使用`bind()`函数将其绑定到指定的端口上。 ```c++ #include <iostream> #include <sys/socket.h> #include <netinet/in.h> #include <unistd.h> int main() { int server_fd, new_socket; struct sockaddr_in address; int opt = 1; int addrlen = sizeof(address); // 创建socket if ((server_fd = socket(AF_INET, SOCK_STREAM, 0)) == 0) { perror("socket failed"); exit(EXIT_FAILURE); } // 设置socket选项 if (setsockopt(server_fd, SOL_SOCKET, SO_REUSEADDR | SO_REUSEPORT, &opt, sizeof(opt))) { perror("setsockopt failed"); exit(EXIT_FAILURE); } // 绑定到指定端口 address.sin_family = AF_INET; address.sin_addr.s_addr = INADDR_ANY; address.sin_port = htons(8080); if (bind(server_fd, (struct sockaddr *)&address, sizeof(address))<0) { perror("bind failed"); exit(EXIT_FAILURE); } // 监听socket if (listen(server_fd, 3) < 0) { perror("listen failed"); exit(EXIT_FAILURE); } // 等待连接 if ((new_socket = accept(server_fd, (struct sockaddr *)&address, (socklen_t*)&addrlen))<0) { perror("accept failed"); exit(EXIT_FAILURE); } // 处理连接 char buffer[1024] = {0}; int valread = read(new_socket, buffer, 1024); std::cout << "Received: " << buffer << std::endl; return 0; } ``` 上述代码中,我们创建了一个socket并绑定到8080端口。然后我们使用`listen()`函数来等待连接。一旦有连接进来,我们就接收数据并进行处理。 需要注意的是,在实际的应用中,你需要考虑如何处理多个连接和并发请求等问题。可以使用多线程、多进程或异步编程等方式来解决这些问题。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值