我有这个可以使用下面提到的ajax调用的webAPI。
我正在尝试使用c#HttpClient
获得相同的结果(抓取data.URLs)。
它是一个POST请求,可以获取数据。
无论我创建什么,它都会遇到404错误。 以下是代码:
$.ajax({
type: "POST",
crossOrigin: true,
headers: { "Authorization-Token": "someToken" },
url: https://someURl?Param1=" + Val1 + "&Param2=" + Val2 + "&Param3=" + Val3,
contentType: false,
processData: false,
data: data,
success: function (data) {
document.getElementById("message").innerHTML = data.Message;
$("#urlelement").empty();
for (var i = 0; i < data.URLs.length; i++) {
$("#urlelement").append('<span>' + data.URLs[i] + '</span>');
$("#urlelement").append('<br />');
}
},
error: function (data, errorThrown, status) {
alert(data.responseText);
}
});
});
我的代码到目前为止: 我知道我没有返回任何值,只是想在响应中有某些内容时达到某一点。不知道是否应该以这种方式创建字符串内容,它也不适用于这种情况
static HttpClient client = new HttpClient();
static string token = "some values"
static void Main()
{
RunAsync().Wait();
}
static async Task RunAsync()
{
client.DefaultRequestHeaders.Accept.Clear();
client.DefaultRequestHeaders.Accept.Add(new MediaTypeWithQualityHeaderValue("text/plain"));
client.DefaultRequestHeaders.Add("Authorization-Token", token);
string Param1 = "val1";
string Param2 = "val2";
int Param3 = val3;
var requestString = "https://someUrl?";
var dataString = String.Format("Param1={0}Param2={1}Param3={2}", val1, val2, val3);
var url = await getDataAsync(requestString, dataString);
}
static async Task<Uri> getDataAsync(string path, string data)
{
StringContent queryString = new StringContent(data);
HttpResponseMessage response = await client.PostAsync(path,queryString);
response.EnsureSuccessStatusCode();
return response.Headers.Location;
}
答案 0 :(得分:0)
您没有正确处理网址的部分,以下内容应该正常工作
var http = new HttpClient();
var url = String.Format("https://someUrl?Param1={0}&Param2={1}&Param3={2}", val1, val2, val3);
var response = await http.PostAsync(url, null);
var result = await response.Content.ReadAsStringAsync();