このトピックにはたくさんの回答がありますが、私の問題の解決策が見つかりませんでした。次のような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);
}
});
URL:
https://localhost/supertext/api/v1/util/CountryList?idList=%5B46%2C14%2C62%2C83%2C120%5D
どちらの方法も機能しません。
本当に文字列として送受信する必要がありますか、それともPOSTを使用する必要がありますか?
いいえ、GETリクエストでJSONを送信しようとしないでください。 POSTやPUTなど、本文を持つ他の動詞とともにJSONを使用します。
アクションパラメータを[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
**次は2つのパラメーターEnumとobjSearchです**
var Enum = "ABCD";
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;戻りアクション。
}