भले ही सुपरमार्केट या आउटलेट्स पर जहां आप अपने उपयोगिता बिलों का भुगतान करते हैं, कतारें इतिहास हैं, हम में से कुछ जानते हैं कि जब कोई लाइन में कूदता है तो कैसा लगता है।
कतार के सामने, यानी। विशेष रूप से, यदि यह इस कारण से है कि उनका बिल लाइन में खड़े अन्य लोगों की तुलना में कहीं अधिक मूल्य का है। स्पष्ट रूप से, जब सेवा की मुस्तैदी की बात आती है तो यह एक मानदंड नहीं होना चाहिए।
अब, लाइन के सामने ले जाने का यह व्यवसाय एथेरियम स्मार्ट कॉन्ट्रैक्ट्स में भी होता है। अन्यथा अग्रणी त्रुटि के रूप में जाना जाता है, जिसका नाम शेयर बाजार की एक समान घटना से प्राप्त किया गया है, उच्च गैस शुल्क का भुगतान करने वाले स्मार्ट अनुबंध लेनदेन उन लोगों की तुलना में अधिक पसंद किए जाते हैं जो नहीं करते हैं।
शुरुआत से ही, यह भेद्यता दोषपूर्ण प्रोग्रामिंग के कारण नहीं होती है, लेकिन जिस तरह से लेनदेन का आदेश दिया जाता है और 'मेमपूल' से एक ब्लॉक में जोड़ा जाता है, उसका उपयोग करता है।
जल्दी पैसा बनाने की चाहत रखने वाले नियमित उपयोगकर्ताओं के अलावा, खनिक इस तरह के लेन-देन से लाभ प्राप्त करते हैं और यही कारण है कि ब्लॉक में जोड़े जाने से पहले वे ऐसे लेन-देन पर नजर रखने की सबसे अधिक संभावना रखते हैं। वास्तव में, एक बार ऐसा करने के बाद, वे एक अनुचित वित्तीय इनाम के लिए अपना स्वयं का लेनदेन भेजते हैं, जो पहले भेजे गए ब्लॉक के बजाय एक ब्लॉक में जोड़ा जाता है।
यहां जो बात ध्यान में रखनी चाहिए वह यह है कि उच्च गैस की कीमत के साथ किए गए लेन-देन दूसरों की तुलना में पहले संसाधित होते हैं। इस वरीयता को ध्यान में रखते हुए, हमलावर केवल उच्च गैस शुल्क का भुगतान करके नीलामी, व्यापार या प्रारंभिक सिक्के की पेशकश जैसी घटनाओं के परिणाम को अपने पक्ष में बदल सकते हैं।
आइए यह समझने के लिए इस सामान्य उदाहरण को देखें कि अग्रगामी भेद्यता कैसे काम करती है:
इस उदाहरण में, हमारे पास तीन अभिनेता हैं: नमन, काव्या और ऐश्वर्या। नमन पहले हैशिंग चुनौती को हल करने के लिए अन्य दो के लिए एक स्मार्ट अनुबंध के रूप में तैनात करता है। जो कोई भी इस हैशिंग पहेली को सुलझाएगा उसे इनाम के तौर पर 10 ईथर मिलेंगे।
अब, काव्या पहले हैशिंग समाधान ढूंढती है और इसे अपने स्मार्ट अनुबंध से गैस शुल्क के रूप में 10 Gwei के साथ भेजती है:
दूसरी ओर, ऐश्वर्या थोड़ी देर बाद इसका जवाब ढूंढती है और गैस शुल्क के रूप में 100 Gwei के साथ अपने स्मार्ट अनुबंध का सही उत्तर पास करती है।
उच्च गैस शुल्क का भुगतान करने के कारण, काव्या को 10 ईथर पुरस्कार प्राप्त करने के बजाय, ऐश्वर्या इसे प्राप्त करती है, जैसा कि नीचे दिखाया गया है:
सीधे शब्दों में कहें, यह अग्रगामी या लेन-देन-आदेश त्रुटि है, क्योंकि यह गैस शुल्क के मूल्य के आधार पर लेनदेन की प्रक्रिया करता है।
दूसरे शब्दों में, भले ही काव्या ने ऐश्वर्या के सामने अपना जवाब जमा कर दिया हो, उसे अपने प्रयासों के लिए कुछ नहीं मिला, जैसा कि नीचे दिखाया गया है:
चूंकि ऐश्वर्या का यह 'जंप इन लाइन' काव्या या किसी और को अच्छा नहीं लगेगा, इसलिए हमारे स्मार्ट कॉन्ट्रैक्ट कोड के लिए कुछ निवारक उपायों पर विचार किया जाना चाहिए।
अब, ऐसे सुधार हैं जो इस तरह के नुकसान को रोक सकते हैं। दूसरे शब्दों में, हमें एक लेन-देन को उस लेनदेन के रूप में लॉक करने में सक्षम होना चाहिए जिसे 10 ईथर प्राप्त करना चाहिए।
विधि 1: लेन-देन काउंटर
लेन-देन काउंटर का उपयोग करना किसी अन्य को किसी अन्य माध्यम से पुरस्कार प्राप्त करने से रोकने का सबसे आसान तरीका है।
जैसा कि आप नीचे जोड़े गए कोड से बता सकते हैं, एक लेन-देन काउंटर जोड़ा गया है जो उस व्यक्ति द्वारा किए गए लेन-देन को लॉक कर देता है जिसने पहले हैशिंग चुनौती पूरी की है। चूंकि ऐसा करने वाले पहले व्यक्ति को ही पुरस्कार प्राप्त करना चाहिए, हम सभी प्रतिभागियों को उनके समाधान के साथ मान 0 जोड़ने के लिए सूचित करते हैं।
चूँकि txCounter का वर्तमान मान पहले प्रस्तुत समाधान के लिए शून्य होगा, यह लॉक हो जाता है। दूसरे शब्दों में, और जैसा कि ऊपर दिए गए उदाहरण में है, काव्या अपने समाधान के साथ-साथ शून्य के मान को 10 ईथर का पुरस्कार प्राप्त करने के लिए दर्ज करेगी। .
यदि कोई और ऐसा करता है, तो समाधान स्वीकार नहीं किया जाएगा क्योंकि लेन-देन काउंटर को एक से अधिक मूल्य में बढ़ा दिया गया है। उस समय तक, पूरे 10 ईथर इनाम, जो काव्या को जाने चाहिए, उसे सही तरीके से स्थानांतरित कर दिए जाएंगे।
विधि 2: गैस सीमा निर्धारित करना
अब, इस पद्धति के साथ, सभी लेन-देन के लिए गैस सीमा निर्धारित करने पर ध्यान केंद्रित किया गया है। दोनों, एक निचली और एक ऊपरी सीमा, यदि आवश्यक हो।
जैसा कि आप याद कर सकते हैं, लेन-देन का आदेश इस आधार पर दिया जाता है कि उक्त लेनदेन के लिए कितनी गैस फीस का भुगतान किया गया है। हालांकि यह उस आदेश को पूरी तरह से समाप्त नहीं कर सकता है, यह निश्चित रूप से इसे काफी हद तक कम कर देता है।
यदि आप नीचे दिए गए कोड को देखते हैं, तो सभी लेन-देन जो 1 या उससे कम की राशि का गैस का भुगतान करते हैं, से गुजरेंगे, लेकिन जो लोग अधिक गैस का भुगतान करके लाइन को पार करने की कोशिश करते हैं, वे गैसथ्रॉटल संशोधक के लिए धन्यवाद नहीं करेंगे। इस मामले में, 1 वीई या जीवीई इस तरह के लेनदेन को संसाधित करने की मानक लागत हो सकती है और जिसकी अनुमति दी जाएगी।
इसलिए, यदि इस थ्रॉटल के आधार पर सभी लेन-देन गैस में इतना भिन्न नहीं होते हैं, तो कुछ लेन-देन को वरीयता दिखाने का मुद्दा नहीं उठेगा। जबकि इस तरह के दृष्टिकोण के फायदे हैं, भुगतान किया गया गैस शुल्क भविष्य में बदलने के लिए बाध्य है।
आज जो ऊंचा है वह एक दो साल में नीचे हो जाएगा, इसलिए नमन को हर समय इस पर नजर रखनी होगी। या फिर, ऐश कुछ समय के लिए प्रतीक्षा करके इन बदलते मूल्यों का लाभ उठाने में सक्षम हो सकता है।
विधि 3: पनडुब्बी-भेजने का दृष्टिकोण
अब, जबकि पहले के दो दृष्टिकोण सरल स्थितियों के लिए काम कर सकते हैं, वे वास्तव में सामने चल रही भेद्यता के मूल कारण को संबोधित नहीं करते हैं: खनिकों और अन्य दुर्भावनापूर्ण उपयोगकर्ताओं दोनों के लिए लेन-देन की जानकारी का पूर्ण प्रकटीकरण।
यह स्पष्ट होना चाहिए कि जब तक इन दोनों पक्षों के पास प्रत्येक लेन-देन की जानकारी तक पहुंच है, तब तक सिस्टम को जुआ खेलने की संभावना बनी रहती है। स्पष्ट रूप से, एक विधि जिसके द्वारा इस समय-संवेदनशील जानकारी को छिपाया जाना चाहिए और जो हमें लिबसबमरीन स्मार्ट कॉन्ट्रैक्ट लाइब्रेरी के हिस्से के रूप में लागू पनडुब्बी-भेजने के दृष्टिकोण में लाती है।
जब कोई इस दृष्टिकोण का उपयोग करता है, तो वे लेन-देन की जानकारी को इस तरह छिपाते हैं कि खनिक या नियमित उपयोगकर्ता वास्तव में लाभ नहीं उठा सकते। इस जानकारी की सुरक्षा में एन्क्रिप्शन एक बड़ी भूमिका निभाता है, जो कि मालिक के विवेक के आधार पर, एक ब्लॉक में जोड़े जाने के बाद प्रकट हो सकता है।
उस ने कहा, भले ही यह दृष्टिकोण सही नहीं है, सुरक्षा का स्तर जो यह प्रदान करता है वह अन्य तरीकों की तुलना में कहीं बेहतर है, वास्तविक कारण को संबोधित करने की इच्छा के कारण सामने चल रहा है - वास्तविक दुनिया में और दोनों ब्लॉकचेन पर।
बेशक, पिछले अनुभाग में चर्चा की गई रणनीतियाँ केवल वही नहीं हैं जो स्मार्ट अनुबंधों को 'फ्रंट-रनिंग' भेद्यता से बचाती हैं।
साइड चेन के साथ, ऑर्डर ऑफ-चेन होता है, जबकि उस पर सेटलमेंट होता है। विभिन्न प्लेटफार्मों पर इन दो चरणों के साथ, यह न केवल थ्रूपुट में वृद्धि के लिए लाभ है, बल्कि खनिकों या नियमित उपयोगकर्ताओं को सामने आने वाली भेद्यता का फायदा उठाने के लिए आवश्यक जानकारी प्राप्त करने से रोकेगा।
एक अन्य रणनीति, भले ही प्रकृति में सैद्धांतिक हो, एक विशेष दौर के लिए लेनदेन के क्रम को यादृच्छिक रूप से शामिल करना शामिल है जो प्रतिबद्ध-प्रकटीकरण योजना में प्रतिबद्ध है। इसे स्मार्ट कॉन्ट्रैक्ट लॉजिक का उपयोग करके लागू किया जाता है। इस दृष्टिकोण के साथ फ्रंटरनर लाइन के सामने नहीं आएंगे क्योंकि ऑर्डरिंग उपरोक्त स्मार्ट अनुबंध द्वारा निर्धारित की जाती है।
अंत में, एक अन्य दृष्टिकोण में इंजेक्शन प्रोटोकॉल का कार्यान्वयन शामिल है जहां उपयोगकर्ता उस सभी महत्वपूर्ण टी-वैल्यू के लिए सत्यापन योग्य विलंब कार्यों को हल करते हैं जो यह निर्धारित करता है कि ऑर्डर किसे मिलता है। नतीजतन, अधिकांश ब्लॉकचेन का उपयोग करने वाले यादृच्छिक क्रम प्रणाली से दूर जाने में सक्षम होने से, सामने वाले हमलों की संभावना भी कम हो जाती है।