![](/img/trans.png)
[英]Not Getting the list data in json responce when i am using the asp.net web api in mvc
[英]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.