Artefak Penting Di Windows-III
Bab ini akan menjelaskan tentang artefak lebih lanjut yang dapat diperoleh penyelidik selama analisis forensik di Windows.
Log Peristiwa
File log peristiwa Windows, seperti namanya –sarankan, adalah file khusus yang menyimpan peristiwa penting seperti saat pengguna masuk ke komputer, saat program mengalami kesalahan, tentang perubahan sistem, akses RDP, peristiwa khusus aplikasi, dll. Penyelidik dunia maya selalu tertarik dengan peristiwa informasi log karena memberikan banyak informasi historis yang berguna tentang akses sistem. Dalam skrip Python berikut, kita akan memproses format log peristiwa Windows lama dan saat ini.
Untuk skrip Python, kita perlu menginstal modul pihak ketiga yaitu pytsk3, pyewf, unicodecsv, pyevt and pyevtx. Kami dapat mengikuti langkah-langkah yang diberikan di bawah ini untuk mengekstrak informasi dari log peristiwa -
Pertama, cari semua log peristiwa yang cocok dengan argumen input.
Kemudian, lakukan verifikasi tanda tangan file.
Sekarang, proses setiap log peristiwa yang ditemukan dengan perpustakaan yang sesuai.
Terakhir, tulis hasilnya ke spreadsheet.
Kode Python
Mari kita lihat bagaimana menggunakan kode Python untuk tujuan ini -
Pertama, impor pustaka Python berikut -
from __future__ import print_function
import argparse
import unicodecsv as csv
import os
import pytsk3
import pyewf
import pyevt
import pyevtx
import sys
from utility.pytskutil import TSKUtil
Sekarang, berikan argumen untuk penangan baris perintah. Perhatikan bahwa di sini ia akan menerima tiga argumen - pertama adalah jalur ke file bukti, kedua adalah jenis file bukti dan ketiga adalah nama log peristiwa yang akan diproses.
if __name__ == "__main__":
parser = argparse.ArgumentParser('Information from Event Logs')
parser.add_argument("EVIDENCE_FILE", help = "Evidence file path")
parser.add_argument("TYPE", help = "Type of Evidence",choices = ("raw", "ewf"))
parser.add_argument(
"LOG_NAME",help = "Event Log Name (SecEvent.Evt, SysEvent.Evt, ""etc.)")
parser.add_argument(
"-d", help = "Event log directory to scan",default = "/WINDOWS/SYSTEM32/WINEVT")
parser.add_argument(
"-f", help = "Enable fuzzy search for either evt or"" evtx extension", action = "store_true")
args = parser.parse_args()
if os.path.exists(args.EVIDENCE_FILE) and \ os.path.isfile(args.EVIDENCE_FILE):
main(args.EVIDENCE_FILE, args.TYPE, args.LOG_NAME, args.d, args.f)
else:
print("[-] Supplied input file {} does not exist or is not a ""file".format(args.EVIDENCE_FILE))
sys.exit(1)
Sekarang, berinteraksilah dengan log peristiwa untuk menanyakan keberadaan jalur yang disediakan pengguna dengan membuat TSKUtilobyek. Itu bisa dilakukan dengan bantuanmain() metode sebagai berikut -
def main(evidence, image_type, log, win_event, fuzzy):
tsk_util = TSKUtil(evidence, image_type)
event_dir = tsk_util.query_directory(win_event)
if event_dir is not None:
if fuzzy is True:
event_log = tsk_util.recurse_files(log, path=win_event)
else:
event_log = tsk_util.recurse_files(log, path=win_event, logic="equal")
if event_log is not None:
event_data = []
for hit in event_log:
event_file = hit[2]
temp_evt = write_file(event_file)
Sekarang, kita perlu melakukan verifikasi tanda tangan diikuti dengan menentukan metode yang akan menulis seluruh konten ke direktori saat ini -
def write_file(event_file):
with open(event_file.info.name.name, "w") as outfile:
outfile.write(event_file.read_random(0, event_file.info.meta.size))
return event_file.info.name.name
if pyevt.check_file_signature(temp_evt):
evt_log = pyevt.open(temp_evt)
print("[+] Identified {} records in {}".format(
evt_log.number_of_records, temp_evt))
for i, record in enumerate(evt_log.records):
strings = ""
for s in record.strings:
if s is not None:
strings += s + "\n"
event_data.append([
i, hit[0], record.computer_name,
record.user_security_identifier,
record.creation_time, record.written_time,
record.event_category, record.source_name,
record.event_identifier, record.event_type,
strings, "",
os.path.join(win_event, hit[1].lstrip("//"))
])
elif pyevtx.check_file_signature(temp_evt):
evtx_log = pyevtx.open(temp_evt)
print("[+] Identified {} records in {}".format(
evtx_log.number_of_records, temp_evt))
for i, record in enumerate(evtx_log.records):
strings = ""
for s in record.strings:
if s is not None:
strings += s + "\n"
event_data.append([
i, hit[0], record.computer_name,
record.user_security_identifier, "",
record.written_time, record.event_level,
record.source_name, record.event_identifier,
"", strings, record.xml_string,
os.path.join(win_event, hit[1].lstrip("//"))
])
else:
print("[-] {} not a valid event log. Removing temp" file...".format(temp_evt))
os.remove(temp_evt)
continue
write_output(event_data)
else:
print("[-] {} Event log not found in {} directory".format(log, win_event))
sys.exit(3)
else:
print("[-] Win XP Event Log Directory {} not found".format(win_event))
sys.exit(2
Terakhir, tentukan metode untuk menulis output ke spreadsheet sebagai berikut -
def write_output(data):
output_name = "parsed_event_logs.csv"
print("[+] Writing {} to current working directory: {}".format(
output_name, os.getcwd()))
with open(output_name, "wb") as outfile:
writer = csv.writer(outfile)
writer.writerow([
"Index", "File name", "Computer Name", "SID",
"Event Create Date", "Event Written Date",
"Event Category/Level", "Event Source", "Event ID",
"Event Type", "Data", "XML Data", "File Path"
])
writer.writerows(data)
Setelah Anda berhasil menjalankan script di atas, kita akan mendapatkan informasi event log in spreadsheet.
Sejarah Internet
Sejarah internet sangat berguna bagi analis forensik; karena sebagian besar kejahatan dunia maya hanya terjadi melalui internet. Mari kita lihat cara mengekstrak riwayat internet dari Internet Explorer, saat kita membahas tentang forensik Windows, dan Internet Explorer hadir secara default dengan Windows.
Di Internet Explorer, riwayat internet disimpan di index.datmengajukan. Mari kita lihat skrip Python, yang akan mengekstrak informasinyaindex.dat mengajukan.
Kami dapat mengikuti langkah-langkah yang diberikan di bawah ini untuk mengekstrak informasi index.dat file -
Pertama, cari index.dat file dalam sistem.
Kemudian, ekstrak informasi dari file itu dengan mengulanginya.
Sekarang, tulis semua informasi ini ke laporan CSV.
Kode Python
Mari kita lihat bagaimana menggunakan kode Python untuk tujuan ini -
Pertama, impor pustaka Python berikut -
from __future__ import print_function
import argparse
from datetime import datetime, timedelta
import os
import pytsk3
import pyewf
import pymsiecf
import sys
import unicodecsv as csv
from utility.pytskutil import TSKUtil
Sekarang, berikan argumen untuk penangan baris perintah. Perhatikan bahwa di sini akan menerima dua argumen - pertama akan menjadi jalur ke file bukti dan yang kedua adalah jenis file bukti -
if __name__ == "__main__":
parser = argparse.ArgumentParser('getting information from internet history')
parser.add_argument("EVIDENCE_FILE", help = "Evidence file path")
parser.add_argument("TYPE", help = "Type of Evidence",choices = ("raw", "ewf"))
parser.add_argument("-d", help = "Index.dat directory to scan",default = "/USERS")
args = parser.parse_args()
if os.path.exists(args.EVIDENCE_FILE) and os.path.isfile(args.EVIDENCE_FILE):
main(args.EVIDENCE_FILE, args.TYPE, args.d)
else:
print("[-] Supplied input file {} does not exist or is not a ""file".format(args.EVIDENCE_FILE))
sys.exit(1)
Sekarang, tafsirkan file bukti dengan membuat objek TSKUtildan lakukan iterasi melalui sistem file untuk menemukan file index.dat. Ini dapat dilakukan dengan mendefinisikan filemain() berfungsi sebagai berikut -
def main(evidence, image_type, path):
tsk_util = TSKUtil(evidence, image_type)
index_dir = tsk_util.query_directory(path)
if index_dir is not None:
index_files = tsk_util.recurse_files("index.dat", path = path,logic = "equal")
if index_files is not None:
print("[+] Identified {} potential index.dat files".format(len(index_files)))
index_data = []
for hit in index_files:
index_file = hit[2]
temp_index = write_file(index_file)
Sekarang, tentukan fungsi dengan bantuan yang kita dapat menyalin informasi dari file index.dat ke direktori kerja saat ini dan nanti mereka dapat diproses oleh modul pihak ketiga -
def write_file(index_file):
with open(index_file.info.name.name, "w") as outfile:
outfile.write(index_file.read_random(0, index_file.info.meta.size))
return index_file.info.name.name
Sekarang, gunakan kode berikut untuk melakukan validasi tanda tangan dengan bantuan fungsi bawaan yaitu check_file_signature() -
if pymsiecf.check_file_signature(temp_index):
index_dat = pymsiecf.open(temp_index)
print("[+] Identified {} records in {}".format(
index_dat.number_of_items, temp_index))
for i, record in enumerate(index_dat.items):
try:
data = record.data
if data is not None:
data = data.rstrip("\x00")
except AttributeError:
if isinstance(record, pymsiecf.redirected):
index_data.append([
i, temp_index, "", "", "", "", "",record.location, "", "", record.offset,os.path.join(path, hit[1].lstrip("//"))])
elif isinstance(record, pymsiecf.leak):
index_data.append([
i, temp_index, record.filename, "","", "", "", "", "", "", record.offset,os.path.join(path, hit[1].lstrip("//"))])
continue
index_data.append([
i, temp_index, record.filename,
record.type, record.primary_time,
record.secondary_time,
record.last_checked_time, record.location,
record.number_of_hits, data, record.offset,
os.path.join(path, hit[1].lstrip("//"))
])
else:
print("[-] {} not a valid index.dat file. Removing "
"temp file..".format(temp_index))
os.remove("index.dat")
continue
os.remove("index.dat")
write_output(index_data)
else:
print("[-] Index.dat files not found in {} directory".format(path))
sys.exit(3)
else:
print("[-] Directory {} not found".format(win_event))
sys.exit(2)
Sekarang, tentukan metode yang akan mencetak output dalam file CSV, seperti yang ditunjukkan di bawah ini -
def write_output(data):
output_name = "Internet_Indexdat_Summary_Report.csv"
print("[+] Writing {} with {} parsed index.dat files to current "
"working directory: {}".format(output_name, len(data),os.getcwd()))
with open(output_name, "wb") as outfile:
writer = csv.writer(outfile)
writer.writerow(["Index", "File Name", "Record Name",
"Record Type", "Primary Date", "Secondary Date",
"Last Checked Date", "Location", "No. of Hits",
"Record Data", "Record Offset", "File Path"])
writer.writerows(data)
Setelah menjalankan script diatas kita akan mendapatkan informasi dari file index.dat dalam file CSV.
Salinan Bayangan Volume
Salinan bayangan adalah teknologi yang disertakan dalam Windows untuk mengambil salinan cadangan atau snapshot dari file komputer secara manual atau otomatis. Ini juga disebut layanan snapshot volume atau layanan bayangan volume (VSS).
Dengan bantuan file VSS ini, ahli forensik dapat memiliki beberapa informasi historis tentang bagaimana sistem berubah dari waktu ke waktu dan file apa yang ada di komputer. Teknologi salinan bayangan membutuhkan sistem file menjadi NTFS untuk membuat dan menyimpan salinan bayangan.
Di bagian ini, kita akan melihat skrip Python, yang membantu mengakses setiap volume salinan bayangan yang ada dalam gambar forensik.
Untuk skrip Python kita perlu menginstal modul pihak ketiga yaitu pytsk3, pyewf, unicodecsv, pyvshadow dan vss. Kami dapat mengikuti langkah-langkah yang diberikan di bawah ini untuk mengekstrak informasi dari file VSS
Pertama, akses volume gambar mentah dan identifikasi semua partisi NTFS.
Kemudian, ekstrak informasi dari salinan bayangan itu dengan mengulanginya.
Sekarang, akhirnya kita perlu membuat daftar file data di dalam snapshot.
Kode Python
Mari kita lihat bagaimana menggunakan kode Python untuk tujuan ini -
Pertama, impor pustaka Python berikut -
from __future__ import print_function
import argparse
from datetime import datetime, timedelta
import os
import pytsk3
import pyewf
import pyvshadow
import sys
import unicodecsv as csv
from utility import vss
from utility.pytskutil import TSKUtil
from utility import pytskutil
Sekarang, berikan argumen untuk penangan baris perintah. Di sini ia akan menerima dua argumen - pertama adalah jalur ke file bukti dan kedua adalah file keluaran.
if __name__ == "__main__":
parser = argparse.ArgumentParser('Parsing Shadow Copies')
parser.add_argument("EVIDENCE_FILE", help = "Evidence file path")
parser.add_argument("OUTPUT_CSV", help = "Output CSV with VSS file listing")
args = parser.parse_args()
Sekarang, validasi keberadaan jalur file input dan juga pisahkan direktori dari file output.
directory = os.path.dirname(args.OUTPUT_CSV)
if not os.path.exists(directory) and directory != "":
os.makedirs(directory)
if os.path.exists(args.EVIDENCE_FILE) and \ os.path.isfile(args.EVIDENCE_FILE):
main(args.EVIDENCE_FILE, args.OUTPUT_CSV)
else:
print("[-] Supplied input file {} does not exist or is not a "
"file".format(args.EVIDENCE_FILE))
sys.exit(1)
Sekarang, berinteraksi dengan volume file bukti dengan membuat file TSKUtilobyek. Itu bisa dilakukan dengan bantuanmain() metode sebagai berikut -
def main(evidence, output):
tsk_util = TSKUtil(evidence, "raw")
img_vol = tsk_util.return_vol()
if img_vol is not None:
for part in img_vol:
if tsk_util.detect_ntfs(img_vol, part):
print("Exploring NTFS Partition for VSS")
explore_vss(evidence, part.start * img_vol.info.block_size,output)
else:
print("[-] Must be a physical preservation to be compatible ""with this script")
sys.exit(2)
Sekarang, tentukan metode untuk menjelajahi file bayangan volume yang diuraikan sebagai berikut -
def explore_vss(evidence, part_offset, output):
vss_volume = pyvshadow.volume()
vss_handle = vss.VShadowVolume(evidence, part_offset)
vss_count = vss.GetVssStoreCount(evidence, part_offset)
if vss_count > 0:
vss_volume.open_file_object(vss_handle)
vss_data = []
for x in range(vss_count):
print("Gathering data for VSC {} of {}".format(x, vss_count))
vss_store = vss_volume.get_store(x)
image = vss.VShadowImgInfo(vss_store)
vss_data.append(pytskutil.openVSSFS(image, x))
write_csv(vss_data, output)
Terakhir, tentukan metode penulisan hasil dalam spreadsheet sebagai berikut -
def write_csv(data, output):
if data == []:
print("[-] No output results to write")
sys.exit(3)
print("[+] Writing output to {}".format(output))
if os.path.exists(output):
append = True
with open(output, "ab") as csvfile:
csv_writer = csv.writer(csvfile)
headers = ["VSS", "File", "File Ext", "File Type", "Create Date",
"Modify Date", "Change Date", "Size", "File Path"]
if not append:
csv_writer.writerow(headers)
for result_list in data:
csv_writer.writerows(result_list)
Setelah Anda berhasil menjalankan skrip Python ini, kami akan mendapatkan informasi yang berada di VSS ke dalam spreadsheet.