WebService中更新函数传入值,再调用其中函数时,函数的参数还是未改变

背景:
今天写了一个webservice,又修改了一下函数的返回类型、out参数的数量(改为:public void SendData(DataSet ds, out string result,out string errMsg)),之后更新引用,再调用的使用时候发现SendData显示为public string SendData(DataSet ds, out string errMsg)形式,不管是添加webservice还是reference service都不行,解决方案也清理过,iis也重启过,都没解决问题。
结果:
最后把函数改成public bool SendData(DataSet ds, out string result,out string errMsg)就可以了,再调用的时候,就会正确提示。可见void与多个out有一定的“矛盾”啊
==》微软在web引用的时候做了一个转换,把void类型函数的out参数自动转换为非void函数,并把这个参数变成了函数的返回值。
比如:

  1. [WebMethod]  
  2.     public void getPwdNick(int userid,out string pwd,out string nick)  
  3.     {  
  4.     }  
他会在web引用后生成如下代码:

[System.Web.Services.Protocols.SoapDocumentMethodAttribute("http://tempuri.org/getPwdNick", RequestNamespace="http://tempuri.org/", ResponseNamespace="http://tempuri.org/", Use=System.Web.Services.Description.SoapBindingUse.Literal, ParameterStyle=System.Web.Services.Protocols.SoapParameterStyle.Wrapped)]        

 [return: System.Xml.Serialization.XmlElementAttribute("pwd")]         

public string getPwdNick(int userid,out string nick) 

{             

object[] results = this.Invoke("getPwdNick"new object[] {userid});             

nick = ((string)(results[1]));             

return ((string)(results[0]));                   

 } 

这段代码在vs中点击显示所有文件,然后再web refences下面localhost-Reference.map-Reference.cs中。



上一篇:【巡检问题分析与最佳实践】RDS MySQL 实例IO高问题


下一篇:[Google Guava] 6-字符串处理:分割,连接,填充