向API发送更新请求时,WebUI无限死机

时间:2018-12-07 23:05:53

标签: c# asp.net-mvc asp.net-mvc-5

我有2个独立的应用程序,一个MVC5 UI和一个Asp.net WebApi2(不是asp.net核心)。我可以从API读取数据。现在,我想将数据从用户界面中的表单发送到API,以便它可以将其写入数据库。

出于内部原因,MVC控制器从表单接收POST请求,然后应该通过将其发送到API来更新数据库中的数据并显示某种形式的结果(错误或确认)。该API会接收数据,运行并响应200和所需的答案(“已更新”)。

可悲的是,UI并没有以某种方式意识到这个答案,并一直等待着……我已经读到90秒钟会出现超时,但是事实并非如此。我必须强调我是新手,所以我想我犯了一些奇怪的错误:D

我使用的代码在控制台应用程序中运行良好,但是我搞砸了它还是根本无法在WebApi中使用?我尝试设置超时时间,但没有任何改变:/

最后一个日志条目是:向api发送更新请求...

控制器代码:

[HttpPost]
    public ActionResult EditTicket(ServiceManagementTicket postedTicket)
    {

        if (!ModelState.IsValid)
        {
            // some error handling code
        }


        string TicketUpdateResult = updateTicket(postedTicket).Result;

        if (TicketUpdateResult == "updated")
        {

            return View("SingleTicketView", postedTicket);
        }
        else
        {

            Log.Verbose("ticket could not be updated. The error should have been logged");
            return View("Views/Pages/InternalServerError");

        }
    }

任务代码:

    public static async Task<string> updateTicket(ServiceManagementTicket postedTicket)
    {


        string FinalEndpoint = "api url here"


        String jsonToExport = JsonConvert.SerializeObject(postedTicket);
        StringContent jsonToExportConverted =
            new StringContent(jsonToExport, Encoding.UTF8, "application/json");

        Log.Verbose("Trying to update ticket at: " + FinalEndpoint);


        try
        {

            using (var client = new HttpClient())
            {

                client.DefaultRequestHeaders.Accept.Clear();
                client.DefaultRequestHeaders.Accept.Add(
                    new MediaTypeWithQualityHeaderValue("application/json"));
                client.Timeout = TimeSpan.FromSeconds(5);

                Log.Verbose("sending update request to api...");

                HttpResponseMessage response = await client.PutAsync(
                    FinalEndpoint,
                    jsonToExportConverted);


                Log.Verbose("Updating the Ticket at the webapi was: " + response.ReasonPhrase);

                if (response.ReasonPhrase == "updated")
                {

                    Log.Verbose("api confirmed the update");
                    return response.Content.ReadAsStringAsync().Result;

                }

                Log.Verbose("something ent wrong :/");
                return "error";

            }
        }
        catch (Exception e)
        {
            // error handling
        }

    }

通过同步调用将数据发送到api也很好,我只是找不到适合我的示例。

1 个答案:

答案 0 :(得分:1)

下面的代码行将在ASP.NET应用程序中死锁,永远不要在ASP.NET应用程序中使用Task.Result

string TicketUpdateResult = updateTicket(postedTicket).Result;

return response.Content.ReadAsStringAsync().Result;

这些代码行应为:

string TicketUpdateResult = await updateTicket(postedTicket);

return await response.Content.ReadAsStringAsync();