从jquery调用async . net 4.5 web服务

本文关键字:web 服务 net jquery 调用 async | 更新日期: 2023-09-27 18:03:10

我试图了解如何从jquery 1.9.1调用使用async/await的。net 4.5 web服务(asmx)。js代码是经典的:

$.ajax({
    type: "POST",
    url: "ws/UpdCategory",
    data: strData,
    async: true,
    contentType: "application/json; charset=utf-8",
    dataType: "json",
    complete: saveCategory_onComplete
});

web服务在ws.cs,代码后面的ws.asmx:

[WebMethod]
public async Task<int> UpdCategory(string jsonData)
{
    JsonGenericResponse objWmJson = new JsonGenericResponse();
    objWmJson.IsInError = "true";
    try
    {
        JavaScriptSerializer objJss = new JavaScriptSerializer();
        Dictionary<string, string> objDict = objJss.Deserialize<Dictionary<string, string>>(jsonData);
        DataIfCloudEspresso objData = new DataIfCloudEspresso();
        //
        StringBuilder objBuilder = new StringBuilder();
        objBuilder.Append("<?xml version=" + (char)39 + "1.0" + (char)39 + " encoding=" + (char)39 + ConfigurationService.XMLEncoding + (char)39 + "?>");
        objBuilder.Append("<Category>");
        .....various fields
        objBuilder.Append("</Category>");
        // the row below call the method on Data Access Layer
        int updatedCount = await objData.UpdCategory(objBuilder.ToString());
        return updatedCount;
    }
}

最后是DAL方法:

public async Task<int> UpdCategorieArticoli(string xmlData)
{
    try
    {
        using (SqlConnection objConn = new SqlConnection(base.ConnectionString))
        {
            using (SqlCommand cmdADO = new SqlCommand("spUpd_Category", objConn))
            {
                cmdADO.Parameters.Add(new System.Data.SqlClient.SqlParameter("@XMLDoc", SqlDbType.Text));
                cmdADO.Parameters["@XMLDoc"].Value = xmlData;
                cmdADO.Parameters.Add(new System.Data.SqlClient.SqlParameter("@RETURN_VALUE", SqlDbType.Int));
                cmdADO.Parameters["@RETURN_VALUE"].Direction = ParameterDirection.ReturnValue;
                //
                cmdADO.CommandType = CommandType.StoredProcedure;
                //
                await objConn.OpenAsync().ConfigureAwait(false);
                return await cmdADO.ExecuteNonQueryAsync().ConfigureAwait(false);
            }
        }
    }
    catch (Exception)
    {
        throw;
    }
    finally
    {
    }
}

问题是这样的:从Page_Load调用DAL方法,例如,工作没有问题;相反,当从web服务(从javascript调用)调用时,代码挂在await cmdADO.ExecuteNonQueryAsync()行上。

我认为问题是客户端的上下文切换(来自浏览器的js代码)和服务器上工作的代码,我不明白如何解决这个问题。我已经尝试了各种代码找到谷歌,但没有解决方案。

明显的范围是最大限度地使用异步代码以获得最大性能。

我试图写一个旧风格的BeginExecuteNonQuery回调,但我还没有找到一个解决方案,如何从EndExecuteNonQuery的结果通信到调用web服务。

从jquery调用async . net 4.5 web服务

根据是否可以在webmethod asmx服务中使用async/await的评论,asmx根本不支持async。这就是为什么你的代码不能工作。这也与jQuery异步无关

jQuery async本身就是一个async。这就是正在发生的事情。当你调用web服务时,它异步执行数据访问逻辑,并向web服务返回http响应OK,这意味着该方法已经成功执行,但它没有返回结果。

当你从Page_Load调用它时,这意味着页面的呈现将为所有异步方法完成以执行呈现。

所以底线是不要在web服务上使用async因为jQuery那边有async