c# 三種方法呼叫WebService介面
1、引用*.wsdl檔案
WebService服務端會提供wsdl檔案,客戶端通過該檔案生成.cs檔案以及生成.dll.
注意:若服務端只提供的了URL,在URL後面加上"?wsdl"在瀏覽器上訪問,複製頁面內容,貼上到文字檔案,將檔案字尾改為為"wsdl",即可得到wsdl檔案。
通過URL或wsdl檔案都可生成.cs檔案。
生成.cs檔案的方法有兩種,如下:
方法一:通過VS命令列工具生成
如上圖所示,輸入命令“wsdl /language:c# /n:CHEER.PresentationLayer /out:生成類的物理路徑(需先建立cs檔案) WebService介面URL或wsdl檔案物理路徑”即可。
方法二:VS中新增外部工具(方便以後使用)
VS工具選單->外部工具->如下圖
輸入上圖紅框中的各個引數,其中,命令是:C:\Program Files (x86)\Microsoft SDKs\Windows\v10.0A\bin\NETFX 4.6.1 Tools\wsdl.exe,即wsdl.exe的物理路徑。
初始目錄:$(ItemDir)表示當前專案根目錄下。
名稱空間使用時直接改成自定義的名稱即可。
下圖是該外部工具的使用,先自定義名稱空間名稱,再在out:後面加上空格,再加上WebService的URL或wsdl檔案物理路徑
2、已知WebService介面的URL,直接呼叫
在VS中,新增服務引用--高階--新增web引用 直接輸入webservice URL
然後,直接例項化該名稱空間下的類的物件,呼叫該介面下的各個方法即可。
3、動態呼叫WebService
先建立幫助類
/// <summary> /// 動態呼叫WebService的幫助類 /// </summary> public class WebServiceHelper { #region InvokeWebService /// < summary> /// 動態呼叫web服務 ///< /summary> /// < param name="url">WSDL服務地址< /param> /// < param name="methodname">方法名< /param> /// < param name="args">引數< /param> /// < returns>< /returns> public object InvokeWebService(string url,string methodname,object[] args) { return this.InvokeWebService(url,null,methodname,args); } /// < summary> /// 動態呼叫web服務 /// < /summary> /// < param name="url">WSDL服務地址< /param> /// < param name="classname">類名< /param> /// < param name="methodname">方法名< /param> /// < param name="args">引數< /param> /// < returns>< /returns> public object InvokeWebService(string url,string classname,object[] args) { string @namespace = "EnterpriseServerBase.WebService.DynamicWebCalling"; if ((classname == null) || (classname == "")) { classname = WebServiceHelper.GetWsClassName(url); } try { //獲取WSDL WebClient wc = new WebClient(); if (!url.ToUpper().Contains("WSDL")) { url = string.Format("{0}?{1}",url,"WSDL"); } Stream stream = wc.OpenRead(url); ServiceDescription sd = ServiceDescription.Read(stream); ServiceDescriptionImporter sdi = new ServiceDescriptionImporter(); sdi.AddServiceDescription(sd,"",""); CodeNamespace cn = new CodeNamespace(@namespace); //生成客戶端代理類程式碼 CodeCompileUnit ccu = new CodeCompileUnit(); ccu.Namespaces.Add(cn); sdi.Import(cn,ccu); CSharpCodeProvider icc = new CSharpCodeProvider(); //設定編譯引數 CompilerParameters cplist = new CompilerParameters(); cplist.GenerateExecutable = false; cplist.GenerateInMemory = true; cplist.ReferencedAssemblies.Add("System.dll"); cplist.ReferencedAssemblies.Add("System.XML.dll"); cplist.ReferencedAssemblies.Add("System.Web.Services.dll"); cplist.ReferencedAssemblies.Add("System.Data.dll"); //編譯代理類 CompilerResults cr = icc.CompileAssemblyFromDom(cplist,ccu); if (true == cr.Errors.HasErrors) { StringBuilder sb = new StringBuilder(); foreach (CompilerError ce in cr.Errors) { sb.Append(ce.ToString()); sb.Append(Environment.NewLine); } throw new Exception(sb.ToString()); } //生成代理例項,並呼叫方法 System.Reflection.Assembly assembly = cr.CompiledAssembly; Type t = assembly.GetType(@namespace + "." + classname,true,true); object obj = Activator.CreateInstance(t); System.Reflection.MethodInfo mi = t.GetMethod(methodname); return mi.Invoke(obj,args); } catch (Exception ex) { throw new Exception(ex.InnerException.Message,new Exception(ex.InnerException.StackTrace)); } } private static string GetWsClassName(string wsUrl) { string[] parts = wsUrl.Split('/'); string[] pps = parts[parts.Length - 1].Split('.'); if (pps[0].Contains("?")) { return pps[0].Split('?')[0]; } return pps[0]; } #endregion } WebServiceHelper WebServiceHelper
然後呼叫,如下
WebServiceHelper webService = new WebServiceHelper(); object obj= webService.InvokeWebService("http://127.0.0.1:8001/WebService1.asmx","Add",new object[] {22,33 }); DataTable dt = obj as DataTable;
注意:該方法比價麻煩,每次呼叫InvokeWebService都是在記憶體中建立動態程式集,效率極低
以上就是c# 三種方法呼叫WebService介面的詳細內容,更多關於c# 呼叫WebService介面的資料請關注我們其它相關文章!