본문 바로가기

[JS] JSON 개요 (JavaScript Object Notation)

[JS] JSON 개요 (JavaScript Object Notation)

 

JSON의 탄생 배경

 

  • JSON은 JavaScript Object Notation의 줄임말이다. (자바스크립트 객체 표기법)
  • 데이터 교환을 위해 만들어진 객체 형태의 포맷이다.
  • 네트워크를 통해, 어떤 객체 내용을 다른 프로그램에 전송한다고 가정해보자. 이 객체 내용을 일종의 메신저 혹은 채팅 프로그램에서 쓰는 하나의 메시지라 한다면, 다음 객체를 어떻게 전송할 수 있을까?
const message = {
  sender: "김코딩",
  receiver: "박해커",
  message: "해커야 오늘 저녁 같이 먹을래?",
  createdAt: "2023-01-12 10:10:10"
}

 

 

  • 메시지 객체가 전송할 수 있게 하려면, 메시지를 보내는 발신자와 메시지를 받는 수신자가 같은 프로그램을 사용하거나,
  • 문자열처럼 범용적으로 읽을 수 있는 형태여야 한다.

 

[정리 : 전송할 수 있는 조건 (transferable condition)]

  • 수신자(reciever)와 발신자(sender)가 같은 프로그램을 사용한다.
  • 또는, 문자열처럼 범용적으로 읽을 수 있어야 한다.

 

  • 객체는 타입 변환을 이용해 String으로 변환할 경우 객체 내용을 포함하지 않는다.
  • JavaScript에서 객체를 문자열로 변환하기 위해 메서드(message.toString())나 형 변환(String(message))을 시도하면, [object Object] 라는 결과를 리턴한다.

 

 

[여기서 잠깐! String()과 .toString()의 차이]

1. String()은 어떤 형태든 문자로 형변환 / .toString()은 null, undefined 입력 시 오류 (Cannot read properties of ~)

2. number.toString(radix)은 숫자를 2~36진수의 수로 변경할 때 사용한다. 
   예)  

   -  radix의 범위는 2~36이며, 값 생략시 10진수로 반환한다. (범위에서 벗어나면 오류)
   -  변환한 진수를 다시 숫자로 변경하는 방법은 parseInt(string, radix)이며 radix의 범위는 동일하다.
   ** 정수 리터럴을 함수에 직접 사용할 경우, .을 소숫점 숫자로 해석해 오류가 날 수 있다. (예: 100.toString())
          100.0.toString() 또는 (100).toString() 으로 쓰면 된다.

 

이 문제를 해결하는 방법은 객체를 JSON의 형태로 변환하거나 JSON을 객체의 형태로 변환하는 방법이다.

  • 이를 위한 메서드는 다음과 같다.
    • JSON.stringify : 객체를 JSON으로 변환 
    • JSON.parse : JSON을 객체로 변환 
    • 자세한 내용은 JSON 공식 문서를 참고 

 

let transferableMessage = JSON.stringify(message)

console.log(transferableMessage) 
// `{"sender":"김코딩","receiver":"박해커","message":"해커야 오늘 저녁 같이 먹을래?","createdAt":"2021-01-12 10:10:10"}`

console.log(typeof(transferableMessage))
// `string`

 

stringify하는 이 과정을 직렬화(serialize)한다고 한다.

 

  • JSON으로 변환된 객체의 타입은 문자열이다. 발신자는 객체를 직렬화한 문자열을 누군가에게 객체의 내용을 보낼 수 있다.
  • 그렇다면 수신자는 이 문자열 메시지를 어떻게 다시 객체의 형태로 만들 수 있을까? JSON.stringify와 정반대의 작업을 수행하는 메서드 JSON.parse 를 사용할 수 있다.
let packet = `{"sender":"김코딩","receiver":"박해커","message":"해커야 오늘 저녁 같이 먹을래?","createdAt":"2021-01-12 10:10:10"}`
let obj = JSON.parse(packet)

console.log(obj)
/*
 * {
 * sender: "김코딩",
 * receiver: "박해커",
 * message: "해커야 오늘 저녁 같이 먹을래?",
 * createdAt: "2021-01-12 10:10:10"
 * }
 */

 console.log(typeof(obj))
 // `object`

 

 

JSON.parse를 적용하는 이 과정을 역직렬화(deserialize)한다고 한다.

 

 

[그림] 직렬화와 역직렬화 모식도(어떤 물건 또는 구조물의 모양을 그대로 따서 입체적으로 그린 그림)

 

  • 이처럼, JSON은 서로 다른 프로그램 사이에서 데이터를 교환하기 위한 포맷이다.
  • 그리고 JSON 포맷은 자바스크립트를 포함한 많은 언어에서 범용적으로 사용하는 유명한 포맷이다.

 

JSON의 기본 규칙

 

JSON은 얼핏 보기에 자바스크립트의 객체와 별반 다를 바가 없어 보이지만, 자바스크립트의 객체와는 미묘하게 다른 규칙이 있다.

 

  자바스크립트  객체JSON
키는 따옴표 없이 쓸 수 있음
{ key : "property" }
반드시 쌍따옴표를 붙여야 함
'{"key":"property"}'
문자열 값 작은따옴표도 사용 가능
{ "key" : 'property' }
문자열 값은 큰 따옴표 사용,
또한 작은따옴표로 객체 전체를 감싸야 함
'{"key":"property"}'
키와 값 사이 공백 사용 가능
{"key" : 'property'}
사용 불가능
'{"key":"property"}'
키-값 쌍 사이 공백 사용 가능
{ "key":'property', num:1 }
사용 불가능
'{"key":"property","num":1}'

 

JSON 용례

 

 

const message = {
  sender: "김코딩",
  receiver: "박해커",
  message: "해커야 오늘 저녁 같이 먹을래?",
  createdAt: "2021-01-12 10:10:10"
}

let stringified = JSON.stringify(message)

console.log(String(message)); // [obejct Object]
console.log(typeof stringified); // string
console.log(typeof JSON.parse(stringified)); // object

 

 

 

728x90
⬆︎