Python Forensics - การถอดรหัสการเข้ารหัส
ในบทนี้เราจะเรียนรู้เกี่ยวกับการถอดรหัสข้อมูลข้อความที่ดึงมาระหว่างการวิเคราะห์และหลักฐาน
ข้อความธรรมดาในการเข้ารหัสคือข้อความที่อ่านได้ตามปกติเช่นข้อความ ในทางกลับกันข้อความการเข้ารหัสคือผลลัพธ์ของอัลกอริทึมการเข้ารหัสที่ดึงข้อมูลมาหลังจากที่คุณป้อนข้อความธรรมดา
อัลกอริทึมง่ายๆในการเปลี่ยนข้อความธรรมดาให้เป็นข้อความเข้ารหัสคือไฟล์ Caesar cipherคิดค้นโดย Julius Caesar เพื่อให้ข้อความธรรมดาเป็นความลับจากศัตรูของเขา การเข้ารหัสนี้เกี่ยวข้องกับการเลื่อนตัวอักษรทุกตัวในข้อความ "ไปข้างหน้า" ตามสามตำแหน่งในตัวอักษร
ต่อไปนี้เป็นภาพประกอบการสาธิต
ก→ง
ข→จ
ค→ F
....
w → Z
x →ก
y → B
z →ค
ตัวอย่าง
ข้อความที่ป้อนเมื่อคุณเรียกใช้สคริปต์ Python ให้ความเป็นไปได้ทั้งหมดของอักขระซึ่งใช้เป็นหลักฐานรูปแบบ
ประเภทของหลักฐานรูปแบบที่ใช้มีดังนี้ -
- รางยางและเครื่องหมาย
- Impressions
- Fingerprints
ข้อมูลไบโอเมตริกซ์ทุกรายการประกอบด้วยข้อมูลเวกเตอร์ซึ่งเราจำเป็นต้องถอดรหัสเพื่อรวบรวมหลักฐานที่สมบูรณ์
โค้ด Python ต่อไปนี้แสดงวิธีสร้างข้อความเข้ารหัสจากข้อความธรรมดา -
import sys
def decrypt(k,cipher):
plaintext = ''
for each in cipher:
p = (ord(each)-k) % 126
if p < 32:
p+=95
plaintext += chr(p)
print plaintext
def main(argv):
if (len(sys.argv) != 1):
sys.exit('Usage: cracking.py')
cipher = raw_input('Enter message: ')
for i in range(1,95,1):
decrypt(i,cipher)
if __name__ == "__main__":
main(sys.argv[1:])
เอาต์พุต
ตอนนี้ตรวจสอบผลลัพธ์ของรหัสนี้ เมื่อเราป้อนข้อความง่ายๆ "Radhika" โปรแกรมจะสร้างข้อความรหัสต่อไปนี้