> 웹 프론트엔드 > JS 튜토리얼 > JSON이란 무엇입니까?

JSON이란 무엇입니까?

Barbara Streisand
풀어 주다: 2024-09-21 06:30:18
원래의
525명이 탐색했습니다.

What is JSON?

JSON 작업

개발자라면 JSON(JavaScript Object Notation)에 대해 들어본 적이 있을 것입니다. 어디에나 있어요! API에서 구성 파일에 이르기까지 JSON은 데이터 교환을 위한 기본 형식입니다. 하지만 Node.js에서는 어떻게 작업하나요? 도움이 될 몇 가지 실제 사례를 통해 간단한 용어로 분석해 보겠습니다.


JSON이란 무엇입니까?

간단히 말하면 JSON은 데이터를 저장하고 교환하는 형식입니다. 읽고 쓰기가 쉽기 때문에 웹 개발에 매우 ​​인기가 높습니다. 다음과 같습니다:

{
  "name": "Alice",
  "age": 25,
  "city": "Wonderland"
}
로그인 후 복사

기본적으로 JavaScript 객체와 같은 키-값 쌍의 모음입니다. 하지만 기억하세요. JSON은 단지 텍스트일 뿐이므로 코드에서 유용하게 사용하려면 개체로 변환해야 합니다.


Node.js에서 JSON 구문 분석

먼저 JSON 문자열을 가져와 작업할 수 있는 JavaScript 개체로 변환해 보겠습니다. JSON.parse()를 사용하여 이 작업을 수행합니다.

예: JSON 구문 분석

const jsonString = '{"name": "Alice", "age": 25, "city": "Wonderland"}';
const jsonObject = JSON.parse(jsonString);

console.log(jsonObject.name); // Output: Alice
로그인 후 복사

JSON 문자열을 가져와서 구문 분석한 후 JavaScript 개체로 변환합니다. 이제 이름, 나이, 도시 등의 속성에 액세스할 수 있습니다.


객체를 JSON으로 변환

데이터를 JSON으로 보내야 한다면 어떻게 해야 할까요? 이것이 JSON.stringify()가 필요한 곳입니다. JavaScript 개체를 가져와 JSON 문자열로 변환합니다.

예: 개체를 JSON으로 변환

const user = {
  name: "Alice",
  age: 25,
  city: "Wonderland"
};

const jsonString = JSON.stringify(user);
console.log(jsonString);
// Output: {"name":"Alice","age":25,"city":"Wonderland"}
로그인 후 복사

API를 구축하거나 데이터를 JSON으로 저장할 때 매우 유용합니다.


Node.js에서 JSON 파일 읽기 및 쓰기

JSON 파일로 작업해야 합니까? Node.js에서는 fs(파일 시스템) 모듈을 사용하면 이를 쉽게 수행할 수 있습니다. 큰 번거로움 없이 JSON 파일을 읽고 쓸 수 있습니다.

예: JSON 파일 읽기

const fs = require('fs');

fs.readFile('data.json', 'utf8', (err, data) => {
  if (err) {
    console.error(err);
    return;
  }
  const jsonData = JSON.parse(data);
  console.log(jsonData);
});
로그인 후 복사

여기에서는 fs.readFile()을 사용하여 JSON 파일을 읽은 다음 파일 내용을 JavaScript 개체로 구문 분석합니다. 이제 데이터로 원하는 모든 것을 할 수 있습니다!

예: JSON 파일에 쓰기

const fs = require('fs');

const user = {
  name: "Alice",
  age: 25,
  city: "Wonderland"
};

fs.writeFile('output.json', JSON.stringify(user, null, 2), (err) => {
  if (err) {
    console.error(err);
    return;
  }
  console.log('Data saved to output.json');
});
로그인 후 복사

이 경우 JSON.stringify()는 객체를 멋진 형식의 JSON 문자열로 변환하고 fs.writeFile()은 이를 파일에 저장합니다. 쉽죠!


HTTP 요청으로 JSON 보내기 및 받기

API를 구축할 때 데이터를 보내고 받기 위해 선택하는 형식은 JSON입니다. Express.js에서는 JSON 데이터를 손쉽게 보내고 받을 수 있습니다.

예: 응답으로 JSON 보내기

const express = require('express');
const app = express();

app.get('/user', (req, res) => {
  const user = { name: "Alice", age: 25, city: "Wonderland" };
  res.json(user);
});

app.listen(3000, () => console.log('Server running on port 3000'));
로그인 후 복사

여기서는 HTTP GET 요청에 대한 응답으로 JSON 개체를 보냅니다. res.json()을 호출하는 것만큼 간단합니다!

예: 요청으로 JSON 수신

app.use(express.json()); // Middleware to parse JSON body

app.post('/user', (req, res) => {
  const user = req.body;
  console.log(user); // Output: { name: "Alice", age: 25, city: "Wonderland" }
  res.send('User received!');
});
로그인 후 복사

이 예에서는 express.json() 미들웨어를 사용하여 요청 본문에서 들어오는 JSON 데이터를 자동으로 구문 분석하여 사용할 수 있는 JavaScript 객체로 변환합니다.


JSON 오류 처리

잘못된 JSON 데이터를 받으면 어떻게 되나요? 걱정하지 마세요. Node.js에는 오류 처리 기능이 내장되어 있습니다. 이러한 오류를 잡는 방법을 살펴보겠습니다.

예: 구문 분석 오류 처리

const faultyJson = '{"name": "Alice", "age": 25'; // Oops, missing closing bracket

try {
  const jsonObj = JSON.parse(faultyJson);
} catch (error) {
  console.error('Failed to parse JSON:', error.message);
}
로그인 후 복사

JSON이 손상되면 JSON.parse()에서 오류가 발생합니다. 이 경우 try-catch 블록은 이를 우아하게 처리하는 데 도움이 됩니다.


마무리

Node.js에서 데이터 작업을 한다면 JSON은 꼭 알아야 할 것입니다. JSON 데이터를 구문 분석, 생성, 읽기 또는 전송하는 경우 Node.js에 내장된 메서드를 사용하면 작업이 간단해집니다. 문자열을 객체로 변환하려면 JSON.parse()를 사용하고, 반대 방향으로 변환하려면 JSON.stringify()를 사용하고, API에서 JSON을 원활하게 처리하려면 Express.js를 사용하세요.

JSON을 사용하여 편안하게 작업하면 개발자 툴킷에서 가장 유용한 도구 중 하나를 갖게 됩니다!


참고자료:

  1. Node.js 문서: JSON 작업
  2. Express.js 가이드: JSON 요청 처리
  3. MDN 웹 문서: JSON.parse()

읽어주셔서 감사합니다. 즐거운 코딩 되세요! ?

위 내용은 JSON이란 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

원천:dev.to
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
저자별 최신 기사
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿