从Azure中的SOAP Web服务检索列表时发生TargetInvocationException

ano*_*ery 7 c# soap web-services azure xamarin

我有一个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;
}
Run Code Online (Sandbox Code Playgroud)

Web服务在主项目中引用,并通过以下方式调用:

client.GetAllMyTypesCompleted += client_GetAllMyTypesCompleted;
client.GetAllMyTypesAsync();
Run Code Online (Sandbox Code Playgroud)

client_GetAllMyTypesCompleted 定义为:

private void client_GetAllMyTypesCompleted(object sender, GetAllMyTypesCompletedEventArgs e)
{
    var collection = e.Result;
}
Run Code Online (Sandbox Code Playgroud)

在这里,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;
}
Run Code Online (Sandbox Code Playgroud)

那我为什么看到这个错误呢?或者我应该如何返回此实例中的对象列表?

Web服务托管在Azure中可能具有相关性.

编辑:将调试器附加到在Azure中运行的Web服务的实例,发现它确实返回了正确的数据.该错误是在调用Web服务的Xamarin手机应用程序中引发的.错误的"消息"只是一个空引用错误,堆栈跟踪是:

在MyApp.MyService.Service1SoapClient.EndGetAllMyTypes(IAsyncResult result)at MyApp.MyService.Service1SoapClient.OnEndGetAllMyTypes(IAsyncResult result)at System.ServiceModel.ClientBase`1.OnAsyncCallCompleted(IAsyncResult result)

ano*_*ery 2

因此,您需要将HttpGet和添加HttpPost到 Web 服务的 Web.config 中的协议中。

<system.web>
    <webServices>
        <protocols>
            <add name="HttpSoap"/>
            <add name="HttpPost"/>
            <add name="HttpGet"/>
            <add name="Documentation"/>
        </protocols>
    </webServices>
</system.web>
Run Code Online (Sandbox Code Playgroud)