方法一、引用*.wsdl文件
WebService服务端会提供wsdl文件,客户端通过该文件生成.cs文件以及生成.dll
PS:注意若是服务端只提供了URL,那可以通过在URL后面加上“?wsdl”在浏览器上访问,复制页面的代码内容,粘贴到文本文件,将文件后缀改为“wsdl”,即可得到wsdl文件。
通过URL或wsdl文件都可生成.cs文件。
生成.cs文件的方法有以下两种:
1):通过VS命令行工具生成
1.1在打开的命令行工具中输入命令“wsdl/language:c# /n:CHEER.PresentationLayer /out:生成的物理路径(需先创建一个空的cs文件)WebService接口URL
1.2在打开的命令行工具中输入命令“wsdl/language:c# /n:CHEER.PresentationLayer /out:生成的物理路径(需先创建一个空的cs文件)wsdl文件物理路径”
PS:在导入文件时,要注意是否原wsdl文件中有多余语句
2):VS中添加外部工具(方便以后使用)
VS工具菜单->外部工具->如下图
输入上图红框中的各个参数,其中,命令框中输入:C:\Program Files (x86)\Microsoft SDKs\Windows\v10.0A\bin\NETFX 4.8 Tools\wsdl.exe,即wsdl.exe的物理路径。
初始目录:$(ItemDir)表示当前目录下。
命名空间使用时直接改成自定义的名称即可。
下图是该外部工具的使用,先自定义命名空间名称,再在out:后面加上空格,再加上WebService的URL或wsdl文件物理路径。
方法二、已知WebService接口的URL,直接调用
在VS中,添加服务引用–高级–添加web引用,直接输入webservice URL
然后直接实例化该命名空间下的类的对象,调用该接口下的各个方法即可。
方法三、动态调用WebService
先创建帮助类
/// <summary>
/// 动态调用WebService的帮助类
/// </summary>
public class WebServiceHelper
{
#region InvokeWebService
///<summary>
///动态调用web服务
/// </summary>
/// <param name="url">WSDL服务地址</param>
/// <param name="methodname">方法名</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