我知道该主题有很多答案,但是找不到解决我问题的方法。我有一个如下所示的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); } });
然后,URL如下所示:
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); } });
网址:
https://localhost/supertext/api/v1/util/CountryList?idList=%5B46%2C14%2C62%2C83%2C120%5D
两种方法都不起作用。
我是否真的必须以字符串形式发送和接收它或使用POST?
不,不要尝试在GET请求中发送JSON。将JSON与其他具有主体的动词一起使用,例如POST和PUT。
通过使用[FromUri]属性装饰您的action参数,以标准方式执行此操作:
[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