我遇到了这个错误:
JSON请求过大无法反序列化。
以下是导致此错误的一种情况。我有一个国家类,其中包含该国家的一系列航运港口列表。
public class Country
{
public int Id { get; set; }
public string Name { get; set; }
public List<Port> Ports { get; set; }
}
我在客户端使用KnockoutJS制作级联下拉菜单。因此,我们有一个包含两个下拉菜单的数组,第一个是国家,第二个是该国家的港口。
到目前为止,一切都运行良好,这是我的客户端脚本:
var k1 = k1 || {};
$(document).ready(function () {
k1.MarketInfoItem = function (removeable) {
var self = this;
self.CountryOfLoadingId = ko.observable();
self.PortOfLoadingId = ko.observable();
self.CountryOfDestinationId = ko.observable();
self.PortOfDestinationId = ko.observable();
};
k1.viewModel = function () {
var marketInfoItems = ko.observableArray([]),
countries = ko.observableArray([]),
saveMarketInfo = function () {
var jsonData = ko.toJSON(marketInfoItems);
$.ajax({
url: 'SaveMarketInfos',
type: "POST",
data: jsonData,
datatype: "json",
contentType: "application/json charset=utf-8",
success: function (data) {
if (data) {
window.location.href = "Fin";
} else {
alert("Can not save your market information now!");
}
},
error: function (data) { alert("Can not save your contacts now!"); }
});
},
loadData = function () {
$.getJSON('../api/ListService/GetCountriesWithPorts', function (data) {
countries(data);
});
};
return {
MarketInfoItems: marketInfoItems,
Countries: countries,
LoadData: loadData,
SaveMarketInfo: saveMarketInfo,
};
} ();
当选择像中国这样有许多港口的国家时,问题就会出现。因此,如果您的数组中有3或4次“China”,而我想将其发送到服务器保存,则会出现错误。
我该怎么办才能解决这个问题?