티스토리 뷰

express

express helmet 적용과 설명

kOsari 2023. 6. 4. 22:59

Helmet이란 ?

Express 사용시 Http 헤더 설정을 자동으로 바꾸어 웹 취약성으로부터 서버 보호해주는 보안 모듈입니다.

 

Helmet 설치

npm install helmet --save

다음과 같이 입력해 Helmet을 설치한다.

 

 

Helmet 사용

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

app.use(helmet());

 

단 helmet의 경우 설정을 하지 않을 경우 기본적인 보안만 설정한다. 

추가로 사용하기 위해선 다음과 같이 적용해야 한다.

app.use(helmet.noCache());
app.use(helmet.frameguard());

 

또 다음과 같이 기본적으로 실행되는 미들웨어를 없앨 수도 있다.

app.use(
  helmet({
    frameguard: false,
  })
);

 

Helmet에 포함된 9가지의 미들웨어

csp

csp Content-Security-Policy이다. 브라우저에서 사용하는 컨텐츠 기반의 보안 정책으로 XSS Data Injection, Click Jacking 등 웹 페이지에 악성 스크립트를 삽입하는 공격기법들을 막기 위해 사용된다.

 

hidePoweredBy

헤더에서 X-Powered-By를 제거한다. 이는 서버에 대한 정보를 제공해주는 역할로 나 같은 경우는 이 영역에 Express라고 표기됨을 확인할 수 있었다. 이 정보는 악의적으로 활용될 가능성이 높기에 헬멧을 통해서 제거해 주는 것이 좋다.

 

HPKP

Public Key Pinning 헤더를 추가하여, 위조된 인증서를 이용한 중간자 공격 을방지한다.

 

HSTS

HTTP Strict Transport Security의 약자로 웹 사이트에 접속할 때 강제적으로 HTTPS로 접속하게 강제하는 기능이다. 
사용자가 특정 사이트에 접속할 때 해당 사이트가 HTTPS를 지원하는지, 하지 않는지를 미리 모르는 경우가 대부분이다. 그렇기에 브라우저는 디폴트로 HTTP로 먼저 접속을 시도한다. 이때 HTTPS로 지원되는 사이트였다면 301Redirect 302 Redirect를 응답하여 HTTPS로 다시 접속하도록 한다.

하지만 이때 해커 중간자 공격을 하여, 중간에 프록시 서버를 두고
[나] <-> [해커] 사이에서는 HTTP 통신을 하고 [해커] <-> [웹사이트] 사이에선 HTTPS 통신을 한다면,
우리의 개인정보가 HTTP 프로토콜을 통해 해커에게로 전해지는 참사가 일어난다.
이러한 공격을 SSL Stripping이라고 하며 이런 공격을 방지하기 위해 HSTS를 설정한다.

 

IeNoOpen

IE8 이상에 대해 X-Download-Options를 설정한다. 이 옵션은 8 버전 이상의 인터넷 익스플로러에서 다운로드된 것들을 바로 여는 것 대신 저장부터 하는 옵션이다. 사용자는 저장부터 하고 다른 응용프로그램에서 열어야 한다.

 

noCache

Cache-Control  Pragma 헤더를 설정하여 클라이언트 측에서 캐싱을 사용하지 않도록 하는 설정이다. 

 

noSniff

X-Content-Type-Options 를 설정하여 선언된 콘텐츠 유형으로부터 벗어난 응답에 대한 브라우저의 MIME 스니핑을 방지한다. MIME이란 Multipurpose Internet Mail Extensions의 약자로 클라이언트에게 전송된 문서의 다양성을 알려주기 위한 포맷이다. 브라우저는 리소스를 내려받을 때 MIME 타입을 보고 동작하기에 정확한 설정이 중요하다.

MIME 스니핑이란 브라우저가 특정 파일을 읽을 때 파일의 실제 내용과 Content-Type에 설정된 내용이 다르면 파일로 부터 형식을 추측하여 실행하는 것인데, 편리함을 위한 기능이지만 공격자에게 악용 될 가능성이 있다.

 

frameguard

X-Frame-Options 헤더를 설정하여 클릭재킹에 대한 보호를 제공한다.
클릭재킹이란 사용자가 자신이 클릭하고 있다고 인지하는 것과 다른 것을 클릭하도록 하여 속이는 해킹 기법이다. 속이기 위해 보이지 않는 레이어에 보이지 않는 버튼을 만드는 방법이 있다.

 

xssFilter

X-XSS-Protection을 설정하여 대부분의 최신 웹 브라우저에서 XSS(Cross-site scripting) 필터를 사용하도록 합니다.

'express' 카테고리의 다른 글

express 비동기 처리  (0) 2023.06.04
aws 지역이동  (0) 2023.06.04
express mysql 연동  (0) 2023.06.04
vue express 연동  (0) 2023.06.04
REST API  (0) 2023.05.28
공지사항
최근에 올라온 글
최근에 달린 댓글
Total
Today
Yesterday
링크
«   2025/07   »
1 2 3 4 5
6 7 8 9 10 11 12
13 14 15 16 17 18 19
20 21 22 23 24 25 26
27 28 29 30 31
글 보관함