從服務中繼資料產生 WCF 用戶端
本主題說明如何使用 Svcutil.exe 中不同的參數,從中繼資料文件中產生用戶端。
中繼資料文件可以位於永久性儲存裝置上或在線上擷取。線上擷取會遵循 WS-MetadataExchange 通訊協定或 Microsoft Discovery (DISCO) 通訊協定。Svcutil.exe 會同時發出以下中繼資料要求,以擷取中繼資料:
對所提供位址的 WS-MetadataExchange (MEX) 要求。
對附加 /mex 之所提供位址的 MEX 要求。
對所提供位址的 DISCO 要求 (使用 ASP.NET Web 服務中的 DiscoveryClientProtocol (本頁面可能為英文))。
Svcutil.exe 會根據 Web 服務描述語言 (WSDL) 或從服務收到的原則檔產生用戶端。使用者主要名稱 (UPN) 是串連包含 "@" 的使用者名稱,並新增完整網域名稱 (FQDN) 所產生的。但是,對於在 Active Directory 上註冊的使用者而言,這個格式無效,且此工具產生的 UPN 會造成 Kerberos 驗證失敗,並顯示下列錯誤訊息: [登入嘗試失敗]。若要解決這個問題,請手動修復由此工具產生的用戶端檔案。
svcutil.exe [/t:code] <metadataDocumentPath>* | <url>* | <epr>
參照與共用型別
選項 | 描述 |
---|---|
/reference:<file path> |
參考指定組件中的型別。產生用戶端時,使用這個選項即可指定組件,這些組件可能包含代表匯入之中繼資料的類型。 簡短形式:/r |
/excludeType:<type> |
指定要從參考的合約類型排除的完整型別名稱或組件限定型別名稱。 簡短形式:/et |
選擇序列化程式
選項 | 描述 |
---|---|
/serializer:Auto |
自動選取序列化程式。這會使用 DataContract 序列化程式。如果這個作業失敗,則使用 XmlSerializer。 簡短形式:/ser:Auto |
/serializer:DataContractSerializer |
產生使用 DataContract 序列化程式以進行序列化與還原序列化的資料型別。 簡短形式:/ser:DataContractSerializer |
/serializer:XmlSerializer |
產生使用 XmlSerializer 以進行序列化與還原序列化的資料型別。 簡短形式:/ser:XmlSerializer |
/importXmlTypes |
設定 DataContract 序列化程式將非 DataContract 型別匯入為 IXmlSerializable 型別。 簡短形式:/ixt |
/dataContractOnly |
只產生 DataContract 型別的程式碼。會產生 ServiceContract 型別。 這個選項應該只能指定本機中繼資料檔案。 簡短形式:/dconly |
選擇用戶端語言
選項 | 描述 |
---|---|
/language:<language> |
指定要用於產生程式碼的程式語言。請提供在 Machine.config 檔案中註冊的語言名稱,或繼承自 CodeDomProvider 之類別的完整名稱。 值:c#、cs、csharp、vb、vbs、visualbasic、vbscript、javascript、c++、mc、cpp 預設:csharp 簡短形式:/l 如需詳細資訊,請參閱 CodeDomProvider 類別 (本頁面可能為英文)。 |
選擇用戶端命名空間
選項 | 描述 |
---|---|
/namespace:<string,string> |
指定從 WSDL 或 XML 結構描述 targetNamespace 到 Common Language Runtime (CLR) 命名空間的對應。使用萬用字元 (*) 做為 targetNamespace 會對應至所有的 targetNamespaces,而不會明確對應至該 CLR 命名空間。 為了確保訊息合約名稱不會與作業名稱衝突,您應該以雙冒號 (::) 來限定型別參照,或確定名稱為唯一。 預設:衍生自 DataContracts 的結構描述文件之目標命名空間。預設命名空間用於所有其他產生的型別。 簡短形式:/n |
選擇資料繫結
選項 | 描述 |
---|---|
/enableDataBinding |
在所有 DataContract 型別上實作 INotifyPropertyChanged 介面,以啟用資料繫結。 簡短形式:/edb |
產生組態
選項 | 描述 |
---|---|
/config:<configFile> |
針對產生的組態檔指定檔案名稱。 預設:output.config |
/mergeConfig |
將產生的組態合併至現有檔案,而非覆寫現有檔案。 |
/noConfig |
不要產生組態檔。 |