पायथन फोरेंसिक - एक एन्क्रिप्शन को क्रैक करना

इस अध्याय में, हम विश्लेषण और सबूत के दौरान प्राप्त एक पाठ डेटा को क्रैक करने के बारे में सीखेंगे।

क्रिप्टोग्राफी में एक सादा पाठ कुछ सामान्य पठनीय पाठ है, जैसे कि संदेश। दूसरी ओर, एक सिफर पाठ, एक एन्क्रिप्शन एल्गोरिथ्म का आउटपुट होता है जिसे आप सादे पाठ में प्रवेश करने के बाद प्राप्त करते हैं।

हम एक सादा पाठ संदेश को सिफर पाठ में कैसे बदलते हैं इसका सरल एल्गोरिथ्म है Caesar cipherका आविष्कार जूलियस सीजर ने अपने दुश्मनों से सादे पाठ को गुप्त रखने के लिए किया था। इस सिफर में वर्णमाला के तीन स्थानों के संदेश "फॉरवर्ड" में हर अक्षर को शिफ्ट करना शामिल है।

निम्नलिखित एक डेमो चित्रण है।

एक → डी

बी → ई

सी → एफ

....

w → Z

x → ए

y → बी

z → सी

उदाहरण

जब आप पायथन स्क्रिप्ट चलाते हैं, तो एक संदेश दर्ज होता है, जो वर्णों की सभी संभावनाओं को देता है, जिसका उपयोग पैटर्न साक्ष्य के लिए किया जाता है।

उपयोग किए जाने वाले पैटर्न के साक्ष्य निम्नानुसार हैं -

  • टायर ट्रैक्स और मार्क्स
  • Impressions
  • Fingerprints

हर बायोमेट्रिक डेटा में वेक्टर डेटा शामिल होता है, जिसे हमें फुल-प्रूफ सबूत इकट्ठा करने के लिए क्रैक करने की आवश्यकता होती है।

निम्नलिखित पायथन कोड दिखाता है कि आप सादे पाठ से सिफर पाठ कैसे बना सकते हैं -

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:])

उत्पादन

अब, इस कोड के आउटपुट की जांच करें। जब हम एक सरल पाठ "राधिका" दर्ज करते हैं, तो कार्यक्रम निम्नलिखित सिफर पाठ का उत्पादन करेगा।