您好,登錄后才能下訂單哦!
這篇文章主要介紹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, string methodname, 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接口的方法的所有內容,感謝各位的閱讀!希望分享的內容對大家有幫助,更多相關知識,歡迎關注億速云行業資訊頻道!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。