RPC_HTTP_TRANSPORT_CREDENTIALS_A 結構 (rpcdce.h)
RPC_HTTP_TRANSPORT_CREDENTIALS 結構會定義使用 RPC/HTTP 時要向 RPC Proxy 伺服器進行驗證的其他認證。
語法
typedef struct _RPC_HTTP_TRANSPORT_CREDENTIALS_A {
SEC_WINNT_AUTH_IDENTITY_A *TransportCredentials;
unsigned long Flags;
unsigned long AuthenticationTarget;
unsigned long NumberOfAuthnSchemes;
unsigned long *AuthnSchemes;
unsigned char *ServerCertificateSubject;
} RPC_HTTP_TRANSPORT_CREDENTIALS_A, *PRPC_HTTP_TRANSPORT_CREDENTIALS_A;
成員
TransportCredentials
包含用戶使用者名稱、網域和密碼 之SEC_WINNT_AUTH_IDENTITY 結構的指標。
Flags
可以與位 OR 運算子結合的一組旗標。
AuthenticationTarget
指定驗證目標。
應設定為下列其中一個或兩個值:
值 | 意義 |
---|---|
|
根據 RPC Proxy 進行驗證,這是從 HTTP 觀點來看的 HTTP 伺服器。 這是最常見的值。 |
|
對 HTTP Proxy 進行驗證。 這個值並不常見。 |
NumberOfAuthnSchemes
AuthnScheme 陣列中的元素數目。
AuthnSchemes
ServerCertificateSubject
包含具有預期伺服器主體名稱的選擇性字串。 主體名稱的格式與針對 RpcCertGeneratePrincipalName 產生的格式相同, (如需詳細資訊,請參閱 主體名稱 以取得) 。 只有在使用 SSL 時,才會使用此成員。 在這種情況下,系統會根據產生的主體名稱檢查伺服器證書。 如果不符合,則會傳回錯誤。 此成員可讓客戶端驗證 RPC Proxy。
備註
如果 TransportCredentials 成員為 NULL ,且驗證配置為 NTLM,則會使用目前登入用戶的認證。 若要避免透過弱式 LM 哈希在網路上公開用戶認證,只有在下列其中一個或兩個條件都成立時,才會使用使用者登入認證:
- 呼叫端要求使用 SSL,並使用 ServerCertificateSubject 成員。 此案例保證認證在傳輸和最終目的地受到保護,即使使用弱式哈希也一樣。
- lncompatibilitylevel 機碼會設定為 2 或更新版本。 這會導致 NTLM 安全性提供者只發出或響應強式 NT 哈希,而不是弱式 LM 哈希。 此外,建議客戶使用層級 3 或更高版本,這會嘗試NTLMv2。
規格需求
需求 | 值 |
---|---|
最低支援的用戶端 | 具有 SP1 的 Windows XP [僅限傳統型應用程式] |
最低支援的伺服器 | Windows Server 2003 [僅限傳統型應用程式] |
標頭 | rpcdce.h (包含 Rpc.h) |
另請參閱
RPC_HTTP_TRANSPORT_CREDENTIALS_V2