पायथन फोरेंसिक - एक एन्क्रिप्शन को क्रैक करना
इस अध्याय में, हम विश्लेषण और सबूत के दौरान प्राप्त एक पाठ डेटा को क्रैक करने के बारे में सीखेंगे।
क्रिप्टोग्राफी में एक सादा पाठ कुछ सामान्य पठनीय पाठ है, जैसे कि संदेश। दूसरी ओर, एक सिफर पाठ, एक एन्क्रिप्शन एल्गोरिथ्म का आउटपुट होता है जिसे आप सादे पाठ में प्रवेश करने के बाद प्राप्त करते हैं।
हम एक सादा पाठ संदेश को सिफर पाठ में कैसे बदलते हैं इसका सरल एल्गोरिथ्म है 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:])
उत्पादन
अब, इस कोड के आउटपुट की जांच करें। जब हम एक सरल पाठ "राधिका" दर्ज करते हैं, तो कार्यक्रम निम्नलिखित सिफर पाठ का उत्पादन करेगा।