• 来看下,C# WebService WSDL自动生成代码,数组参数的BUG。。。ArrayOfString


    ArrayOfString
    ArrayOfString
    ArrayOfString

    解决C#客户端 ArrayOfString 参数问题。(希望搜索引擎能搜到,帮你解决神奇的ArrayOfString)


    ASP.NET 服务端添加 asmx WebService文件,并添加如下方法。注意只添加这个如下方法:

    参数为字符串数组:

        [WebMethod]
            public string HelloWorld(string[] inputs)
            {
                return "Hello World";
            }
    

    其他项目添加服务器引用这个WebService (其实是wsdl.exe 程序根据 WebService 声明的WDSL文件自动生成代码。)
    生成如下代码

    public string HelloWorld(ConsoleApp2.ServiceReference1.ArrayOfString inputs) 
    

    注意:参数string[] 变为ArrayOfString 对象。。。

    神奇的是,用了这么多年的WebService 都没发现有这问题。。

        [WebMethod]
            public string HelloWorld(string[] inputs)
            {
                return "Hello World";
            }
            
        //添加下边的这个方法后,重新引用,上边的string[] 参数就不会变成ArrayOfString对象。。。
        [WebMethod]
            public DataTable AddTable()
            {
                return null;
            }
    

    对比两个WDSL,只要添加DataTable,WDSL里的声明结构就不一样了。。。

    
                //没有添加Datatable 的WebService会导致声明的string[]参数变为ArrayOfString 对象
                ServiceReference1.WebService1SoapClient client = new ServiceReference1.WebService1SoapClient();
                client.HelloWorld(new ServiceReference1.ArrayOfString());
    
                //添加Datatable声明的WebService就是正常的
                ServiceReference2.WebService2SoapClient client2 = new ServiceReference2.WebService2SoapClient();
                string[] input = new string[0];
                client2.HelloWorld(input);
    

    DEMO:

    https://github.com/zifeiniu/WebserviceArrayOfString.git

  • 相关阅读:
    FATFS 初学之 f_open/ f_close
    前端JQuery(二)
    前端JQuery(一)
    8.22MySQL(五)pymysql模块、sql注入问题
    8.21MySQL(四)基本查询语句及方法、连表、子查询
    8.20MySQL(三)外键
    8.19MySQL(二)
    8.16MySQL(一)
    8.15并发编程(四)
    8.14并发编程(三)
  • 原文地址:https://www.cnblogs.com/zifeiniu/p/12069224.html
Copyright © 2020-2023  润新知