PHP服务器端通过命名管道与C/C++程序通信

本文介绍了一种使用Windows命名管道实现PHP与C/C++程序间通信的方法。通过每次重新挂载命名管道的方式,简化了PHP端的代码,并解决了管道重复使用导致的109错误。同时讨论了时序问题及其实现细节。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

在这几天的工作过程中,需要实现PHP在服务器端能与其他程序通信。和老何俩人研究了半天,终于大致弄出了一个用WINDOWS的命名管道通信的方法。

有几点需要注意的:

PHP服务器端我们每次都是重新挂接命名管道。(这样写,PHP端代码量极其少,而且也很方便。)

那么我们用C/C++写的命名管道服务器则需要每次通信都创建一次管道(方法很恶心,但是暂时能实现,而且对效率要求不是那么高。我们就这么用了。)

如果不是每次都创建管道的话,会出现109错误——这个问题我们调了N久……

还有一个时序问题,在管道SERVER端每次关闭后,需要等PHP端从管道中取完数据,再重新创建管道。(此处我们为图方便,暂时用的sleep。)

下面给出例子:

PHP客户端

function Pipe($msg) { $fp = @fopen("////.//pipe//tongxun", 'w+r+b'); @fwrite($fp,$msg);//写 $result = @fread($fp,256);//读 fclose($fp); }

C++服务器端

while(1) { // 创建管道服务器 char strPipeName[] = "////.//pipe//tongxun"; char szBuf[1024] = {0}; DWORD dwRead ; DWORD userID; char cmd; PSECURITY_DESCRIPTOR psd; psd = (PSECURITY_DESCRIPTOR) LocalAlloc(LPTR, SECURITY_DESCRIPTOR_MIN_LENGTH); if (!InitializeSecurityDescriptor(psd, SECURITY_DESCRIPTOR_REVISION)) { LocalFree((HLOCAL)psd); return -1; } if (!SetSecurityDescriptorDacl(psd, TRUE, (PACL)NULL, FALSE)) { LocalFree((HLOCAL)psd); return -1; } SECURITY_ATTRIBUTES saAttr; saAttr.nLength =sizeof(SECURITY_ATTRIBUTES); saAttr.lpSecurityDescriptor = psd; saAttr.bInheritHandle = TRUE; HANDLE hIPC = CreateNamedPipe(strPipeName, PIPE_ACCESS_DUPLEX | FILE_FLAG_OVERLAPPED, PIPE_TYPE_BYTE | PIPE_READMODE_BYTE | PIPE_WAIT, 1, 0, 0, 1000, &saAttr); if (hIPC == INVALID_HANDLE_VALUE) { return -1; } // 连接管道 ConnectNamedPipe(hIPC, NULL); // 从管道读取信息 if (!ReadFile(hIPC, szBuf, sizeof(szBuf), &dwRead, 0)) { break; } //处理读到的数据szBuf... .... //写数据... //如WriteFile(hIPC, msg, strlen(msg), &dwWrite, NULL) CloseHandle(hIPC); Sleep(100); }

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值