Wie kann die Web-API ein Objekt, das JSON.Net deserialisiert, nicht deserialisieren?Warum wird die Web-API dies nicht deserialisieren, sondern JSON.Net?
Dies ist der Web API Controller:
public void Put(EditorSubmissionMainView ajaxSubmission) {
// ajaxSubmission: EditorSubmissionMainView with all values ('data' also == null)
string json = "{\"id\":\"row_1377\",\"data\":{\"ROTATION\":\"1\",\"EQUIPMENT\":[{\"id\":\"6\"},{\"id\":\"8\"}],\"NOTES\":\"\"}}";
EditorSubmissionMainView foo = Newtonsoft.Json.JsonConvert.DeserializeObject<EditorSubmissionMainView>(json) as EditorSubmissionMainView;
// foo is a EditorSubmissionMainView but properly deserialized.
}
Dies ist der JSON- durch Fiedler erfasst und formatiert:
{
"id": "row_1377",
"data": {
"ROTATION": "1",
"EQUIPMENT": [{
"id": "6"
},
{
"id": "8"
}],
"NOTES": ""
}
}
Ein Beispiel der Klasse, die mit serialisiert JSON.Net aber nicht mit einem Web-API-Controller:
[Serializable]
public class EditorSubmissionMainView
{
public string id { get; set; }
public EditorSubmissionMainViewData data { get; set; }
}
[Serializable]
public class EditorSubmissionMainViewData
{
[JsonProperty("ROTATION")]
public int? rotation { get; set; } // Same problem if everything is a string
[JsonProperty("EQUIPMENT")]
public ICollection<Dictionary<string, int?>> equipment { get; set; }
[JsonProperty("NOTES")]
public string notes { get; set; }
}
Die Web-API verwendet JSON.Net, und ich verwende keine benutzerdefinierten JSON-Formatierer, sondern übergebe den JSON nur an einen Web-API-Controller. Warum funktioniert das nicht?
EDIT: Wie gewünscht, rufe ich meine Web-API-Controller mit diesem Javascript (Teil von JQuery DataTables). Beachten Sie, dass ich sicher bin, das gleiche JSON mein Controller wird immer unabhängig, weil ich das rohe HTTP-Paket mit Fiddler aufgenommen haben und dafür gesorgt, dass es richtig ist:
"ajaxUrl": {
"create": "POST @Url.Content("~/API/MainView")",
"edit": "PUT @Url.Content("~/API/MainView")",
"remove": "DELETE @Url.Content("~/API/MainView")"
},
"ajax": function (method, url, data, successCallback, errorCallback) {
$.ajax({
"type": method,
"url": url,
"data": JSON.stringify(data), // Requires IE8+
"contentType": "application/json",
"dataType": "json",
"success": function (json) {
successCallback(json);
},
"error": function (xhr, error, thrown) {
errorCallback(xhr, error, thrown);
}
});
},
Die rohe HTTP-Anforderung folgt:
PUT http://localhost:53367/API/MainView HTTP/1.1
x-requested-with: XMLHttpRequest
Accept-Language: en-us
Referer: http://localhost:53367/Manage/MainView
Accept: application/json, text/javascript, */*; q=0.01
Content-Type: application/json
Accept-Encoding: gzip, deflate
User-Agent: Mozilla/5.0 (compatible; MSIE 9.0; Windows NT 6.1; WOW64; Trident/5.0)
Host: localhost:53367
Content-Length: 306
Connection: Keep-Alive
Pragma: no-cache
Cookie: ASP.NET_SessionId=wqsghjrol20cszrxfzdm0qo4
{"id":"row_1377","data":{"ROTATION":"1","EQUIPMENT":[{"id":"6"},{"id":"8"}],"NOTES":""}}
Bitte posten Sie wie Sie Ihre Webapi-Methode (den Js Ajax-Code) aufrufen! – nemesv
Stellen Sie sicher, dass Ihre Anfrage den Header "Content-Type: application/json" hat – marcind
@nemesv: Fertig. :) –