책 소개
소스 코드 파일은 여기에서 내려 받으실 수 있습니다.
요약
Node.js 설치부터 채팅 시스템 구현에 이르기까지 Node.js를 활용해 하나의 시스템을 완성하는 방법을 폭넓게 다룬다. 특히 Confetti Cusine이라는 가상 요리 학교의 수업 등록 사이트 제작을 캡스톤 프로젝트로 정하고 이를 구현하면서 실제 Node.js를 활용한 개발 과정을 보여준다. 진행하는 과정에서 볼 수 있는 Q&A를 풀어간다면 Node.js를 활용한 개발에서 기억해야 할 점을 잘 정리하게 될 것이다.
이 책에 쏟아진 찬사
"Node.js로 가는 길을 실용적이고 명료하게 제시한다"
— 카일리 심슨(Kyle Simpson), Getify
"JavaScript 프로그래머를 한 주 안에 Node 닌자로 키워준다"
— 조셉 화이트(Joseph White), Joecasa Consulting
"최신 기술을 사용해 Node.js 앱 개발을 단계별로 안내해주는 위대한 책"
— 제레미 랭(Jeremy Lange), Sertifi
"Node의 핵심을 배우고 빠른 생산성을 갖추기 위한 모범이 되는 책"
— 비풀 굽타(Vipul Gupta), Microsoft
"이해하기 쉬우면서 모던하고 재미있는 Node.js 안내서"
— 브라이스 달링(Bryce Darling), Advanced Data & Network Solutions
추천의 글
나는 운 좋게도 2009년 말 독일 베를린에서 열린 첫 번째 JSConf.EU에 참가했다. 250명이 넘는 사람들이 모인 곳에서 잘 모르는 연사가 갑자기 일어나 자신을 라이언 달(Ryan Dahl)이라고 소개했다. 한 시간 동안 그는 유머와 전달력이 없는 말투로 핵심만 간단하게 이야기했는데, 청중의 반응을 이끌어 낼 만한 종류의 이야기는 아닌 듯했다.
그러나 잠시 후 우리는 모두 일어서서 수분 동안 그에게 기립 박수를 보냈다. 왜? 그 연설이 JavaScript 개발자들의 판을 바꿔버렸기 때문이다. 라이언 달은 그 자리에서 공식적으로 Node.js를 론칭했다. JS의 세계는 더 이상 예전의 세계가 아니었다. 그로부터 8년이 지난 지금 Node.js는 Javascript 영역뿐만 아니라 다양한 분야에서 폭넓게 사용되고 있다.
오늘날 Node.js는 글로벌 스케일 웹 애플리케이션을 위한 강력하고 훌륭한 엔터프라이즈 서버사이드 플랫폼으로 알려져 있다. 로봇에서 텔레비전, 전구에 이르기까지 실제로 컴퓨팅이나 전자 장치에 JS를 포함시키는 것에 관한 관심이 폭발적으로 증가했다.
Node.js의 에코시스템은 수천 개의 모듈 패키지를 제공하는 npm을 통해 구축돼 있는데, 이는 가장 큰 코드 리포지터리이며 타 랭귀지에 비해 6배나 크다. 이 통계는 수백만 라인의 JavaScript로 돼 있는 수많은 프라이빗 패키지 인스톨은 포함하지 않는 수치다. 이런 흐름과 관심은 자칫 Node.js 생태계를 배우려고 시작하는 이들에게 엄청난 부담으로 다가올 수 있다. 하지만 이 책을 통해 부담을 덜 수 있다. 이 책은 첫 페이지부터 Node.js를 따라가는 방법을 실용적이고 명확하게 보여준다. 역사적, 철학적인 내용은 다루지 않는다. Node.js를 설치하고 구성하는 방법을 보여줌으로써 가능한 한 코드에 빨리 접근할 수 있도록 한다.
이 책은 짧고 이해하기 쉬운 레슨(Lesson) 단원으로 구성돼 있다. 각 단원을 명확하게 구성하고 있어 큰 그림을 놓치지 않도록 진행한다. 이 책으로 Node.js에 파고드는 동안 저자인 조나단이 당신 옆에 앉아 있는 것 같을 것이다. 그리고 다음 단원으로 진행하게끔 도전 의식을 불러일으켜 줄 것이다.
30페이지 정도 읽으면 여러분은 웹 요청을 처리할 수 있는 웹 서버를 만들 수 있을 것 같은 느낌이 든다. 제약 없이 자신의 애플리케이션을 컨트롤한다는 느낌이 충만해지면 기립 박수라도 치고 싶은 충동이 들 것이다.
책에서 약 40개의 레슨을 진행하면서 Node.js 프로그래밍 기능의 범위를 체계적으로 API 처리, 데이터베이스, 인증 등으로 확장한다. 이 책은 Node.js를 프로그래밍 핵심 도구로 사용하고자 배우고 습득해야 할 사항의 체크리스트도 제공한다.
내가 라이언 달의 이야기를 처음 듣는 순간부터 지금까지 Node.js는 항상 내 곁에 있어 왔다. Node.js는 내게 JavaScript 개발자라는 경력과 내 모든 애플리케이션에 가능성을 제공한 강력한 도구다. 이 책은 Node.js의 시작부터 좋아하는 웹 애플리케이션 도구로써 효과적으로 활용할 수 있는 방법까지 당신이 찾고 있던 가이드가 될 것이라 확신한다. 조나단이 당신을 0장에서 기다리고 있다. 뭘 기다리는가. 바로 Node.js 프로그래밍을 시작하자!
- 카일리 심슨(Kyle Simpson)
/Getify, 오픈 웹 에반젤리스트
이 책에서 다루는 내용
■ ES2015 이후의 새로운 기능들
■ 비동기 코드 작성
■ 데이터 모델 생성
■ JavaScript 모듈 디버깅
이 책의 대상 독자
웹 애플리케이션을 빌드하고자 Node.js 및 관련 도구를 배우는 데 관심이 있는 독자를 위한 책이다. 이미 JavaScript에 친숙하지만 웹 개발 경험이 없다면 더욱 유용할 것이다.
프로젝트 기반으로 구성돼 있어 각자 컴퓨터에서의 실습에 익숙해야 한다. 백엔드나 서비스 기술에 배경지식은 이 책을 이해하는 데 큰 도움이 될 것이다. 신입 개발자라면 다음 기술에 익숙해져야 한다.
■ JavaScript
■ HTML
■ CSS
■ 터미널/CLI
JavaScript ES6 엔진에 관한 지식은 도움은 되지만 필수는 아니다.
이 책의 구성
0부에서는 시작에 필요한 배경지식을 제공하고 Node.js와 개발 도구 설치 과정을 안내한다.
1부에서는 기본적인 웹 개발 개념을 다루고 기초부터 시작해 Node.js에서 첫 번째 웹 애플리케이션을 작성할 수 있는 지침을 제공한다.
2부에서는 대부분의 Node.js 개발자가 애플리케이션을 작성하는 데 사용하는 웹 프레임워크 Express.js를 소개한다. Express.js가 제공하는 것, 작동 방식 및 사용자 정의 기능 등을 배운다. MVC(Model-View-Controller) 애플리케이션 아키텍처 패턴도 학습한다.
3부에서는 애플리케이션을 데이터베이스에 연결하는 과정을 설명한다. 덧붙여 몇 가지 새로운 도구를 설치하고 몽고DB로 데이터베이스를 구조화하는 방법을 설명한다.
4부에서는 데이터 모델을 작성하는 방법을 설명한다. 데이터베이스의 데이터 생성, 읽기, 수정, 삭제를 하는 CRUD 작업을 다룬다.
5부에서는 객체지향 구조에서 사용자 계정을 나타내는 코드 작성을 설명한다. 새로운 사용자를 위해 데이터 보안 및 로그인 양식 작성도 설명한다.
6부에서는 API 제작을 설명한다. API의 구성 요소, API의 보호 방법, REST 아키텍처를 사용해 API를 디자인하는 방법을 배운다.
7부에서는 애플리케이션에 실시간 채팅 시스템 구축 방법을 추가한다. 메인스트림 애플리케이션이 사용자에게 좀 더 빠르고 효율적으로 데이터를 가져오기 위해 사용하는 라이브러리 Socket.io를 사용해 폴링, 웹 소켓 및 데이터 브로드캐스팅 기능을 제공한다.
8부에서는 배포 프로세스를 설명한다. 배포에 필요한 도구와 계정을 배울 것이다.
상세 이미지
목차
목차
- Unit 0. 시작하기
- Lesson 0. Node.js의 설정과 JavaScript 엔진 설치
- 0.1 여러분이 배울 것들
- 0.2 Node.js의 이해
- 0.3 왜 Node.js로 개발하는가?
- 0.4 준비 사항
- 0.5 요약
- Lesson 1. 환경설정
- 1.1 Node.js 설치
- 1.2 텍스트 에디터 설치
- 1.3 SCM과 배포 도구 설치
- 1.4 터미널에서 Node.js REPL로 작업하기
- 1.5 요약
- Lesson 2. Node.js 애플리케이션 실행
- 2.1 JavaScript 파일의 생성
- 2.2 Node.js로 JavaScript 파일 실행하기
- 2.3 개별 JavaScript 명령 실행하기
- 2.4 요약
- Unit 1. Node.js의 시작
- Lesson 3. Node.js 모듈의 생성
- 3.1 npm 실행
- 3.2 Node.js 애플리케이션의 초기화
- 3.3 요약
- Lesson 4. Node.js에서 웹 서버 만들기
- 4.1 웹 서버의 이해
- 4.2 npm으로 애플리케이션 초기화
- 4.3 애플리케이션 코딩
- 4.4 애플리케이션의 실행
- 4.5 요약
- Lesson 5. 수신 데이터 다루기
- 5.1 서버 코드의 수정
- 5.2 요청 데이터의 분석
- 5.3 웹 애플리케이션에 라우트 붙이기
- 5.4 요약
- Lesson 6. 라우트와 외부 파일
- 6.1 fs 모듈을 이용한 정적 파일 제공
- 6.2 에셋 제공
- 6.3 라우트를 다른 파일로 바꿔 연결하기
- 6.4 요약
- Lesson 7. 캡스톤 프로젝트: 첫 번째 웹 애플리케이션 만들기
- 7.1 애플리케이션의 초기화
- 7.2 애플리케이션 디렉터리 구조의 이해
- 7.3 router.js 및 main.js 파일의 생성
- 7.4 뷰 페이지 생성
- 7.5 에셋 추가
- 7.6 라우트 생성
- 7.7 요약
- Unit 2. Express.js를 통한 웹 개발
- Lesson 8. Express.js의 설정
- 8.1 Express.js 패키지 설치
- 8.2 첫 Express.js 애플리케이션의 작성
- 8.3 웹 프레임워크를 이용한 작업
- 8.4 요약
- Lesson 9. Express.js에서의 라우트
- 9.1 Express.js로 라우트 만들기
- 9.2 요청 데이터의 분석
- 9.3 MVC의 사용
- 9.4 요약
- Lesson 10 뷰와 템플릿의 연결
- 10.1 템플릿 엔진의 연결
- 10.2 컨트롤러로부터의 데이터 전달
- 10.3 요소들 및 레이아웃 설정
- 10.4 요약
- Lesson 11. 설정과 에러 처리
- 11.1 시작 스크립트 수정
- 11.2 Express.js의 에러 처리
- 11.3 정적 파일의 제공
- 11.4 요약
- Lesson 12. 캡스톤 프로젝트: Express.js를 통한 Confetti Cuisine 사이트 개선
- 12.1 애플리케이션 초기화
- 12.2 애플리케이션 제작
- 12.3 라우트의 추가
- 12.4 뷰로 라우팅
- 12.5 정적 뷰 제공
- 12.6 뷰로의 콘텐츠 전달
- 12.7 에러 처리
- 12.8 요약
- Unit 3. 데이터베이스 연결
- Lesson 13. 몽고DB 데이터베이스 셋업
- 13.1 몽고DB 세팅
- 13.2 몽고DB 셸에서 명령어 실행
- 13.3 애플리케이션에 몽고DB 연결
- 13.4 요약
- Lesson 14. Mongoose를 사용한 모델 제작
- 14.1 Node.js 애플리케이션으로 Mongoose 설정
- 14.2 스키마의 생성
- 14.3 모델의 분류
- 14.4 요약
- Lesson 15. 컨트롤러와 모델과의 연결
- 15.1 구독자를 위한 컨트롤러 만들기
- 15.2 포스팅된 데이터의 모델로의 저장
- 15.3 Mongoose로 프로미스 사용
- 15.4 요약
- Lesson 16. 캡스톤: 사용자 구독 저장
- 16.1 데이터베이스의 설정
- 16.2 데이터 모델링
- 16.3 구독자 뷰와 라우터 추가
- 16.4 요약
- Unit 4. 사용자 모델 제작
- Lesson 17. 데이터 모델의 개선
- 17.1 모델에 유효성 평가 추가
- 17.2 REPL에서의 테스팅 모델
- 17.3 모델 조합의 생성
- 17.4 연결 모델로부터의 데이터 포퓰레이팅
- 17.5 요약
- Lesson 18. 사용자 모델의 구현
- 18.1 사용자 모델 작성
- 18.2 모델에 CRUD 메소드 붙이기
- 18.3 인덱스 페이지 작성
- 18.4 액션의 정리
- 18.5 요약
- Lesson 19. 모델의 생성과 읽기
- 19.1 새로운 사용자 폼 제작
- 19.2 뷰로부터 새로운 사용자 생성
- 19.3 show를 통한 사용자 데이터 읽기
- 19.4 요약
- Lesson 20. 모델의 업데이트와 삭제
- 20.1 사용자 정보 편집 폼 생성
- 20.2 뷰에서 사용자 수정 폼
- 20.3 delete 액션에서 사용자 삭제
- 20.4 요약
- Lesson 21. 캡스톤 프로젝트: Confetti Cusine에 CRUD 모델 추가
- 21.1 시작하기
- 21.2 모델의 생성
- 21.3 뷰의 생성
- 21.4 라우트 구조화
- 21.5 컨트롤러 제작
- 21.6 요약
- Unit 5. 사용자 계정 인증
- Lesson 22. 세션과 플래시 메시지의 추가
- 22.1 플래시 매시지 모듈 설정
- 22.2 컨트롤러 액션에 플래시 메시지 추가
- 22.3 요약
- Lesson 23. 사용자 로그인 폼 생성과 패스워드 해시
- 23.1 사용자 로그인 폼
- 23.2 패스워드의 해싱
- 23.3 express-validator 로 유효성 체크 미들웨어 추가
- 23.4 요약
- Lesson 24. 사용자 인증 추가
- 24.1 Passport.js의 실행
- 24.2 패스포트 등록 사용을 위한 Create 액션 수정
- 24.3 로그인 시 사용자 인증
- 24.4 요약
- Lesson 25. 캡스톤 프로젝트: Confetti Cuisine에 사용자 인증 추가
- 25.1 준비 작업
- 25.2 로그인 폼의 생성
- 25.3 passport.js를 이용한 암호화 추가
- 25.4 플래시 메시징 추가
- 25.5 express-validator로 유효성 체크 미들웨어 추가
- 25.6 Passport.js로 인증 추가
- 25.7 로그인과 로그아웃
- 25.8 요약
- Unit 6. API 빌드
- Lesson 26. 애플리케이션에 API 추가
- 26.1 라우트의 구성
- 26.2 API의 생성
- 26.3 클라이언트로부터 API호출
- 26.4 요약
- Lesson 27. 애플리케이션에서 API 액세스
- 27.1 API 네임스페이스의 적용
- 27.2 모달을 통한 강좌의 결합
- 27.3 모델 간 통신을 위한 API 엔드포인트 생성
- 27.4 요약
- Lesson 28. API 보안
- 28.1 간단한 보안 구현
- 28.2 API 토큰 추가
- 28.3 JSON 웹 토큰의 사용
- 28.4 요약
- Lesson 29. 캡스톤 프로젝트: API 구현
- 29.1 라우트의 재구성
- 29.2 강좌의 일부 추가
- 29.3 AJAX 함수 생성
- 29.4 API 엔드포인트 추가
- 29.5 사용자 등록을 위한 액션 생성
- 29.6 요약
- Unit 7. 채팅 기능 추가
- Lesson 30. socket.io로의 작업
- 30.1 socket.io의 사용
- 30.2 채팅 박스 생성
- 30.3 서버와 클라이언트의 연결
- 30.4 요약
- Lesson 31. 채팅 메시지의 저장
- 31.1 사용자와 메시지의 연결
- 31.2 채팅에서 사용자 이름 표시
- 31.3 메시지 모델의 생성
- 31.4 요약
- Lesson 32. 채팅 알림 표시 추가
- 32.1 다른 소켓으로의 브로드캐스팅
- 32.2 내비게이션에 채팅 표시기 생성
- 32.3 요약
- Lesson 33. 캡스톤 프로젝트: Confetti Cuisine에 채팅 기능 추가
- 33.1 socket.io 설치
- 33.2 서버에 socket.io 설정
- 33.3 클라이언트에서 socket.io 설정
- 33.4 메시지 모델 생성
- 33.5 접속 시 메시지 읽어들이기
- 33.6 채팅 아이콘 설정
- 33.7 요약
- Unit 8. 프로덕션에서의 코드 배포와 관리
- Lesson 34. 애플리케이션 배포
- 34.1 배포 준비
- 34.2 애플리케이션의 배포
- 34.3 프로덕션에서 데이터베이스 설정
- 34.4 요약
- Lesson 35. 프로덕션에서의 관리
- 35.1 시드 데이터 읽기
- 35.2 린팅
- 35.3 애플리케이션의 디버깅
- 35.4 요약
- Lesson 36 애플리케이션의 테스팅
- 36.1 코어 모듈의 기본 테스팅
- 36.2 mocha와 chai를 이용한 테스팅
- 36.3 데이터베이스 및 서버 테스팅
- 36.4 요약
- Lesson 37. 캡스톤 프로젝트: Confetti Cuisine의 배포
- 37.1 린팅과 로깅
- 37.2 배포를 위한 준비
- 37.3 Heroku로의 배포
- 37.4 데이터베이스의 설정
- 37.5 프로덕션에서의 디버깅
- 37.6 요약
- Appendix A. ES6에서 소개하는 JavaScript 문법
- Appendix B. 로깅과 Node.js의 전역 객체의 사용
도서 오류 신고
정오표
정오표
[p.70 고려 사항 아래 본문 5행]
message.js
->
messages.js
[p.70 아래에서 4행]
message 속성
->
messages 속성
[p.71 Listing 3.1]
printmessage.js
->
printmessages.js
message.js
->
messages.js
messageModule.message
->
messageModule.messages
[p.71 두 번째 문단 2-3행]
message.js
->
messages.js
printmessage.js
->
printmessages.js
[p.83 3행]
npm i http-status-code -S
->
npm i http-status-codes -S
[p.162 아래에서 3행]