.. | ||
file-data-carving-recovery-tools.md | ||
file-data-carving-tools.md | ||
README.md |
Sehemu za Diski/Mifumo ya Faili/Carving
Jifunze AWS hacking kutoka sifuri hadi shujaa na htARTE (HackTricks AWS Red Team Expert)!
Njia nyingine za kusaidia HackTricks:
- Ikiwa unataka kuona kampuni yako ikitangazwa kwenye HackTricks au kupakua HackTricks kwa PDF Angalia MIPANGO YA USAJILI!
- Pata bidhaa rasmi za PEASS & HackTricks
- Gundua Familia ya PEASS, mkusanyiko wetu wa NFTs za kipekee
- Jiunge na 💬 Kikundi cha Discord au kikundi cha telegram au tufuate kwenye Twitter 🐦 @hacktricks_live.
- Shiriki mbinu zako za udukuzi kwa kuwasilisha PRs kwa HackTricks na HackTricks Cloud repos za github.
Sehemu
Diski ngumu au diski ya SSD inaweza kuwa na sehemu tofauti na lengo la kutenganisha data kimwili.
Kitengo cha chini cha diski ni sektori (kawaida inajumuisha 512B). Kwa hivyo, ukubwa wa kila sehemu unahitaji kuwa maradufu ya ukubwa huo.
MBR (Rekodi ya Mwanzo ya Boot)
Imetengwa katika sektori ya kwanza ya diski baada ya 446B ya msimbo wa boot. Sekta hii ni muhimu kwa kuelekeza PC ni nini na kutoka wapi sehemu inapaswa kufungwa.
Inaruhusu hadi sehemu 4 (angalau moja tu inaweza kuwa inayoweza kuanzishwa). Walakini, ikiwa unahitaji sehemu zaidi unaweza kutumia sehemu zilizopanuliwa. Bayt ya mwisho ya sektori hii ya kwanza ni saini ya rekodi ya boot 0x55AA. Sehemu moja tu inaweza kuwa imeorodheshwa kama inayoweza kuanzishwa.
MBR inaruhusu max 2.2TB.
Kutoka kwa bayti 440 hadi 443 za MBR unaweza kupata Sahihi ya Diski ya Windows (ikiwa Windows inatumika). Barua ya kisasa ya diski ngumu inategemea Saini ya Diski ya Windows. Kubadilisha saini hii inaweza kuzuia Windows kuanza (zana: Mhariri wa Diski ya Active).
Muundo
Offset | Urefu | Kitu |
---|---|---|
0 (0x00) | 446(0x1BE) | Msimbo wa Boot |
446 (0x1BE) | 16 (0x10) | Sehemu ya Kwanza |
462 (0x1CE) | 16 (0x10) | Sehemu ya Pili |
478 (0x1DE) | 16 (0x10) | Sehemu ya Tatu |
494 (0x1EE) | 16 (0x10) | Sehemu ya Nne |
510 (0x1FE) | 2 (0x2) | Saini 0x55 0xAA |
Muundo wa Rekodi ya Sehemu
Offset | Urefu | Kitu |
---|---|---|
0 (0x00) | 1 (0x01) | Bendera ya Kazi (0x80 = inayoweza kuanzishwa) |
1 (0x01) | 1 (0x01) | Kichwa cha Kuanza |
2 (0x02) | 1 (0x01) | Sekta ya Kuanza (bits 0-5); bayti za juu za silinda (6- 7) |
3 (0x03) | 1 (0x01) | Silinda ya Kuanza ya chini |
4 (0x04) | 1 (0x01) | Nambari ya aina ya sehemu (0x83 = Linux) |
5 (0x05) | 1 (0x01) | Kichwa cha Mwisho |
6 (0x06) | 1 (0x01) | Sekta ya Mwisho (bits 0-5); bayti za juu za silinda (6- 7) |
7 (0x07) | 1 (0x01) | Silinda ya Mwisho ya chini |
8 (0x08) | 4 (0x04) | Sekta zilizotangulia sehemu (kidogo kwa kidogo) |
12 (0x0C) | 4 (0x04) | Sekta katika sehemu |
Ili kufunga MBR kwenye Linux kwanza unahitaji kupata kianzishaji wa kuanza (unaweza kutumia fdisk
na amri ya p
)
Na kisha tumia msimbo ufuatao
#Mount MBR in Linux
mount -o ro,loop,offset=<Bytes>
#63x512 = 32256Bytes
mount -o ro,loop,offset=32256,noatime /path/to/image.dd /media/part/
LBA (Logical block addressing)
Ukarabati wa kibao cha mantiki (LBA) ni mpango wa kawaida unaotumika kwa kutaja mahali pa vitalu vya data vilivyohifadhiwa kwenye vifaa vya kuhifadhi vya kompyuta, kwa ujumla mifumo ya kuhifadhi ya sekondari kama vile diski ngumu. LBA ni mpango wa kutaja wa moja kwa moja wa linear; vitalu hupatikana kwa kiashiria cha nambari ya kima cha nambari, na kibao cha kwanza kikiwa LBA 0, kibao cha pili LBA 1, na kadhalika.
GPT (Mwongozo wa Jedwali la Sehemu)
Mwongozo wa Jedwali la Sehemu, unaojulikana kama GPT, unapendelewa kwa uwezo wake ulioboreshwa ikilinganishwa na MBR (Rekodi ya Kwanza ya Kuanza). Kipekee kwa kitambulisho cha kipekee duniani kwa sehemu, GPT inaonekana katika njia kadhaa:
- Mahali na Ukubwa: GPT na MBR zinaanza katika sehemu 0. Walakini, GPT inafanya kazi kwa biti 64, ikilinganishwa na biti 32 za MBR.
- Vikwazo vya Sehemu: GPT inasaidia hadi sehemu 128 kwenye mifumo ya Windows na inaweza kuhifadhi hadi 9.4ZB ya data.
- Majina ya Sehemu: Inatoa uwezo wa kuita sehemu kwa hadi wahusika wa Unicode 36.
Uimara na Uokoaji wa Data:
- Udhibitishaji: Tofauti na MBR, GPT haifungi upangaji wa sehemu na data ya kuanza kwenye sehemu moja. Inarejesha data hii kote kwenye diski, ikiboresha uadilifu na uimara wa data.
- Uchunguzi wa Redundancy wa Mzunguko (CRC): GPT inatumia CRC kuhakikisha uadilifu wa data. Inachunguza kwa uangalifu uharibifu wa data, na ikigunduliwa, GPT inajaribu kurejesha data iliyoharibika kutoka kwenye eneo lingine la diski.
MBR ya Kinga (LBA0):
- GPT inaendeleza utangamano wa nyuma kupitia MBR ya kinga. Kipengele hiki kinaishi katika nafasi ya MBR ya urithi lakini imeundwa kuzuia programu za zamani za MBR kwa makosa kuharibu diski zilizo na GPT, hivyo kulinda uadilifu wa data kwenye diski zilizo na GPT.
MBR ya Kihybridi (LBA 0 + GPT)
Katika mifumo ya uendeshaji inayounga mkono kuanza kwa GPT kupitia huduma za BIOS badala ya EFI, sekta ya kwanza inaweza pia kutumika kuhifadhi hatua ya kwanza ya msimbo wa kuanza wa bootloader, lakini imebadilishwa kutambua sehemu za GPT. Bootloader katika MBR haitakiwi kudhani ukubwa wa sekta ni 512 biti.
Kichwa cha Jedwali la Sehemu (LBA 1)
Kichwa cha jedwali la sehemu hufafanua vitalu vinavyoweza kutumika kwenye diski. Pia hufafanua idadi na ukubwa wa vipengele vya sehemu vinavyounda jedwali la sehemu (offsets 80 na 84 kwenye jedwali).
Offset | Urefu | Yaliyomo |
---|---|---|
0 (0x00) | 8 biti | Saini ("EFI PART", 45h 46h 49h 20h 50h 41h 52h 54h au 0x5452415020494645ULL kwenye mashine za little-endian) |
8 (0x08) | 4 biti | Mapitio 1.0 (00h 00h 01h 00h) kwa UEFI 2.8 |
12 (0x0C) | 4 biti | Ukubwa wa kichwa kwa mtindo wa little-endian (kwa biti, kawaida 5Ch 00h 00h 00h au 92 biti) |
16 (0x10) | 4 biti | CRC32 ya kichwa (offset +0 hadi ukubwa wa kichwa) kwa mtindo wa little-endian, na uga huu ukiwekwa sifuri wakati wa kuhesabu |
20 (0x14) | 4 biti | Imehifadhiwa; lazima iwe sifuri |
24 (0x18) | 8 biti | LBA ya Sasa (eneo la nakala hii ya kichwa) |
32 (0x20) | 8 biti | LBA ya Kurejesha (eneo la nakala nyingine ya kichwa) |
40 (0x28) | 8 biti | LBA ya kwanza inayoweza kutumika kwa sehemu (jedwali la sehemu la msingi la mwisho LBA + 1) |
48 (0x30) | 8 biti | LBA ya mwisho inayoweza kutumika (jedwali la sehemu la sekondari la kwanza LBA − 1) |
56 (0x38) | 16 biti | GUID ya Diski kwa mtindo wa mchanganyiko |
72 (0x48) | 8 biti | Kuanza LBA ya safu ya vipengele vya sehemu (daima 2 kwenye nakala ya msingi) |
80 (0x50) | 4 biti | Idadi ya vipengele vya sehemu kwenye safu |
84 (0x54) | 4 biti | Ukubwa wa kipengele kimoja cha sehemu (kawaida 80h au 128) |
88 (0x58) | 4 biti | CRC32 ya safu ya vipengele vya sehemu kwa mtindo wa little-endian |
92 (0x5C) | * | Imehifadhiwa; lazima iwe sifuri kwa sehemu iliyobaki (420 biti kwa ukubwa wa sekta ya 512 biti; lakini inaweza kuwa zaidi na ukubwa mkubwa wa sekta) |
Vipengele vya Sehemu (LBA 2–33)
Muundo wa Kuingia wa Sehemu ya GUID | ||
---|---|---|
Offset | Urefu | Yaliyomo |
0 (0x00) | 16 biti | GUID ya aina ya sehemu (mchanganyiko wa mchanganyiko) |
16 (0x10) | 16 biti | GUID ya sehemu ya kipekee (mchanganyiko wa mchanganyiko) |
32 (0x20) | 8 biti | LBA ya Kwanza (little-endian) |
40 (0x28) | 8 biti | LBA ya Mwisho (pamoja, kawaida ni namba ya kipekee) |
48 (0x30) | 8 biti | Bendera za sifa (k.m. biti 60 inaonyesha kusoma tu) |
56 (0x38) | 72 biti | Jina la sehemu (36 UTF-16LE vitengo vya nambari) |
Aina za Sehemu
Aina zaidi za sehemu katika https://en.wikipedia.org/wiki/GUID_Partition_Table
Ukaguzi
Baada ya kufunga picha ya uchunguzi na ArsenalImageMounter, unaweza kukagua sekta ya kwanza ukitumia zana ya Windows Active Disk Editor. Katika picha ifuatayo, MBR iligunduliwa kwenye sehemu 0 na kufafanuliwa:
Ikiwa ilikuwa jedwali la GPT badala ya MBR inapaswa kuonekana saini EFI PART kwenye sehemu 1 (ambayo kwenye picha iliyotangulia iko wazi).
Mifumo ya Faili
Orodha ya mifumo ya faili ya Windows
- FAT12/16: MSDOS, WIN95/98/NT/200
- FAT32: 95/2000/XP/2003/VISTA/7/8/10
- ExFAT: 2008/2012/2016/VISTA/7/8/10
- NTFS: XP/2003/2008/2012/VISTA/7/8/10
- ReFS: 2012/2016
FAT
FAT (File Allocation Table) mfumo wa faili umebuniwa karibu na sehemu yake kuu, jedwali la kugawanya faili, lililowekwa mwanzoni mwa kiasi. Mfumo huu unalinda data kwa kudumisha nakala mbili za jedwali, ikihakikisha usalama wa data hata kama moja imeharibika. Jedwali, pamoja na folda ya mizizi, lazima iwe katika eneo lililofungwa, muhimu kwa mchakato wa kuanza kwa mfumo.
Kitengo cha msingi cha kuhifadhi cha mfumo wa FAT ni kluster, kawaida 512B, ikijumuisha sehemu nyingi. FAT imeendelea kupitia toleo:
- FAT12, ikiunga mkono anwani za kluster za biti 12 na kushughulikia hadi kluster 4078 (4084 na UNIX).
- FAT16, ikiboresha hadi anwani za biti 16, hivyo kuhifadhi hadi kluster 65,517.
- FAT32, ikisonga mbele zaidi na anwani za biti 32, kuruhusu kluster 268,435,456 za kuvutia kwa kiasi.
Kizuizi kikubwa kote kwenye toleo za FAT ni ukubwa wa faili wa 4GB, uliowekwa na uga wa biti 32 uliotumika kuhifadhi ukubwa wa faili.
Vipengele muhimu vya saraka ya mizizi, haswa kwa FAT12 na FAT16, ni pamoja na:
- Jina la Faili/Folda (hadi wahusika 8)
- Sifa
- Tarehe za Uundaji, Kubadilisha, na Kupata Mwisho
- Anwani ya Jedwali la FAT (inayoonyesha kluster ya kuanza ya faili)
- Ukubwa wa Faili
EXT
Ext2 ndio mfumo wa faili wa kawaida zaidi kwa partisheni zisizo na journaling (partisheni ambazo hazibadiliki sana) kama partisheni ya boot. Ext3/4 ni journaling na hutumiwa kawaida kwa partisheni zilizobaki.
Metadata
Baadhi ya faili zina metadata. Taarifa hii ni kuhusu maudhui ya faili ambayo mara nyingine inaweza kuwa ya kuvutia kwa mchambuzi kwani kulingana na aina ya faili, inaweza kuwa na taarifa kama:
- Kichwa
- Toleo la MS Office lililotumika
- Mwandishi
- Tarehe za uundaji na ubadilishaji wa mwisho
- Mfano wa kamera
- Vihisishi vya GPS
- Taarifa ya Picha
Unaweza kutumia zana kama exiftool na Metadiver kupata metadata ya faili.
Uokoaji wa Faili Zilizofutwa
Faili Zilizofutwa Zilizosajiliwa
Kama ilivyoonekana hapo awali kuna sehemu kadhaa ambapo faili bado imehifadhiwa baada ya "kufutwa". Hii ni kwa sababu kawaida kufuta faili kutoka kwa mfumo wa faili kunaiweka kama imefutwa lakini data haijaguswa. Kisha, inawezekana kuangalia usajili wa faili (kama MFT) na kupata faili zilizofutwa.
Pia, OS kawaida huihifadhi habari nyingi kuhusu mabadiliko ya mfumo wa faili na nakala rudufu, hivyo inawezekana kujaribu kuzitumia kurejesha faili au habari nyingi iwezekanavyo.
{% content-ref url="file-data-carving-recovery-tools.md" %} file-data-carving-recovery-tools.md {% endcontent-ref %}
Uchongaji wa Faili
Uchongaji wa faili ni mbinu inayojaribu kupata faili katika data nyingi. Kuna njia 3 kuu ambazo zana kama hizi hufanya kazi: Kulingana na vichwa na miguu ya aina za faili, kulingana na miundo ya aina za faili na kulingana na maudhui yenyewe.
Tafadhali kumbuka kuwa mbinu hii haitafaulu kurejesha faili zilizovunjika. Ikiwa faili haipo katika sehemu za mfululizo, basi mbinu hii haitaweza kuipata au angalau sehemu yake.
Kuna zana kadhaa unazoweza kutumia kwa Uchongaji wa Faili ukionyesha aina za faili unazotaka kutafuta
{% content-ref url="file-data-carving-recovery-tools.md" %} file-data-carving-recovery-tools.md {% endcontent-ref %}
Uchongaji wa Mizizi ya Data
Uchongaji wa Mizizi ya Data ni sawa na Uchongaji wa Faili lakini badala ya kutafuta faili kamili, inatafuta vipande vya kuvutia vya habari.
Kwa mfano, badala ya kutafuta faili kamili inayohifadhi URL zilizosajiliwa, mbinu hii itatafuta URL.
{% content-ref url="file-data-carving-recovery-tools.md" %} file-data-carving-recovery-tools.md {% endcontent-ref %}
Kufuta kwa Usalama
Kwa dhahiri, kuna njia za kufuta faili kwa usalama na sehemu za kumbukumbu kuhusu hizo. Kwa mfano, inawezekana kubadilisha maudhui ya faili na data ya taka mara kadhaa, kisha iondoe kumbukumbu kutoka kwa $MFT na $LOGFILE kuhusu faili, na iondoe Nakala za Kivuli cha Kiasi.
Unaweza kugundua kuwa hata ukifanya hatua hiyo, kunaweza kuwa na sehemu zingine ambapo uwepo wa faili bado unasajiliwa, na hiyo ni kweli na sehemu ya kazi ya kitaalam ya uchunguzi wa kielelezo.
Marejeo
- https://en.wikipedia.org/wiki/GUID_Partition_Table
- http://ntfs.com/ntfs-permissions.htm
- https://www.osforensics.com/faqs-and-tutorials/how-to-scan-ntfs-i30-entries-deleted-files.html
- https://docs.microsoft.com/en-us/windows-server/storage/file-server/volume-shadow-copy-service
- iHackLabs Certified Digital Forensics Windows