我知道这个主题有很多答案,但无法找到我的问题的解决方案。 我有一个ASP.NET MVC Web API,如下所示:
[HttpGet]
public IList<Country> GetCountryList(List<long> idList)
我试过这样称呼它:
$.ajax({
dataType: "json",
data: JSON.stringify({idList: listOfIds}),
type: "GET",
url: "api/v1/util/CountryList",
success: function (result) {
alert(result);
}
});
网址如下所示:
https://localhost/supertext/api/v1/util/CountryList?{%22idList%22:[46,14,62,83,120]}
替代:
$.ajax({
dataType: "json",
data: {
idList: JSON.stringify(listOfIds),
}
type: "GET",
url: "api/v1/util/CountryList",
success: function (result) {
alert(result);
}
});
URL:
https://localhost/supertext/api/v1/util/CountryList?idList=%5B46%2C14%2C62%2C83%2C120%5D
两种方法都不起作用。
我是否真的必须以字符串形式发送和接收它或使用POST?
答案 0 :(得分:54)
不,不要尝试在GET请求中发送JSON。将JSON与其他具有正文的动词一起使用,例如POST和PUT。
以标准方式执行操作,方法是使用[FromUri]
属性修饰您的操作参数:
public IList<Country> GetCountryList([FromUri] List<long> idList)
{
...
}
然后只是触发AJAX请求:
$.ajax({
url: 'api/v1/util/CountryList',
type: 'GET',
data: { idList: [1, 2, 3] },
traditional: true,
success: function (result) {
console.log(JSON.stringify(result));
}
});
进一步推荐阅读有关Web API中模型绑定如何工作的信息:
http://www.asp.net/web-api/overview/working-with-http/sending-html-form-data,-part-1
答案 1 :(得分:0)
**以下是两个参数Enum和objSearch **
var Enum =&#34; ABCD&#34 ;;
var objSearch = [
{"Name":"Navjot Angra","Age":23},
{"Name":"Nav","Age":22}];
//这是ajax方法
$。AJAX({
type: "GET",
var GatwayUrl ='http//2937/' (//Your url)
url: GatwayUrl + 'api/Certificate/GetDetail/?Enum=' + Enum +'+&objSearch='+ JSON.stringify(objSearch),
contentType: "application/json; charset=utf-8",
dataType: "json",
success: function (result) {
if (result) {
alert("Your Code");
} }
});
//此部分是web api部分
[HTTPGET]
public IHttpActionResult Fetch([FromUri] string Enum,[FromUri] string objSearch) {
IHttpActionResult action = null; 返回行动;
}