3

我有一个主要基于以下内容编写的 Namedpipeserver:http:
//msdn.microsoft.com/en-us/library/windows/desktop/aa365588
(v=vs.85).aspx 当我尝试从.NET 连接到它时使用此代码的客户端:

NamedPipeClientStream clientPipe = new NamedPipeClientStream(".",      
    "\\\\.\\pipe\\TTCUIHELPER_SEND_TTC_RECEIVE",PipeDirection.Out);
try
{        

    if (clientPipe != null)
    {
        clientPipe.Connect(5000);
        if (clientPipe.IsConnected == true)
        {
            byte[] bytes = pm.GetMessageData();
            clientPipe.Write(bytes, 0, bytes.Length);
            clientPipe.Flush(); 
            clientPipe.Dispose();
            clientPipe.Close();
        }
    }
}
catch (Exception Ex)
{
    System.Windows.MessageBox.Show(Ex.Message);
}

然后连接总是超时。奇怪的是,如果我尝试使用 CPP 编写测试客户端,如下所示:

LPTSTR lpszPipename = TEXT("\\\\.\\pipe\\TTCUIHELPER_SEND_TTC_RECEIVE");
const TCHAR* lpvMessage=L"QQQQ";

HANDLE hPipe = CreateFile( 
    lpszPipename,   // pipe name 
    GENERIC_READ |  // read and write access 
    GENERIC_WRITE, 
    0,              // no sharing 
    NULL,           // default security attributes
    OPEN_EXISTING,  // opens existing pipe 
    0,              // default attributes 
    NULL);          // no template file 

// Break if the pipe handle is valid. 

DWORD cbWritten;
DWORD cbToWrite = (lstrlen(lpvMessage)+1)*sizeof(TCHAR);
_tprintf( TEXT("Sending %d byte message: \"%s\"\n"), cbToWrite, lpvMessage); 

BOOL fSuccess = WriteFile( 
    hPipe,                  // pipe handle 
    lpvMessage,             // message 
    cbToWrite,              // message length 
    &cbWritten,             // bytes written 
    NULL);                  // not overlapped 

if ( ! fSuccess) 
{
    _tprintf( TEXT("WriteFile to pipe failed. GLE=%d\n"), GetLastError() ); 
    return -1;
}

然后完美无缺。如果它适用于 CPP 而不是 .NET,我会做错什么?

4

1 回答 1

2

只需从管道名称中丢失管道前缀,即仅使用名称本身:

"TTCUIHELPER_SEND_TTC_RECEIVE"

.NETNamedPipeClientStream类在内部调用 Windows WriteFile API 时会为您添加前缀。

于 2012-10-08T09:33:33.193 回答