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接口的详细内容,更多关于c# 调用WebService接口的资料请关注脚本之家其它相关文章!