inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

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

XSS를 방지하기 위해 NESTJS에서 설정할 수 있는 것들이 있을까요?

599

젊음의돌

작성한 질문수 4

2

현재 개발 중인 서비스가 XSS 공격에 취약하여 이를 방지하기 위한 NESTJS에서 할 수 있는 부분이 있을까 궁금합니다. 

NestJS ssr nodejs express mongodb

답변 1

1

김건탁

안녕하세요, 젊음의돌님.
남겨주신 질문에 대한 답변 드립니다.

우선 XSS 보안 취약점을 보완할 수 있는 방법은 [파이프(Pipe)를 활용하는 방법, 라이브러리를 활용하는 방법, 가장 기본적으로 보완할 수 있는 방법]이렇게 크게 3가지가 있습니다.

(1) Pipe
Pipe는 공식문서에 아래와 같이 작성되어 있습니다.

pipes operate on the arguments being processed by a controller route handler

파이프는 컨트롤러에 요청이 동작하기 전에 동작하는 기능입니다.
즉, 컨트롤러에서 XSS 보안 문제를 일으킬 수 있는 사용자의 입력값을 Pipe에서 필터링 등을 통해 XSS 취약점을 보완할 수 있습니다. 더 자세한 내용은 공식문서 참고바랍니다.

(2) 라이브러리 활용
Node 생태계에 존재하는 여럿 보안 취약점들을 대비해 많은 라이브러리들이 개발되고 있습니다. 그 중에서 helmet이라는 라이브러리를 추천드립니다. helmet은 사용 방법이 아주 쉬워서 개발하고 계시는 서비스에 적용하기에 부담스럽지 않으실 것 같습니다. helmet의 자세한 설명은 공식문서 참고바랍니다.

(3) 가장 기본적인 보완할 수 있는 방법
사용자의 입력값을 먼저 필터링 하여 보안 취약점을 보완할 수 있는 방법입니다.

{사용자의 입력값}.replace(
      /\<|\>|\"|\'|\%|\;|\(|\)|\&|\+|\-/g,
      "",
    )

위 코드와 같이 사용자의 입력값에 XSS를 발생시킬 수 있는 부분을 먼저 공백으로 치환하여 보완할 수 있는 방법이 있습니다. 가장 기본적인 방법인만큼, 이를 뚫을 수 있는 방법도 많기에 추천드리지는 않습니다.

답변에 대해 더 궁금하신 사항이 있으시다면, 새로운 질문글로 작성해주시면 답변해 드리도록 하겠습니다.
감사합니다 🦦

 

0

젊음의돌

깔끔한 답변 감사드립니다. 한 번 적용해보도록 하겠습니다.

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

2

103

1

DTO에 대한 질문

1

99

2

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

1

112

2

추가 업데이트 관련 건

0

106

2

nest js 버전문제

0

97

2

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

0

113

1

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

0

84

1

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

0

82

1

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

0

115

0

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

0

86

1

채팅 이슈

0

140

1

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

0

216

1

오류가 있습니다

0

114

1

import 에서 오류가 납니다

0

132

1

이런 오류가 나옵니다

0

110

1

에러가 발생합니다

0

117

1

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

0

169

1

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

0

109

1

서버연결이 안됩니다.

1

408

1

[PM2][ERROR] Command not found

0

530

1

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

0

256

1

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

0

608

1

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

0

331

2

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

0

346

1