JSON을 생성했으며 JavaScript로 객체로 가져 오려고합니다. 계속 오류가 발생합니다. 내가 가진 것은 다음과 같습니다.
var data = '{"count" : 1, "stack" : "sometext\n\n"}';
var dataObj = eval('('+data+')');
이것은 나에게 오류를 준다 :
unterminated string literal
을 사용하면 Chrome에서 ” “, Firefox 및 IE에서 ” ” 와 JSON.parse(data)
유사한 오류 메시지가 표시 됩니다.Unexpected token ↵
unterminated string literal
두 경우 모두 오류가 사라진 \n
후 꺼내십시오 sometext
. 왜 \n
제조사 eval
와 JSON.parse
실패 했는지 알아낼 수 없습니다 .
답변
나는 이것이 당신이 원하는 것 같아요 :
var data = '{"count" : 1, "stack" : "sometext\\n\\n"}';
(문자열에서 “\”를 이스케이프 처리 (이중 “” “으로 전환)해야합니다. 그렇지 않으면 JSON 데이터가 아닌 JSON 소스의 개행 문자가됩니다.)
답변
당신은 대체하는 기능이 있어야합니다 \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"}
답변
사양에 따르면 http://www.ecma-international.org/publications/files/ECMA-ST/ECMA-404.pdf :
문자열은 따옴표 (
U+0022
)로 묶인 일련의 유니 코드 코드 포인트 입니다. 이스케이프해야하는 문자 (따옴표 (U+0022
), 역 진법 (U+005C
) 및 제어 문자)U+0000
를 제외한 모든 문자를 따옴표 안에 넣을 수 있습니다U+001F
. 일부 문자에는 두 문자 이스케이프 시퀀스 표현이 있습니다.
따라서 직접 전달 0x0A
하거나 0x0C
코드 를 작성할 수 없습니다 . 금지되어 있습니다! 사양은 일부 잘 정의 된 코드에 대한 이스케이프 시퀀스를 사용하는 제안 U+0000
에 U+001F
:
\f
양식 피드 문자 (U+000C
)를 나타냅니다 .\n
줄 바꿈 문자 (U+000A
)를 나타냅니다 .
대부분의 프로그래밍 언어가 \
인용에 사용하므로 이스케이프 구문을 피해야합니다 (이중 이스케이프-언어 / 플랫폼에 대해 한 번, JSON 자체에 대해 한 번).
jsonStr = "{ \"name\": \"Multi\\nline.\" }";
답변
예를 들어 JSON 필드의 값을 쓸 때 서버에서 문자열을 이스케이프하고 클라이언트 브라우저에서 값을 검색 할 때 이스케이프를 해제 할 수 있습니다.
모든 주요 브라우저의 JavaScript 구현에는 unescape 명령이 있습니다.
예:
서버에서 :
response.write "{""field1"":""" & escape(RS_Temp("textField")) & """}"
브라우저에서 :
document.getElementById("text1").value = unescape(jsonObject.field1)
답변
이 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();
}
답변
이 함수를 사용하여 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',
"`" => "'", "´" => "'", '"' => ',', '`' => "'",
'´' => "'", '"' => '\"', '"' => "\"", '´' => "'",
"’" => "'",
"{" => "",
"~" => "", "–" => "-", "'" => "'", " " => " ");
$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']);
답변
JSON.stringify
JSON.stringify(`{
a:"a"
}`)
위의 문자열을
"{ \n a:\"a\"\n }"
여기에 언급 된 바와 같이
이 함수는 입력 문자열의 시작과 끝에 큰 따옴표를 추가하고 특수 JSON 문자를 이스케이프합니다. 특히, 줄 바꿈은 \ n 문자로 대체되고 탭은 \ t 문자로 대체되고 백 슬래시는 두 개의 백 슬래시로 대체되며 백 슬래시는 각 인용 부호 앞에 배치됩니다.