पायथन फोरेंसिक - मूल फोरेंसिक अनुप्रयोग
फोरेंसिक दिशानिर्देशों के अनुसार एक एप्लिकेशन बनाने के लिए, इसके नामकरण सम्मेलनों और पैटर्न को समझना और उनका पालन करना महत्वपूर्ण है।
नामकरण की परंपरा
पायथन फोरेंसिक अनुप्रयोगों के विकास के दौरान, निम्नलिखित नियमों और नियमों का पालन निम्नलिखित तालिका में किया गया है।
स्थिरांक | अंडरस्कोर जुदाई के साथ अपरकेस | उच्च तापमान |
स्थानीय चर नाम | ऊबड़ टोपी के साथ लोअरकेस (अंडरस्कोर वैकल्पिक हैं) | currentTemperature |
वैश्विक चर नाम | धमाकेदार टोपी के साथ उपसमुच्चय निचला भाग (अंडरस्कोर वैकल्पिक हैं) | gl_maximumRecordedTemperature |
कार्य नाम | सक्रिय आवाज के साथ ऊबड़ टोपी (अंडरस्कोर वैकल्पिक) के साथ अपरकेस | ConvertFarenheitToCentigrade (...) |
वस्तु का नाम | ऊबड़ टोपी के साथ उपसर्ग ob_ लोअरकेस | ob_myTempRecorder |
मापांक | एक अंडरस्कोर जिसके बाद ऊबड़ टोपी के साथ लोअरकेस होता है | _tempRecorder |
वर्ग के नाम | उपसर्ग class_ फिर ऊबड़ खाबड़ और संक्षिप्त रखें | class_TempSystem |
कम्प्यूटेशनल फोरेंसिक में नामकरण सम्मेलनों के महत्व को समझने के लिए एक परिदृश्य लेते हैं। मान लीजिए हमारे पास एक हैशिंग एल्गोरिथ्म है जो आमतौर पर डेटा एन्क्रिप्ट करने के लिए उपयोग किया जाता है। एक तरफ़ा हैशिंग एल्गोरिथ्म द्विआधारी डेटा की एक धारा के रूप में इनपुट लेता है; यह एक पासवर्ड, एक फ़ाइल, बाइनरी डेटा या कोई भी डिजिटल डेटा हो सकता है। हैशिंग एल्गोरिथ्म तब निर्माण करता हैmessage digest (md) इनपुट में प्राप्त आंकड़ों के संबंध में।
एक नया बाइनरी इनपुट बनाना व्यावहारिक रूप से असंभव है जो किसी दिए गए संदेश को पचाएगा। यहां तक कि बाइनरी इनपुट डेटा का एक भी बिट, अगर बदला गया है, तो एक अनूठा संदेश उत्पन्न करेगा, जो पिछले एक से अलग है।
उदाहरण
निम्नलिखित नमूना कार्यक्रम पर एक नज़र डालें जो उपर्युक्त सम्मेलनों का अनुसरण करता है।
import sys, string, md5 # necessary libraries
print "Please enter your full name"
line = sys.stdin.readline()
line = line.rstrip()
md5_object = md5.new()
md5_object.update(line)
print md5_object.hexdigest() # Prints the output as per the hashing algorithm i.e. md5
exit
उपरोक्त कार्यक्रम निम्नलिखित आउटपुट का उत्पादन करता है।
इस कार्यक्रम में, पायथन लिपि इनपुट (आपका पूरा नाम) को स्वीकार करती है और इसे md5 हैशिंग एल्गोरिथम के अनुसार परिवर्तित करती है। यह डेटा को एन्क्रिप्ट करता है और यदि आवश्यक हो तो जानकारी को सुरक्षित करता है। फोरेंसिक दिशानिर्देशों के अनुसार, इस पैटर्न में साक्ष्य या किसी भी अन्य प्रमाण का नाम सुरक्षित किया जा सकता है।