共用方式為


RpcServerUseProtseqEpExA 函式 (rpcdce.h)

RpcServerUseProtseqEpEx函式會告訴 RPC 執行時間程式庫使用指定的通訊協定序列,結合指定的端點來接收遠端程序呼叫。

語法

RPC_STATUS RpcServerUseProtseqEpExA(
  RPC_CSTR     Protseq,
  unsigned int MaxCalls,
  RPC_CSTR     Endpoint,
  void         *SecurityDescriptor,
  PRPC_POLICY  Policy
);

參數

Protseq

要向 RPC 執行時間程式庫註冊的通訊協定序列字串識別碼指標。

MaxCalls

ncacn_ip_tcp通訊協定序列的待辦專案佇列長度。 所有其他通訊協定序列都會忽略此參數。 使用 RPC_C_PROTSEQ_MAX_REQS_DEFAULT 來指定預設值。 請參閱<備註>。

Endpoint

要用於建立 Protseq所指定通訊協定序列之系結的端點位址資訊指標。

SecurityDescriptor

為安全性子系統提供的選擇性參數指標。 僅用於 ncacn_npncalrpc 通訊協定序列。 所有其他通訊協定序列都會忽略此參數。 不建議在端點上使用安全性描述元,以確保伺服器安全。 此參數不會出現在此 API 的 DCE 規格中。

Policy

RPC_POLICY結構的指標,其中包含設定傳輸特定屬性的旗標。 在 ncadg_mq 傳輸的情況下,這些旗標會指定伺服器進程接收佇列的屬性。 在 ncacn_ip_tcpncadg_ip_udp 傳輸的情況下,這些旗標會限制動態埠的埠配置,並允許多路電腦選擇性地系結至網路介面卡。

只有在使用ncacn_ip_tcpncadg_ip_udpncadg_mq通訊協定序列時,[原則] 欄位中的旗標設定才有效。 針對所有其他通訊協定序列,RPC 執行時間會忽略這些值。

注意 呼叫 RpcServerUseProtseqEpEx 函式時,會忽略與動態端點相關聯的原則部分,因為埠是在端點本身中指定。
 

傳回值

意義
RPC_S_OK
呼叫成功。
RPC_S_PROTSEQ_NOT_SUPPORTED
此主機不支援通訊協定順序。
RPC_S_INVALID_RPC_PROTSEQ
通訊協定順序無效。
RPC_S_INVALID_ENDPOINT_FORMAT
端點格式無效。
RPC_S_OUT_OF_MEMORY
系統記憶體不足。
RPC_S_DUPLICATE_ENDPOINT
端點是重複的。
RPC_S_INVALID_SECURITY_DESC
安全性描述元無效。
 
注意 如需有效錯誤碼的清單,請參閱 RPC 傳回值
 

備註

RpcServerUseProtseqEpEx的參數和效果會減去RpcServerUseProtseqEp的參數和效果。 差異在於 Policy 參數,可讓您在端點上設定特定原則。 將RPC_POLICY結構的NICFlags欄位設定為零,可讓這個擴充函式相當於搭配ncacn_ip_tcpncadg_ip_udp傳輸時的原始RpcServerUseProtseqEp

伺服器應用程式會呼叫 RpcServerUseProtseqEpEx ,以向 RPC 執行時間程式庫註冊一個通訊協定序列。 透過每個通訊協定順序註冊, RpcServerUseProtseqEpEx 包含指定的端點位址資訊。

若要接收遠端程序呼叫要求,伺服器必須向 RPC 執行時間程式庫註冊至少一個通訊協定序列。 伺服器應用程式可以多次呼叫此常式,以註冊額外的通訊協定序列和端點。 針對伺服器註冊的每個通訊協定序列,RPC 執行時間程式庫會建立一或多個端點,讓伺服器接收遠端程序呼叫要求。 RPC 執行時間程式庫會為每個通訊協定序列建立不同的端點。 不過,進程中的每個介面都可以透過任何端點存取。 如需詳細資訊,請參閱撰寫安全的 RPC 用戶端或伺服器。

針對 MaxCalls,應用程式所提供的值只是提示。 RPC 執行時間或 Windows Sockets 提供者可能會覆寫值。 例如,在 Windows XP 或 Windows 2000 Professional 上,此值限制為 5。 忽略大於 5 的值,並改用 5。 在 Windows Server 2003 和 Windows 2000 Server 上,將會接受此值。

應用程式必須小心,才能在 MaxCalls中傳遞合理的值。 伺服器、進階伺服器或 Datacenter Server 上的大值可能會導致使用大量的非分頁集區記憶體。 使用太小的值也不適合使用,因為如果待辦專案佇列耗盡,可能會導致 TCP RST 從伺服器符合 TCP SYN 封包。 應用程式開發人員在判斷 MaxCalls的適當值時,應該平衡記憶體使用量與延展性需求。

當電腦設定為使用選擇性系結時,成功傳回不保證伺服器已為電腦上存在的所有網路介面建立端點。 RPC 執行時間可能不會接聽某些網路介面,視選擇性系結設定而定。 此外,如果介面尚未使用 DHCP 接收 IP 位址,RPC 伺服器就不會在網路介面上接聽,直到將 DHCP 位址指派給它為止。 成功傳回表示伺服器正在至少接聽一個網路介面;可以透過對 RpcServerInqBindings 函式的呼叫來取得遠端程序呼叫的完整系結控制碼清單。

如需詳細資訊,請參閱 伺服器端系結、 字串系結、 設定埠配置和選擇性系結的登錄,以及 RPC 訊息佇列 和 MIDL 參考頁面 訊息ncadg_mq

注意

rpcdce.h 標頭會根據 UNICODE 預處理器常數的定義,將 RpcServerUseProtseqEpEx 定義為自動選取此函式的 ANSI 或 Unicode 版本。 混合使用編碼中性別名與非編碼中性的程式碼,可能會導致編譯或執行時間錯誤不符。 如需詳細資訊,請參閱 函式原型的慣例

需求

   
最低支援的用戶端 Windows 2000 專業版 [僅限傳統型應用程式]
最低支援的伺服器 Windows 2000 Server [僅限傳統型應用程式]
目標平台 Windows
標頭 rpcdce.h (包含 Rpc.h)
程式庫 Rpcrt4.lib
Dll Rpcrt4.dll

另請參閱

RPC_POLICY

RpcServerUseAllProtseqsEx

RpcServerUseAllProtseqsIfEx

RpcServerUseProtseqEx

RpcServerUseProtseqIfEx

撰寫安全的 RPC 用戶端或伺服器