繁体   English   中英

如何使用存储库架构在 ASP.NET MVC 应用程序中实现获取 Web API 数据?

[英]How can I implement getting Web API data in an ASP.NET MVC app using the repository architecture?

我有以下代码可以从 ASP.NET Web API 检索数据:

string BaseUrl = "https://localhost:48262/";

public async Task<ActionResult> Index()
{
    List<User> users= new List<User>();

    using (var client = new HttpClient())
    {
        client.BaseAddress = new Uri(BaseUrl);
        client.DefaultRequestHeaders.Clear();

        client.DefaultRequestHeaders.Accept.Add(new MediaTypeWithQualityHeaderValue("application/json"));

        HttpResponseMessage res = await client.GetAsync("api/Users");

        if (res.IsSuccessStatusCode)
        {
            var userdiagnosisRes = res.Content.ReadAsStringAsync().Result;
            users = JsonConvert.DeserializeObject<List<User>>(userRes);
        }

        return View(users);
    }
}

此代码有效,它位于控制器中,数据显示在Index页面上。

我怎样才能实现这是一个存储库架构? 我的应用程序也有一个与另一个数据库的DbContext连接,但对于这个连接,我必须从 RESTapi 检索数据。 我希望能够在其他地方使用 webapi 数据,而不仅仅是这个控制器。

我利用委托和表达式:

public async Task<HttpResponseMessage> GetAsync(string url, Action<HttpRequestHeaders> headers, Action<IHttpRequestParameters> parameters)
    {
        using (var client = new HttpClient())
        {
            headers?.Invoke(client.DefaultRequestHeaders);

            if (parameters != null)
            {
                parameters.Invoke(_httpRequestParameters);
                var query = _httpRequestParameters.GetQueryString();
                url += query;
            }

            return await client.GetAsync(url);
        }
    }

然后像这样调用它:

var test = await _handler.GetAsync("https://myurl.com", header =>
        {
            header.Add("mynewheader", "ha! it works!!");
            header.Accept.Add(new System.Net.Http.Headers.MediaTypeWithQualityHeaderValue("application/xml"));
            header.Authorization = new System.Net.Http.Headers.AuthenticationHeaderValue("Bearer", "fefe5648564grgrgr65446");
        }, parameters =>
        {
            parameters.Add("test", "firstparam");
            parameters.Add("test2", "secondparam");
        });

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM