CURL возвращает BAD REQUEST для многострочных данных JSON [дубликат]

Указатель NULL - это тот, который указывает на никуда. Когда вы разыскиваете указатель p, вы говорите «дайте мне данные в месте, хранящемся в« p ». Когда p является нулевым указателем, местоположение, хранящееся в p, является nowhere, вы говорите «Дайте мне данные в месте« нигде ». Очевидно, он не может этого сделать, поэтому он выбрасывает NULL pointer exception.

В общем, это потому, что что-то не было правильно инициализировано.

211
задан apsillers 5 December 2014 в 17:11
поделиться

7 ответов

Я думаю, это то, что вы хотите:

var data = '{"count" : 1, "stack" : "sometext\\n\\n"}';

(вам нужно избежать «\» в вашей строке (превращая ее в двойную - «\»), иначе она станет newline в источнике JSON, а не данные JSON.)

279
ответ дан BlaM 18 August 2018 в 06:27
поделиться
  • 1
    Это, конечно, правильно, но я хотел бы добавить причину этого: спецификация JSON в ietf.org/rfc/rfc4627.txt содержит это предложение в разделе 2.5: & quot; Все символы Юникода могут быть помещены в кавычки, за исключением символов, которые должны быть экранированы: кавычка, обратное солидус и управляющие символы (U + 0000 через U + 001F). & Quot; Поскольку новая строка является управляющим символом, она должна быть экранирована. – daniel kullmann 25 April 2013 в 11:48
  • 2
    Согласно www.json.org, JSON принимает последовательность управления\n & quot; в строках - и если вы попробуете JSON.parse (['& quot; a \\na & quot;]) [1] .charCodeAt (); который покажет 10 - это «Линия», в последний раз я проверил. --- Кстати: перестань кричать! – BlaM 11 November 2015 в 08:25

Я столкнулся с этой проблемой, создав класс в PHP4 для эмуляции json_encode (доступный в PHP5). Вот что я придумал:

class jsonResponse {
    var $response;

    function jsonResponse() {
        $this->response = array('isOK'=>'KO','msg'=>'Undefined');
    }

    function set($isOK, $msg) {
        $this->response['isOK'] = ($isOK) ? 'OK' : 'KO';
        $this->response['msg'] = htmlentities($msg);
    }

    function setData($data=null) {
        if(!is_null($data))
            $this->response['data'] = $data;
        elseif(isset($this->response['data']))
            unset($this->response['data']);
    }

    function send() {
        header('Content-type: application/json');
        echo '{"isOK":"'.$this->response['isOK'].'","msg":'.$this->parseString($this->response['msg']);
        if(isset($this->response['data']))
            echo ',"data":'.$this->parseData($this->response['data']);
        echo '}';
    }

    function parseData($data) {
        if(is_array($data)) {
            $parsed = array();
            foreach ($data as $key=>$value)
                array_push($parsed, $this->parseString($key).':'.$this->parseData($value));
            return '{'.implode(',', $parsed).'}';
        } else
            return $this->parseString($data);
    }

    function parseString($string) {
            $string = str_replace("\\", "\\\\", $string);
            $string = str_replace('/', "\\/", $string);
            $string = str_replace('"', "\\".'"', $string);
            $string = str_replace("\b", "\\b", $string);
            $string = str_replace("\t", "\\t", $string);
            $string = str_replace("\n", "\\n", $string);
            $string = str_replace("\f", "\\f", $string);
            $string = str_replace("\r", "\\r", $string);
            $string = str_replace("\u", "\\u", $string);
            return '"'.$string.'"';
    }
}

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

0
ответ дан GabrielP 18 August 2018 в 06:27
поделиться
  • 1
    6 сокращений для управляющих символов, указанных на json.org, не являются исчерпывающим списком всех управляющих символов. В результате эта функция может генерировать недействительный JSON. – Phil 24 August 2017 в 14:52

Согласно спецификации: http://www.ecma-international.org/publications/files/ECMA-ST/ECMA-404.pdf

A string is a sequence of Unicode code points wrapped with quotation marks
(U+0022). All characters may be placed within the quotation marks except for the
characters that must be escaped: quotation mark (U+0022), reverse solidus
(U+005C), and the control characters U+0000 to U+001F. There are two-character
escape sequence representations of some characters.

So вы не можете передавать коды 0x0A или 0x0C напрямую. Запрещено! Spec предлагает использовать escape-последовательности для некоторых четко определенных кодов от U+0000 до U+001F:

\f  represents the form feed character (U+000C). 
\n  represents the line feed character (U+000A).

Поскольку большинство языков программирования использует \ для цитирования, вам следует избегать синтаксиса escape (double-escape - один раз для языка / платформы, один раз для самого Json):

jsonStr = "{ \"name\": \"Multi\\nline.\" }";
4
ответ дан gavenkoa 18 August 2018 в 06:27
поделиться

Возможно, вы захотите изучить эту функцию C #, чтобы избежать строки:

http://www.aspcode.net/C-encode-a-string-for-JSON-JavaScript .aspx

public static string Enquote(string s)  
{ 
    if (s == null || s.Length == 0)  
    { 
        return "\"\""; 
    } 
    char         c; 
    int          i; 
    int          len = s.Length; 
    StringBuilder sb = new StringBuilder(len + 4); 
    string       t; 

    sb.Append('"'); 
    for (i = 0; i < len; i += 1)  
    { 
        c = s[i]; 
        if ((c == '\\') || (c == '"') || (c == '>')) 
        { 
            sb.Append('\\'); 
            sb.Append(c); 
        } 
        else if (c == '\b') 
            sb.Append("\\b"); 
        else if (c == '\t') 
            sb.Append("\\t"); 
        else if (c == '\n') 
            sb.Append("\\n"); 
        else if (c == '\f') 
            sb.Append("\\f"); 
        else if (c == '\r') 
            sb.Append("\\r"); 
        else 
        { 
            if (c < ' ')  
            { 
                //t = "000" + Integer.toHexString(c); 
                string t = new string(c,1); 
                t = "000" + int.Parse(tmp,System.Globalization.NumberStyles.HexNumber); 
                sb.Append("\\u" + t.Substring(t.Length - 4)); 
            }  
            else  
            { 
                sb.Append(c); 
            } 
        } 
    } 
    sb.Append('"'); 
    return sb.ToString(); 
} 
2
ответ дан geofftnz 18 August 2018 в 06:27
поделиться

Вам понадобится функция, которая заменяет \n на \\n в случае, если data не является строковым литералом.

function jsonEscape(str)  {
    return str.replace(/\n/g, "\\\\n").replace(/\r/g, "\\\\r").replace(/\t/g, "\\\\t");
}

var data = '{"count" : 1, "stack" : "sometext\n\n"}';
var dataObj = JSON.parse(jsonEscape(data));

Результатом dataObj будет

Object {count: 1, stack: "sometext\n\n"}
22
ответ дан manish_s 18 August 2018 в 06:27
поделиться
  • 1
    вам нужно избежать escape-символов (то есть .replace("\\n", "\\\\n")), и я также предложил бы использовать регулярное выражение, чтобы разрешить замену нескольких экземпляров (т. е. .replace(/\n/g, "\\\\n")) – musefan 12 March 2012 в 11:14
  • 2
    почему вам нужно бежать от персонажей? Я имею в виду что-то вроде .replace("\n", "\\n") должно отлично выполнять работу !! Например, var test = [{"description":"Some description about the product. This can be multi-line text."}]; console.log(JSON.parse(test.replace(/\n/g, "\\n"))); выведет объект отлично в консоль браузера, как [{"description":"Some description about the product.\nThis can be multi-line text."}] – Fr0zenFyr 27 November 2015 в 12:43
  • 3
    BTW, в вышеприведенном комментарии, исходная строка JSON содержит новую строку, которая удаляется форматированием комментариев stackoverflow. Вы можете видеть, что окончательный вывод после замены должен вставить в значение новый символ \n. – Fr0zenFyr 27 November 2015 в 12:45
  • 4
    Потому что в консоли он должен печатать \\n, а не \n – manish_s 18 October 2016 в 00:43
  • 5
    -1 В этом ответе сначала строятся строки недопустимого JSON (поскольку newline является управляющим символом), затем пытается исправить его серией неполных замен (имеется более трех управляющих символов). Затем, чтобы справиться с этим, ему также удается использовать функцию eval. 17 upvotes ??? – Phil 24 August 2017 в 14:33

Привет, я использовал эту функцию для разметки новой строки или других символов в данных для анализа данных JSON:

function normalize_str($str) {

    $invalid = array('Š'=>'S', 'š'=>'s', 'Đ'=>'Dj', 'đ'=>'dj', 'Ž'=>'Z', 'ž'=>'z',
    'Č'=>'C', 'č'=>'c', 'Ć'=>'C', 'ć'=>'c', 'À'=>'A', 'Á'=>'A', 'Â'=>'A', 'Ã'=>'A',
    'Ä'=>'A', 'Å'=>'A', 'Æ'=>'A', 'Ç'=>'C', 'È'=>'E', 'É'=>'E', 'Ê'=>'E', 'Ë'=>'E',
    'Ì'=>'I', 'Í'=>'I', 'Î'=>'I', 'Ï'=>'I', 'Ñ'=>'N', 'Ò'=>'O', 'Ó'=>'O', 'Ô'=>'O',
    'Õ'=>'O', 'Ö'=>'O', 'Ø'=>'O', 'Ù'=>'U', 'Ú'=>'U', 'Û'=>'U', 'Ü'=>'U', 'Ý'=>'Y',
    'Þ'=>'B', 'ß'=>'Ss', 'à'=>'a', 'á'=>'a', 'â'=>'a', 'ã'=>'a', 'ä'=>'a', 'å'=>'a',
    'æ'=>'a', 'ç'=>'c', 'è'=>'e', 'é'=>'e', 'ê'=>'e',  'ë'=>'e', 'ì'=>'i', 'í'=>'i',
    'î'=>'i', 'ï'=>'i', 'ð'=>'o', 'ñ'=>'n', 'ò'=>'o', 'ó'=>'o', 'ô'=>'o', 'õ'=>'o',
    'ö'=>'o', 'ø'=>'o', 'ù'=>'u', 'ú'=>'u', 'û'=>'u', 'ý'=>'y',  'ý'=>'y', 'þ'=>'b',
    'ÿ'=>'y', 'Ŕ'=>'R', 'ŕ'=>'r', "`" => "'", "´" => "'", '"' => ',', '`' => "'",
    '´' => "'", '"' => '\"', '"' => "\"", '´' => "'", "&acirc;€™" => "'", "{" => "",
    "~" => "", "–" => "-", "'" => "'","     " => " ");

    $str = str_replace(array_keys($invalid), array_values($invalid), $str);

    $remove = array("\n", "\r\n", "\r");
    $str = str_replace($remove, "\\n", trim($str));

      //$str = htmlentities($str,ENT_QUOTES);

    return htmlspecialchars($str);
}


echo normalize_str($lst['address']);
2
ответ дан ShivarajRH 18 August 2018 в 06:27
поделиться
  • 1
    В большинстве языков у вас есть лучшие способы разделить акценты с строк юникода, чем записать свою собственную функцию сопоставления. См. Этот вопрос для примера в python: stackoverflow.com/questions/517923/… – MiniQuark 1 February 2013 в 16:35
  • 2
    ya у нас есть много способов контролировать специальные символы на языках языков. – ShivarajRH 6 February 2013 в 12:46
  • 3
    В общем-то все плохо. Лучше закодировать их как ссылку на числовой символ XML, а затем декодировать на принимающей стороне. – Annarfych 29 November 2016 в 18:22

Вы могли бы просто уйти от своей строки на сервере при записи значения поля json и unescape при получении значения в браузере клиента, например.

Реализация javascript всех основных браузеров команда unescape.

Пример: на сервере:

response.write "{""field1"":""" & escape(RS_Temp("textField")) & """}"

в браузере:

document.getElementById("text1").value = unescape(jsonObject.field1)
3
ответ дан Victor_Magalhaes 18 August 2018 в 06:27
поделиться
Другие вопросы по тегам:

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