inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

탄탄한 백엔드 NestJS, 기초부터 심화까지

HTTP vs Socket

웹 소켓을 이용 하려면

227

ㅌㅇ

작성한 질문수 43

1

<script src='https://unpkg.com/@babel/standalone/babel.min.js'></script>

<script
src='https://polyfill.io/v3/polyfill.min.js?features=default%2Ces2015%2Ces2016%2Ces2017%2Ces2018%2Ces2019'
></script>

<script

src='https://cdn.socket.io/3.1.3/socket.io.min.js'

integrity='sha384-cPwlPLvBTa3sKAgddT6krw0cJat7egBga3DJepJyrLl4Q9/5WLra3rrnMcyTyOnh'

crossorigin='anonymous'

></script>
이 코드는 항상 있어야 하는건가요?

mongodb nodejs express ssr NestJS

답변 1

0

윤상석

안녕하세요. EH님!

아닙니다. WebSocket은 브라우저 자체에서 제공합니다. (관련 문서)

하지만 socket.io 라이브러리를 사용하면 WebSocket을 편하게 사용할 수 있습니다.

클라이언트에서 socket.io 라이브러리를 사용하기 위해  cdn 서비스를 사용할 수 있습니다.  즉, 스크립트 태그를 통해서 자바스크립트를 브라우저에서 실행할 수 있는데 아래와 같이 src="https:// ..." 을 통해서 웹 URL로 코드들을 끼워넣어서 사용할 수 있다는 것입니다.

<script src="https://cdn.socket.io/3.1.3/socket.io.min.js" integrity="sha384-cPwlPLvBTa3sKAgddT6krw0cJat7egBga3DJepJyrLl4Q9/5WLra3rrnMcyTyOnh" crossorigin="anonymous"></script>
<script>
const socket = io();
</script>

https://cdn.socket.io/3.1.3/socket.io.min.js 에 들어가면 코드를 확인할 수 있습니다. (코드 뭉치를 삽입한 것이죠)

이와 비슷하게 아래의 코드는 "babel"이라는 코드 뭉치를 URL을 통해서 가져옵니다. "babel" 패키지는 자바스크립트 코드의 브라우저 호환성을 지켜줍니다. 예를들어 최신 자바스크립트 문법인 에로우 문법 (()=>{...}) 등을 구형 브라우저에서도 동작할 수 있도록 도와주는 것이죠. 해당 패키지는 저희 프로젝트를 진행함에 있어서 사실 필요는 없지만 이런게 있다는 느낌으로 삽입하고 넘어갔습니다.

<script src='https://unpkg.com/@babel/standalone/babel.min.js'></script>

또한 아래의 코드는 polyfill로 바벨과 비슷하게 브라우저 호환성을 지켜줍니다. 바벨은 ESNext에서 지원하는 문법을 ES5 문법으로 번역해주지만 ES5에 존재하지 않는 문법(Map, Promise 등)은 번역하지 못합니다. 이를 도와주는 패키지라고 생각하시면 됩니다. 해당 패키지 또한 저희 프로젝트를 진행함에 있어서 필요는 없습니다. (해당 문법을 사용하지 않기 때문에)

<script src='https://polyfill.io/v3/polyfill.min.js?features=default%2Ces2015%2Ces2016%2Ces2017%2Ces2018%2Ces2019'></script>

혹시 이해가 되지 않으시면 추가 보충 강의로 설명해 드리겠습니다. :)

감사합니다!

프로젝트 환경 세팅할 때 최신 노드 버젼을 사용하시는 분들은 참고하셔도 좋을 것 같아요~

2

101

1

DTO에 대한 질문

1

97

2

백엔드 MVC에서 View의 역할은 무엇인가요?

1

111

2

추가 업데이트 관련 건

0

105

2

nest js 버전문제

0

95

2

mongdb 스키마 공식 문서와 형태가 다른 이유 궁금합니다.

0

113

1

라인 끝에 에러 표시(eslint) 때문에 구글 찾아 보니.

0

83

1

전체 고양이 조회 라우터 중 error.message 오류

0

82

1

캡슐화 추가 설명 중 단일책임원칙 관련 질문

0

115

0

42강 고양이끼리 소통 댓글 구현 중 Schema hasn't been registered for model 'comments' 에러 해결

0

86

1

채팅 이슈

0

137

1

모듈이 더 이상 지원하지 않는답니다

0

216

1

오류가 있습니다

0

114

1

import 에서 오류가 납니다

0

131

1

이런 오류가 나옵니다

0

108

1

에러가 발생합니다

0

117

1

프론트 에러 뜨는데 수정 안해주시나요

0

168

1

emit() broadcast.emit() 질문있습니다

0

107

1

서버연결이 안됩니다.

1

408

1

[PM2][ERROR] Command not found

0

528

1

S3에 업로드까지는 성공했는데 사진이 나오지 않습니다.

0

254

1

error_code : Property 'user' does not exist on type 'Request<ParamsDictionary, any, any, ParsedQs, Record<string, any>>'.ts(2339)

0

607

1

jwt를 따로 연습하고 있는데 env를 못읽는 것 같습니다.

0

330

2

Ec2로 안하시는 이유가 있을까요?

0

345

1