hacktricks/forensics/basic-forensic-methodology/partitions-file-systems-carving/ext.md

28 KiB

जानें AWS हैकिंग को शून्य से हीरो तक htARTE (HackTricks AWS Red Team Expert) के साथ!

HackTricks का समर्थन करने के अन्य तरीके:

Ext - Extended Filesystem

Ext2 बूट पार्टीशन जैसे जर्नलिंग नहीं करने वाले पार्टीशनों के लिए सबसे सामान्य फ़ाइल सिस्टम है। Ext3/4 जर्नलिंग हैं और सामान्यत: शेष पार्टीशनों के लिए उपयोग किए जाते हैं।

फ़ाइल सिस्टम में सभी ब्लॉक समूहों का एक ही आकार होता है और यह क्रमशः स्टोर किए जाते हैं। यह करने से कर्नेल को आसानी से डिस्क में एक ब्लॉक समूह की स्थिति का पता लगाने में सहायता मिलती है।

प्रत्येक ब्लॉक समूह में निम्नलिखित जानकारी शामिल होती है:

  • फ़ाइल सिस्टम का सुपरब्लॉक की एक प्रतिलिपि
  • ब्लॉक समूह विवरणकर्ताओं की एक प्रतिलिपि
  • डेटा ब्लॉक बिटमैप जो समूह के अंदर मुक्त ब्लॉकों की पहचान के लिए उपयोग किया जाता है
  • इनोड बिटमैप, जो समूह के अंदर मुक्त इनोड की पहचान के लिए उपयोग किया जाता है
  • इनोड तालिका: यह एक श्रृंखला के रूप में होती है, हर एक में एक पूर्वनिर्धारित आकार का फ़ाइल सिस्टम 1,024 बाइट ब्लॉक में 8 इनोड्स होते हैं, जबकि 4,096-बाइट ब्लॉक में 32 इनोड्स होते हैं। ध्यान दें कि Ext2 में, इनोड नंबर और संबंधित ब्लॉक नंबर के बीच एक मैपिंग स्टोर करने की आवश्यकता नहीं है क्योंकि अंतिम मान ब्लॉक समूह संख्या और इनोड तालिका के अंदर स्थानीय स्थिति से प्राप्त किया जा सकता है। उदाहरण के लिए, मान लें कि प्रत्येक ब्लॉक समूह में 4,096 इनोड होते हैं और हमें डिस्क पर इनोड 13,021 का पता लगाना है। इस मामले में, इनोड तीसरे ब्लॉक समूह का है और इसका डिस्क पता संबंधित इनोड तालिका के 733 वें प्रविष्टि में संग्रहीत है। जैसा कि आप देख सकते हैं, इनोड नंबर केवल एक कुंजी है जिसका उपयोग Ext2 रूटीनों द्वारा त्वरित रूप से डिस्क पर उचित इनोड विवरणकर्ता प्राप्त करने के लिए किया जाता है
  • फ़ाइलें रखने वाले डेटा ब्लॉक। कोई भी ब्लॉक जिसमें कोई अर्थपूर्ण जानकारी नहीं है, उसे मुक्त कहा जाता है।

Ext वैकल्पिक विशेषताएँ

विशेषताएँ प्रभावित करती हैं कि डेटा कहाँ स्थित है, कैसे डेटा इनोड में स्टोर किया जाता है और कुछ उनमें से अतिरिक्त मेटाडेटा प्रदान कर सकती हैं, इसलिए विशेषताएँ Ext में महत्वपूर्ण हैं।

Ext में ऐसी वैकल्पिक विशेषताएँ हैं जिन्हें आपका ओएस समर्थन कर सकता है या नहीं, तीन संभावनाएँ हैं:

  • संगत
  • असंगत
  • संगत केवल पढ़ने के लिए: इसे माउंट किया जा सकता है लेकिन लेखन के लिए नहीं

यदि असंगत विशेषताएँ हैं तो आप फ़ाइल सिस्टम को माउंट नहीं कर पाएंगे क्योंकि ओएस नहीं जानेगा कि डेटा तक पहुंचने का तरीका क्या है।

{% hint style="info" %} संदिग्ध हमलावर के पास गैर-मानक विस्तार हो सकता है {% endhint %}

कोई भी उपयोगी जो सुपरब्लॉक को पढ़ता है, एक Ext फ़ाइल सिस्टम की विशेषताएँ दिखा सकता है, लेकिन आप file -sL /dev/sd* का भी उपयोग कर सकते हैं।

सुपरब्लॉक

सुपरब्लॉक प्रारंभ से पहले 1024 बाइट है और प्रत्येक समूह के पहले ब्लॉक में दोहराया गया है और इसमें निम्नलिखित शामिल है:

  • ब्लॉक आकार
  • कुल ब्लॉक
  • ब्लॉक प्रति ब्लॉक समूह
  • पहले ब्लॉक समूह से पहले आरक्षित ब्लॉक
  • कुल इनोड
  • इनोड प्रति ब्लॉक समूह
  • वॉल्यूम नाम
  • अंतिम लेखन समय
  • अंतिम माउंट समय
  • फ़ाइल सिस्टम को अंतिम बार कहाँ माउंट किया गया था
  • फ़ाइल सिस्टम स्थिति (साफ?)

इस जानकारी को एक Ext फ़ाइल सिस्टम फ़ाइल से प्राप्त करना संभव है:

fsstat -o <offsetstart> /pat/to/filesystem-file.ext
#You can get the <offsetstart> with the "p" command inside fdisk

आप नि:शुल्क GUI एप्लिकेशन भी उपयोग कर सकते हैं: https://www.disk-editor.org/index.html
या आप python का भी उपयोग कर सकते हैं सुपरब्लॉक जानकारी प्राप्त करने के लिए: https://pypi.org/project/superblock/

इनोड्स

इनोड्स में ब्लॉकों की सूची होती है जो फ़ाइल के वास्तविक डेटा को सम्मिलित करती है।
अगर फ़ाइल बड़ी है, और इनोड अन्य इनोड्स के लिंक कर सकता है जो ब्लॉक/अधिक इनोड्स की ओर इशारा करते हैं जो फ़ाइल डेटा को सम्मिलित करते हैं।

Ext2 और Ext3 में इनोड्स का आकार 128B है, Ext4 वर्तमान में 156B का उपयोग करता है लेकिन भविष्य में विस्तार की अनुमति देने के लिए डिस्क पर 256B का आवंटन करता है।

इनोड संरचना:

ऑफसेट आकार नाम विवरणF
0x0 2 फ़ाइल मोड फ़ाइल मोड और प्रकार
0x2 2 UID मालिक ID के निचले 16 बिट
0x4 4 आकार इल फ़ाइल के आकार के निचले 32 बिट
0x8 4 Atime एपॉक से सेकंड में पहुंच का समय
0xC 4 Ctime एपॉक से सेकंड में परिवर्तन का समय
0x10 4 Mtime एपॉक से सेकंड में संशोधन का समय
0x14 4 Dtime एपॉक से सेकंड में हटाने का समय
0x18 2 GID समूह ID के निचले 16 बिट
0x1A 2 Hlink count हार्ड लिंक गणना
0xC 4 ब्लॉक्स आईओ ब्लॉक गणना के निचले 32 बिट
0x20 4 ध्वज ध्वज
0x24 4 यूनियन osd1 लिनक्स: I संस्करण
0x28 69 ब्लॉक[15] 15 डेटा ब्लॉक की ओर इशारा करता है
0x64 4 संस्करण NFS के लिए फ़ाइल संस्करण
0x68 4 फ़ाइल एसीएल लो विस्तारित विशेषताएँ के निचले 32 बिट (ACL, आदि)
0x6C 4 फ़ाइल आकार हाई फ़ाइल के आकार के ऊपरी 32 बिट (केवल ext4)
0x70 4 विघटित फ्रेगमेंट एक पुराना फ्रेगमेंट पता
0x74 12 Osd 2 दूसरा ऑपरेटिंग सिस्टम निर्भर संघ
0x74 2 ब्लॉक्स हाई ब्लॉक गणना के ऊपरी 16 बिट
0x76 2 फ़ाइल एसीएल हाई विस्तारित विशेषताएँ के ऊपरी 16 बिट (ACL, आदि)
0x78 2 UID हाई मालिक ID के ऊपरी 16 बिट
0x7A 2 GID हाई समूह ID के ऊपरी 16 बिट
0x7C 2 चेकसम आईओ इनोड चेकसम के निचले 16 बिट

"संशोधित" वह समय है जिस समय फ़ाइल की सामग्री को संशोधित किया गया है। इसे अक्सर "मॉटाइम" कहा जाता है।
"परिवर्तन" वह समय है जिस समय फ़ाइल का इनोड परिवर्तित किया गया है, जैसे अनुमतियाँ बदलना, स्वामित्व, फ़ाइल का नाम, और हार्ड लिंक की संख्या। इसे अक्सर "सीटाइम" कहा जाता है।

इनोड संरचना विस्तारित (Ext4):

ऑफसेट आकार नाम विवरण
0x80 2 अतिरिक्त आकार मानक 128 से अतिरिक्त कितने बाइट उपयोग किए गए हैं
0x82 2 चेकसम हाई इनोड चेकसम के ऊपरी 16 बिट
0x84 4 सीटाइम अतिरिक्त परिवर्तन समय अतिरिक्त बिट
0x88 4 मॉटाइम अतिरिक्त संशोधन समय अतिरिक्त बिट
0x8C 4 एक्सेस टाइम अतिरिक्त पहुंच का समय अतिरिक्त बिट
0x90 4 क्रिएट टाइम फ़ाइल निर्माण का समय (एपॉक से सेकंड)
0x94 4 क्रिएट टाइम अतिरिक्त फ़ाइल निर्माण का अतिरिक्त बिट
0x98 4 संस्करण हाई संस्करण के ऊपरी 32 बिट
0x9C अप्रयुक्त भविष्य के विस्तार के लिए रिजर्व्ड स्थान

विशेष इनोड्स:

इनोड विशेष उद्देश्य
0 ऐसा कोई इनोड नहीं है, गणना 1 से शुरू होती है
1 विकृत ब्लॉक सूची
2 रूट निर्देशिका
3 उपयोगकर्ता कोटा
4 समूह कोटा
5 बूट लोडर
6 डिलीट निर्देशिका
7 रिजाइज़ करने के लिए आरक्षित समूह विवरण (फ़ाइल सिस्टम का आकार बदलने के लिए)
8 जर्नल
9 इनोड को असमाविष्ट करें (स्नैपशॉट के लिए)
10 रिप्लिका इनोड
11 पहला गैर-रिजर्व इनोड (अक्सर खो जाता है + मिला हुआ)

{% hint style="info" %} ध्यान दें कि निर्माण समय केवल Ext4 में ही प्रकट होता है। {% endhint %}

इनोड नंबर जानकर आप आसानी से इसका सूचकांक पा सकते हैं:

  • वहाँ एक इनोड का समूह जिसमें एक इनोड शामिल है: (इनोड नंबर - 1) / (इनोड्स प्रति समूह)
  • इसके समूह में इंडेक्स: (इनोड नंबर - 1) mod(इनोड/समूह)
  • इनोड तालिका में ऑफसेट: इनोड नंबर * (इनोड आकार)
  • "-1" इसलिए है क्योंकि इनोड 0 परिभाषित नहीं है (उपयोग नहीं होता)
ls -ali /bin | sort -n #Get all inode numbers and sort by them
stat /bin/ls #Get the inode information of a file
istat -o <start offset> /path/to/image.ext 657103 #Get information of that inode inside the given ext file
icat -o <start offset> /path/to/image.ext 657103 #Cat the file

फ़ाइल मोड

संख्या विवरण
15 रेग/स्लिंक-13/सॉकेट-14
14 डायरेक्टरी/ब्लॉक बिट 13
13 चार डिवाइस/ब्लॉक बिट 14
12 FIFO
11 सेट UID
10 सेट GID
9 स्टिकी बिट (इसके बिना, किसी भी व्यक्ति जिसके पास डायरेक्टरी पर लेखन और क्रियान्वयन अनुमतियाँ हैं, फ़ाइलें हटा सकता और नाम बदल सकता है)
8 मालिक पढ़ें
7 मालिक लिखें
6 मालिक क्रियान्वयन
5 समूह पढ़ें
4 समूह लिखें
3 समूह क्रियान्वयन
2 अन्य व्यक्ति पढ़ें
1 अन्य व्यक्ति लिखें
0 अन्य व्यक्ति क्रियान्वयन

बोल्ड बिट्स (12, 13, 14, 15) दर्शाते हैं कि फ़ाइल किस प्रकार की है (एक डायरेक्टरी, सॉकेट...) केवल बोल्ड विकल्पों में से एक हो सकता है।

डायरेक्टरी

ऑफसेट आकार नाम विवरण
0x0 4 इनोड
0x4 2 रेक लेन रेकॉर्ड लंबाई
0x6 1 नाम लंबाई नाम लंबाई
0x7 1 फ़ाइल प्रकार

0x00 अज्ञात
0x01 नियमित

0x02 निर्देशक

0x03 चार डिवाइस

0x04 ब्लॉक डिवाइस

0x05 FIFO

0x06 सॉकेट

0x07 सिम लिंक

0x8 नाम नाम स्ट्रिंग (अधिकतम 255 वर्ण)

प्रदर्शन बढ़ाने के लिए, रूट हैश डायरेक्टरी ब्लॉक का उपयोग किया जा सकता है।

विस्तारित गुण

किया जा सकता है

  • इनोड्स के बीच अतिरिक्त जगह (256 - इनोड का आकार, सामान्यत: = 100)
  • इनोड में फ़ाइल_एसीएल के द्वारा संकेतित डेटा ब्लॉक

उपयोग किया जा सकता है कुछ भी यदि नाम "उपयोगकर्ता" से शुरू होता है। इस तरह से डेटा छुपाया जा सकता है।

विस्तारित गुण प्रविष्टियाँ

ऑफसेट आकार नाम विवरण
0x0 1 नाम लंबाई गुण के नाम की लंबाई
0x1 1 नाम सूची

0x0 = कोई उपसर्ग नहीं

0x1 = उपयोगकर्ता। उपसर्ग

0x2 = सिस्टम.पॉसिक्स_एसीएल_एक्सेस

0x3 = सिस्टम.पॉसिक्स_एसीएल_डिफ़ॉल्ट

0x4 = विश्वसनीय।

0x6 = सुरक्षा।

0x7 = सिस्टम।

0x8 = सिस्टम.रिचेक्ल

0x2 2 मूल्य ऑफस पहले इनोड प्रविष्टि या ब्लॉक की शुरुआत से अंतर
0x4 4 मूल्य ब्लॉक्स मूल्य संग्रहित किया गया डिस्क ब्लॉक या इस ब्लॉक के लिए शून्य
0x8 4 मूल्य आकार मूल्य की लंबाई
0xC 4 हैश ब्लॉक में गुणों के लिए हैश या अगर इनोड में है तो शून्य
0x10 नाम गुण का नाम बिना अंतिम नल वाला
setfattr -n 'user.secret' -v 'This is a secret' file.txt #Save a secret using extended attributes
getfattr file.txt #Get extended attribute names of a file
getdattr -n 'user.secret' file.txt #Get extended attribute called "user.secret"

फ़ाइल सिस्टम दृश्य

फ़ाइल सिस्टम की सामग्री देखने के लिए, आप मुफ्त उपकरण का उपयोग कर सकते हैं: https://www.disk-editor.org/index.html
या आप इसे अपने लिनक्स में mount कमांड का उपयोग करके माउंट कर सकते हैं।

https://piazza.com/class_profile/get_resource/il71xfllx3l16f/inz4wsb2m0w2oz#:~:text=The%20Ext2%20file%20system%20divides,lower%20average%20disk%20seek%20time.