일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
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 |
- 알고리즘
- 타입스크립트
- CSS
- 리액트
- HTML
- AWS
- TypeScript
- BFS
- docker
- 이슈
- k8s
- 백준
- next.js
- 블록체인
- 이더리움
- kubernetes
- VUE
- react
- 쿠버네티스
- 클라우드
- 솔리디티
- 웹
- 자바스크립트
- 프론트엔드
- JavaScript
- es6
- 컴퓨터공학
- 파이썬
- 가상화
- 백엔드
- Today
- Total
즐겁게, 코드
noopener 속성으로 Tabnabbing 공격 방어하기 본문
<a>
태그를 활용할 때 새 창에서 페이지를 이동하기 위해서는 target="_blank"
라는 속성을 활용합니다.
<a href="https://www.naver.com/" target="_blank">네이버로 이동!</a>
그런데, 이 속성에 보안 문제가 숨어있다는 사실을 알고 계신가요?
Tabnabbing 공격
window.opener
라는 전역 객체는 현재 창을 열었던 이전 창의 참조를 반환합니다.
그런데 해커들이 기가 막힌 방법을 고안해냈는데요, 이 window.opener
의 location
을 피싱 사이트의 주소로 바꿔치기하는 것입니다. 그러면 원래 사이트는 피싱 사이트로 변하게 되고 사용자는 별 의심 없이 정보를 건네주게 되는 것이죠.
간단 시연
_blank 속성으로 새 탭에서 네이버에 들어간 뒤, 네이버에서 window.opener.location
속성을 조작해 이전 탭을 피싱 사이트로 바꿔치기한 모습입니다.
이렇게 _blank 속성을 활용하면 opener 객체가 생성된다는 점으로 인해 성능과 보안상 취약점이 생기게 되는데요, 이를 극복하기 위한 것이 바로 rel=noopener
속성입니다.
noopener & noreferrer
<a href="https://www.naver.com/" target="_blank" rel="noopener">네이버로 이동!</a>
noopener
속성을 사용하면 새 탭에서 opener를 참조할 수 없게 되는데요, 이러면 보안 문제와 함께 *성능 문제를 함께 해결할 수 있습니다.
(* opener에 참조가 가능할 경우 이전 탭을 항상 지켜보고 있어야 하므로 같은 스레드에서 두 페이지가 동작하게 됩니다.)
추가적인 보안을 위해 noreferrer
속성을 활용할 수도 있는데요, 요청이 어느 오리진으로부터 왔는지에 대한 정보를 담고 있는 referrer
헤더를 숨겨 잠재적인 위협을 방지할 수 있습니다.
하지만 2021년 이후의 브라우저 버전에서는 대부분 링크에 기본적으로 noopener
와 noreferrer
속성이 적용됩니다.
다만 그래도 여러 브라우저를 지원하는 것이 프론트엔드 개발자의 목표이니, target=_blank
속성을 사용할 때는 습관처럼 noopener
속성을 붙여줄 수 있도록 합시다. 😄
TL;DR
- target=_blank
속성은 window.opener
객체를 활용한 Tabnabbing 공격에 노출되어 있다.
- 이를 막기 위해 rel=noopener noreferrer
속성을 추가하자.
'🎨 프론트엔드' 카테고리의 다른 글
리액트와 뷰로 크롬 익스텐션 빌드하기 (0) | 2021.08.05 |
---|---|
강의 추천 : udacity 웹 최적화 기법 강의 (0) | 2021.08.03 |
쿠키? 그거 먹는 건가요? (0) | 2021.02.15 |
웹 페이지 컨텐츠 복사 방지 구현하기 (0) | 2021.02.14 |
HTML의 data- 속성에 대하여 (0) | 2021.02.13 |