這部分基本和上一節一樣,不過上一節中 RPC 是通過 Named Pipe 調用的,這里我們再試一下 TCP 的方式。
代碼大部分都是相同的, IDL 接口不用變(無論是通過什么方式 RPC,接口都是與之無關的)。
服務端要換成 TCP 的方式:
---------------------------------
int main(int argc,char * argv[])
{
// 用TCP 方式作為RPC 的通道。綁定端口13521。
RpcServerUseProtseqEp(
(unsigned char *)"ncacn_ip_tcp",
RPC_C_PROTSEQ_MAX_REQS_DEFAULT,
(unsigned char *)"13521",
NULL);
// 注意:從Windows XP SP2 開始,增強了安全性的要求,如果用 RpcServerRegisterIf() 注冊
// 接口,客戶端調用時會出現 RpcExceptionCode() == 5,即Access Denied 的錯誤. 因此,必
// 須用 RpcServerRegisterIfEx 帶 RPC_IF_ALLOW_CALLBACKS_WITH_NO_AUTH 標志允許客戶端直
// 接調用。
// RpcServerRegisterIf(HelloWorld_v1_0_s_ifspec, NULL, NULL);
RpcServerRegisterIfEx(
HelloWorld_v1_0_s_ifspec, // Interface to register.
NULL,
NULL, // Use the MIDL generated entry-point vector.
RPC_IF_ALLOW_CALLBACKS_WITH_NO_AUTH,
0,
NULL);
// 后面都相同
...
return 0;
}
客戶端的調用方式也要換:
---------------------------------
int main(int argc, char * argv[])
{
// 前面都相同
...
// 用 TCP 方式作為 RPC 的通道。服務器端口 13521。第3個
// 參數 NetworkAddr 如果取 NULL,那么就是連接本機服務,
// 也可以取IP, 域名, servername 等
RpcStringBindingCompose(
NULL,
(unsigned char*)"ncacn_ip_tcp",
(unsigned char*)"localhost" /*NULL*/,
(unsigned char*)"13521",
NULL,
&pszStringBinding
);
// 后面都相同
...
}
別的地方都是一樣的。
示例下載