разбор JSON в сервлете [дубликат]

Тип математики с плавающей запятой, которая может быть реализована на цифровом компьютере, обязательно использует приближение реальных чисел и операций над ними. (Стандартная версия стандартная работает до более чем пятидесяти страниц документации и имеет комитет для рассмотрения ее ошибок и дальнейшего уточнения.)

Это приближение представляет собой смесь приближений разного типа, каждый из которых можно либо игнорировать, либо тщательно учитывать из-за его конкретного способа отклонения от точности. Это также включает в себя ряд явных исключительных случаев как на уровне аппаратного обеспечения, так и на уровне программного обеспечения, которое большинство людей прогуливает прямо мимо, делая вид, что не замечает.

Если вам нужна бесконечная точность (например, вместо числа π одного из его более коротких резервных копий), вы должны написать или использовать символическую математическую программу.

Но если вы в порядке с идеей о том, что иногда математика с плавающей запятой нечеткая по значению и логике и ошибки могут быстро накапливаться, и вы можете написать свои требования и тесты для этого, тогда ваш код может часто проходить с помощью того, что находится в вашем FPU.

57
задан Michał Perłakowski 9 February 2016 в 18:44
поделиться

5 ответов

Поскольку вы не указали ни тип содержимого запроса, ни правильный запрос JSON. Вот правильный способ отправки запроса JSON:

var arr = { City: 'Moscow', Age: 25 };
$.ajax({
    url: 'Ajax.ashx',
    type: 'POST',
    data: JSON.stringify(arr),
    contentType: 'application/json; charset=utf-8',
    dataType: 'json',
    async: false,
    success: function(msg) {
        alert(msg);
    }
});

Замечания:

  • Использование метода JSON.stringify для преобразования объекта javascript в строку JSON который является родным и встроенным в современные браузеры. Если вы хотите поддерживать старые браузеры, вам может потребоваться включить json2.js
  • Указание типа содержимого запроса с использованием свойства contentType, чтобы указать серверу цель отправка запроса JSON
  • Свойство dataType: 'json' используется для типа ответа, который вы ожидаете от сервера. jQuery достаточно умен, чтобы угадать его из заголовка ответа сервера Content-Type. Поэтому, если у вас есть веб-сервер, который уважает более или менее HTTP-протокол и отвечает на Content-Type: application/json на ваш запрос, jQuery будет автоматически анализировать ответ в javascript-объекте в обратном вызове success, так что вам не нужно указывать Свойство dataType.

Осторожно:

  • То, что вы называете arr, не является массивом. Это объект javascript со свойствами (City и Age). Массивы обозначаются символом [] в javascript. Например, [{ City: 'Moscow', Age: 25 }, { City: 'Paris', Age: 30 }] представляет собой массив из двух объектов.
149
ответ дан Darin Dimitrov 27 August 2018 в 05:28
поделиться

Я написал небольшую удобную функцию для размещения JSON.

$.postJSON = function(url, data, success, args) {
  args = $.extend({
    url: url,
    type: 'POST',
    data: JSON.stringify(data),
    contentType: 'application/json; charset=utf-8',
    dataType: 'json',
    async: true,
    success: success
  }, args);
  return $.ajax(args);
};

$.postJSON('test/url', data, function(result) {
  console.log('result', result);
});
3
ответ дан Aram Kocharyan 27 August 2018 в 05:28
поделиться

Вам нужно установить правильный тип контента и подкрепить свой объект.

var arr = {City:'Moscow', Age:25};
$.ajax({
    url: "Ajax.ashx",
    type: "POST",
    data: JSON.stringify(arr),
    dataType: 'json',
    async: false,
    contentType: 'application/json; charset=utf-8',
    success: function(msg) {
        alert(msg);
    }
});
0
ответ дан locateganesh 27 August 2018 в 05:28
поделиться

Поскольку по умолчанию jQuery сериализует объекты, переданные как параметр data, на $.ajax. Он использует $.param для преобразования данных в строку запроса.

Из документов jQuery для $.ajax :

[аргумент data] преобразуется в строку запроса, если уже не строка

Если вы хотите отправить JSON, вам придется ее кодировать самостоятельно:

data: JSON.stringify(arr);

Обратите внимание, что JSON.stringify присутствует только в современных браузерах. Для устаревшей поддержки загляните в json2.js

8
ответ дан lonesomeday 27 August 2018 в 05:28
поделиться

Он сериализуется так, чтобы URI мог считывать пары значений имени в запросе POST по умолчанию. Вы можете попробовать установить processData: false в свой список параметров. Не уверен, что это поможет.

0
ответ дан picus 27 August 2018 в 05:28
поделиться
Другие вопросы по тегам:

Похожие вопросы: