我创建了以下界面
[ServiceContract]
public interface IPlusFive
{
[OperationContract]
int PlusFive(int value);
}
和以下服务器
class Program
{
static void Main(string[] args)
{
using (ServiceHost host = new ServiceHost(typeof(PlusFiver),
new Uri[] { new Uri("net.pipe://localhost") }))
{
host.AddServiceEndpoint(typeof(IPlusFive), new NetNamedPipeBinding(), "PipePlusFive");
host.Open();
Console.WriteLine("Service is Available. Press enter to exit.");
Console.ReadLine();
host.Close();
}
}
}
然后,我创建了一个C#客户端来对其进行测试,效果很好。
根据this博客文章,我需要读取一个内存映射文件来获取管道的名称。
所以我写了下面的名字
#include "stdafx.h"
#include "windows.h"
#include <iostream>
using namespace std;
int _tmain(int argc, _TCHAR* argv[])
{
char pipeName[] = "EbmV0LnBpcGU6Ly8rL1BJUEVQTFVTRklWRS8=";
wcout << "Opening file map.."<< endl;
std::wstring mapFile;
mapFile.append(L"net.pipe:E");
mapFile.append(L"bmV0LnBpcGU6Ly8rLw==");
HANDLE fileMap = OpenFileMapping(FILE_MAP_READ, FALSE, mapFile.c_str());
if(fileMap == NULL)
{
wcout << "Failed to connect to pipe" << endl;
system("pause");
return 1;
}
wcout << "map opened."<< endl;
wcout << "reading file map" << endl;
LPCTSTR pBuf = (LPTSTR)MapViewOfFile(fileMap,
FILE_MAP_READ,
0,
0,
0);
if(pBuf == NULL)
{
wcout << "failed to read file map" << endl;
CloseHandle(fileMap);
system("pause");
return 1;
}
wcout << "File map read successfully" << endl;
wcout << "pipe name: " << pBuf << endl;
MessageBox(NULL, pBuf, TEXT("test"),MB_OK);
system("pause");
UnmapViewOfFile(pBuf);
CloseHandle(fileMap);
return 0;
}
它给出以下输出
Opening file map..
map opened.
reading file map
File map read successfully
pipe name: ☺
Press any key to continue . . .
似乎内存映射文件在那里,但看起来不像它包含管道的名称。我是C++的新手,所以我不知道自己做错了什么还是尝试做错了。我读取文件不正确吗?
最佳答案
您引用的博客文章的引文:
您希望文件是一个包含字符串的文本文件。
实际上,该文件是二进制文件,其中包含GUID structure。
关于c# - 如何使用非托管C++获取WCF命名管道的名称?,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/11759286/