从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服务。
根据是否可以在webmethod asmx服务中使用async/await的评论,asmx根本不支持async
。这就是为什么你的代码不能工作。这也与jQuery异步无关
jQuery async本身就是一个async。这就是正在发生的事情。当你调用web服务时,它异步执行数据访问逻辑,并向web服务返回http响应OK,这意味着该方法已经成功执行,但它没有返回结果。
当你从Page_Load调用它时,这意味着页面的呈现将为所有异步方法完成以执行呈现。
所以底线是不要在web服务上使用async因为jQuery那边有async