通过GET请求发送JSON列表

时间:2016-01-05 00:02:38

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

我正在尝试加快本地软件同步的过程。现在我们发送一个请求我们需要的每个单独记录的GET,并且API发回一个包含该记录数据的JSON字符串,然后将其插入到本地数据库中。这一切都有效,但它可能很乏味。我试图加快速度,并希望一个好的方法是发送List<Dictionary<string, string>>的JSON。这样就可以让我在API端一次性请求更多数据,将其添加到列表中,然后将其作为JSON传递给本地机器。

现在我在本地方面:

Encoding enc = System.Text.Encoding.GetEncoding(1252);
using (HttpClient client = new HttpClient())
{
    string basicAuth = Convert.ToBase64String(ASCIIEncoding.ASCII.GetBytes(string.Format("{0}:{1}", usr, pwd)));

    client.BaseAddress = new Uri(baseUrl);
    client.DefaultRequestHeaders.Clear();
    client.DefaultRequestHeaders.Authorization = new System.Net.Http.Headers.AuthenticationHeaderValue("Basic", basicAuth);
    client.DefaultRequestHeaders.Accept.Add(new System.Net.Http.Headers.MediaTypeWithQualityHeaderValue("application/json"));
    string requested = JsonConvert.SerializeObject(tableList);

    HttpResponseMessage response = client.GetAsync(syncUrl + hash + "/" + requested).Result;

    if (!response.IsSuccessStatusCode)
    {
        // get the error
        StreamReader errorStream = new StreamReader(response.Content.ReadAsStreamAsync().Result, enc);
        throw new Exception(errorStream.ReadToEnd());
    }
}

我的控制器调用如下所示:

[System.Web.Http.AcceptVerbs("GET")]
[Route("getRecords/{hash}/{requested}")]
public HttpResponseMessage getRecords(string hash, string requested)

每当我进行此调用时,它都会给我一个错误,它无法找到URI,我甚至没有在我的API上点击断点。我如何让这个工作,或者有更好的方法来完成我正在做的事情?

1 个答案:

答案 0 :(得分:0)

你需要对数据进行urlencode,如果有任何特殊的url字符(如&符号或斜杠),它将使数据无法使用,所以你必须对其进行urlencode以使其格式正确。

使用像...这样的东西。

string requested = Uri.EscapeDataString(JsonConvert.SerializeObject(tableList));

这将对特殊字符进行编码,以便可以在URL上安全地传输它们。