2017-02-16 44 views
0

我想从web服务返回列表类型。我使用了一个与here类似的版本。Asp.net Webservice不工作,而返回列表<object>

我收到以下错误

System.InvalidOperationException:有一个错误生成XML文档。 ---> System.InvalidOperationException:类型 System.Collections.Generic.List`1 [[System.String,mscorlib, Version = 4.0.0.0,Culture = neutral,PublicKeyToken = b77a5c561934e089]] 不得用于这个背景。

代码:

[WebMethod] 
    public List<object> getnpsTrend(string region, string client, string product) 
    { 
     List<object> iData = new List<object>(); 
     List<string> labels = new List<string>(); 

     labels.Add ("test1"); 
     iData.Add(labels); 
     return iData; 
    } 

感谢您的帮助提前!

更新: 后挣扎的时间,我发现,当我的列表对象包含另一个复杂对象(如数组/另一个列表)它不只是工作。否则它有效。以下代码可以得到完美的结果。

[WebMethod] 
    public List<Object> getnpsTrend() 
    { 
     List<Object> li = new List<object>(); 
     string obj = "Test"; 
     li.Add(obj); 
     return li ; 
    } 

但是我需要一个包含list的列表作为返回类型。有什么办法可以创建一个具有所需结构的用户定义类型,它可以通过xml序列化?

回答

0

我能够在更多搜索后找到解决方案。我想,当我们使用更复杂的返回类型时,我们将不得不使用类定义结构。只有当asp能够映射它时,它才会显示不相关的错误消息:)。幸好另一个人有一个similar question

请找到的情况下,下面的代码,你正在寻找的答案:

[WebMethod]   
    public List<ChartDatasets> getnpsTrend(string region, string client, string product) 
    { 
     List<ChartDatasets> chart1 = new List<ChartDatasets>(); 
     List<string> lblnames = new List<string>(); 

     DataTable dt = biz.FetchData_RCP("", region, client, product); 
     dt.TableName = "data"; 
     foreach (DataRow drow in dt.Rows) 
     { 
      lblnames.Add(drow["Timeline"].ToString());     
     } 


     Labels lbl1 = new Labels(); 
     lbl1.LabelNames = lblnames; 


     List<Decimal> lst_dataItem_1 = new List<Decimal>(); 
     foreach (DataRow dr in dt.Rows) 
     { 
      lst_dataItem_1.Add(Convert.ToDecimal(dr["NPSScore"].ToString())); 
     } 
     dataset_deci ds1_class = new dataset_deci(); 
     ds1_class.Value = lst_dataItem_1; 

     List<Decimal> lst_dataItem_2 = new List<Decimal>(); 
     foreach (DataRow dr in dt.Rows) 
     { 
      lst_dataItem_2.Add(Convert.ToDecimal(dr["Promoter_Count"].ToString())); 
     } 
     dataset_deci ds2_class = new dataset_deci(); 
     ds2_class.Value = lst_dataItem_2; 


     chart1.Add(new ChartDatasets { Lbls = new List<Labels> { lbl1 }, ds1 = new List<dataset_deci> { ds1_class }, ds2 = new List<dataset_deci> { ds2_class } }); 
     return chart1; 
    } 

    public class ChartDatasets 
    { 
     public List<Labels> Lbls; 
     public List<dataset_deci> ds1; 
     public List<dataset_deci> ds2; 
    } 

    public class Labels 
    { 
     public List<string> LabelNames; 
    } 

    public class dataset_deci 
    { 
     public List<Decimal> Value; 
    }