[Node.js] #4 HTTP

2021. 12. 26. 19:02· 웹 개발/Node.js
목차
  1.  
  2. 본 내용은 Node jsd의 "http module"의 개념과 예제들을 통해 Brower와 server의 통신 방법을 이해하기 위함입니다. 

 

본 내용은 Node jsd의 "http module"의 개념과 예제들을 통해 Brower와 server의 통신 방법을 이해하기 위함입니다. 

 


 

1. HTTP?

https://mdn.mozillademos.org/files/13677/Fetching_a_page.png

"HyperText Transfer Protocol"의 악자로, HTML 문서와 같은 리소스들을 가져올 수 있도록 해주는 프로토콜입니다. HTTP는 주로 웹에서 클라이언트-서버 사이에 이루어지는 요청/응답(Requset/Response) 프로토콜이죠! 예를 들면, 웹 브라우저(클라이언트)가 HTTP를 통해 서버로부터 웹페이지의 그림 정보, 혹은 Document 정보를 요청(Request) 하면, 서버는 응답(Response)하여 필요한 정보를 클라이언트로 전달합니다. 

 

2. 서버 생성
const http = require('http');

const server = http.createServer((req,res) => {
	...
})

웹 서버 객체를 생성하기위해 http 모듈의 "createServer" 메서드를 사용합니다. 이 서버로 오는 HTTP 요청마다 createServer에 전달된 함수가 한 번씩 호출됩니다. HTTP 요청이 오면 node가 트랜잭션을 다루기위해 request와 response객체를 전달하며 요청 핸들러 함수를 호출합니다!

 

Request Message 구조

 

Request Message는 start line, header, 그리고 body로 구성되어있다.

 

1. Start Line : Method / target URL / HTPP version

GET / localhost:5000 / HTTP/1.1

2. Header : Request에 대한 추가 정보를 담고 있다.

3. Body: Request 메세지의 실제 내용, 없는 경우가 많다.

 

Response Message 구조

 

1. Status Line: HTTP ver / Status code / Status text

HTTP/1.0 / 200 / OK

 

2. Headers: connection 상태, content-type이 무엇인지에 대한 정보. 

 

3. Body: 실제 Response Message로 web에 전달된 html 파일

 

예제 코드
const http = require('http')
const server = http.createServer((req, res) => {
  var url = req.url;
  if (url === "/") {
    res.writeHead(200, { "content-type": "text/html" }); // response header
    res.write(homePage);				// response body : html file
    res.end();
  } else if (url === "/about") {
    res.writeHead(200, { "content-type": "text/html" }); // response header
    res.write("<h1> About Page </h1>");			// response body : html 형식
    res.end();
  } else {
    res.writeHead(404);	
    res.end();
  }
});

Web의 Request를 받아 호출되는 createServer 메서드를 통해, response message에 담을 내용을 구현합니다. 먼저, res.writeHead를 통해 header를 "status code, content-type"을 작성합니다. 

 

결과 화면

 

'웹 개발 > Node.js' 카테고리의 다른 글

[Node.js] #3 Promise 객체 사용과 Async 동작  (0) 2021.12.12
[Node.js] #2 Event Loop이 무엇인가?  (0) 2021.11.19
[Node.js] #1 Event Loop이 무엇인가?  (0) 2021.11.06
  1.  
  2. 본 내용은 Node jsd의 "http module"의 개념과 예제들을 통해 Brower와 server의 통신 방법을 이해하기 위함입니다. 
'웹 개발/Node.js' 카테고리의 다른 글
  • [Node.js] #3 Promise 객체 사용과 Async 동작
  • [Node.js] #2 Event Loop이 무엇인가?
  • [Node.js] #1 Event Loop이 무엇인가?
Hardii2
Hardii2
Hardii2
개발 블로그
Hardii2
전체
오늘
어제
  • 분류 전체보기
    • 알고리즘
    • 웹 개발
      • Node.js
      • React
    • 게임개발
      • DirectX12
      • 관련 지식
      • Unreal C++
      • Unreal 블루프린트
    • 언어
      • Effective C++
      • Basic C++
      • 디자인 패턴
      • 자료구조
      • 기술 질문
    • 문제 풀이
      • BOJ 문제 풀이
      • Programmers 문제 풀이
      • geeksForgeeks 문제 풀이
    • 수학
      • 확률과 통계
      • 게임수학
    • 개인프로젝트
    • 그룹프로젝트
      • PM
      • Dev
    • Github

블로그 메뉴

  • 홈
  • 글쓰기

공지사항

인기 글

태그

  • set
  • 우선순위 큐
  • 정렬
  • 기술 질문
  • 알고리즘
  • Effective C++
  • DP
  • dfs
  • 트리
  • C++
  • unreal
  • BOJ
  • 최단 경로
  • BFS
  • 그래프
  • 개발
  • 디자인 패턴
  • stl
  • programmers
  • Unreal Blueprint

최근 댓글

최근 글

hELLO · Designed By 정상우.v4.2.2
Hardii2
[Node.js] #4 HTTP
상단으로

티스토리툴바

개인정보

  • 티스토리 홈
  • 포럼
  • 로그인

단축키

내 블로그

내 블로그 - 관리자 홈 전환
Q
Q
새 글 쓰기
W
W

블로그 게시글

글 수정 (권한 있는 경우)
E
E
댓글 영역으로 이동
C
C

모든 영역

이 페이지의 URL 복사
S
S
맨 위로 이동
T
T
티스토리 홈 이동
H
H
단축키 안내
Shift + /
⇧ + /

* 단축키는 한글/영문 대소문자로 이용 가능하며, 티스토리 기본 도메인에서만 동작합니다.