我有一个SOAP Web服务,我从中提取各种信息。大多数函数都正常工作,但我需要一些函数来返回List
。
WebMethod
的定义如下:
List<MyType> myTypes = new List<MyTypes>();
[WebMethod]
public List<MyType> GetAllMyTypes()
{
string sql = "SELECT * FROM MyType";
DataTable dt = new DataTable();
dt = Globals.GLS_DataQuery(sql);
List<MyType> myType = new List<MyType>();
foreach (DataRow row in dt.Rows)
{
MyType myType = new MyType()
{
ID = (int)row["Id"]
};
myTypes.Add(myType);
}
return myTypes;
}
Web服务在主项目中引用,并由以下方式调用:
client.GetAllMyTypesCompleted += client_GetAllMyTypesCompleted;
client.GetAllMyTypesAsync();
client_GetAllMyTypesCompleted
定义为:
private void client_GetAllMyTypesCompleted(object sender, GetAllMyTypesCompletedEventArgs e)
{
var collection = e.Result;
}
这里引发TargetInvocationException
,特别是关于Result
。如果您自己运行Web服务,则返回正确的数据。供参考GLS_DataQuery
定义为:
public static DataTable GLS_DataQuery(string sql)
{
DataTable dt = new DataTable
SqlCommand command = new SqlCommand(sql, connection);
SqlDataAdapter adapter = new SqlDataAdapter(command);
adapter.Fill(dt);
return dt;
}
那为什么我会看到这个错误?或者我应该如何返回此实例中的对象列表?
Web服务托管在Azure中可能具有相关性。
编辑:将调试器附加到在Azure中运行的Web服务的实例,可以看到它确实返回了正确的数据。该错误是在调用Web服务的Xamarin手机应用程序中引发的。错误的“消息”只是一个空引用错误,堆栈跟踪是:
在 MyApp.MyService.Service1SoapClient.EndGetAllMyTypes(IAsyncResult的 结果)在 MyApp.MyService.Service1SoapClient.OnEndGetAllMyTypes(IAsyncResult的 结果)在 System.ServiceModel.ClientBase`1.OnAsyncCallCompleted(IAsyncResult的 结果)