- क्या आप किसी **साइबर सुरक्षा कंपनी** में काम करते हैं? क्या आप अपनी **कंपनी को HackTricks में विज्ञापित** देखना चाहते हैं? या क्या आपको **PEASS के नवीनतम संस्करण या HackTricks को PDF में डाउनलोड करने का उपयोग** करने की आवश्यकता है? [**सदस्यता योजनाएं**](https://github.com/sponsors/carlospolop) की जांच करें!
जावा `Serializable` इंटरफेस (`java.io.Serializable`) एक मार्कर इंटरफेस है जिसे आपकी कक्षाएं अगर वे **सीरीयलाइज़ की जाएं** और **डीसीरीयलाइज़ की जाएं** तो उन्हें लागू करनी होगी। जावा ऑब्जेक्ट सीरीयलाइज़ करना (लिखना) [ObjectOutputStream](http://tutorials.jenkov.com/java-io/objectoutputstream.html) के साथ किया जाता है और डीसीरीयलाइज़ करना (पढ़ना) [ObjectInputStream](http://tutorials.jenkov.com/java-io/objectinputstream.html) के साथ किया जाता है।
चलो एक **कक्षा व्यक्ति** के साथ एक उदाहरण देखते हैं जो **सीरीयलाइज़ करने योग्य** है। इस कक्षा में, कक्षा व्यक्ति की **readObject फ़ंक्शन को अधिलेखित** किया गया है, इसलिए जब भी इस कक्षा के **किसी भी ऑब्जेक्ट** को **डीसीरीयलाइज़ किया जाता है**, तो यह **फ़ंक्शन** चलाई जाएगी।\
उदाहरण में, कक्षा व्यक्ति की readObject फ़ंक्शन उसके पालतू जानवर की `eat()` फ़ंक्शन को बुलाती है और एक कुत्ते की `eat()` फ़ंक्शन (किसी कारण से) एक **calc.exe** को बुलाती है। **हम देखेंगे कि कैसे एक Person ऑब्जेक्ट को सीरीयलाइज़ और डीसीरीयलाइज़ करके इस कैलकुलेटर को चलाया जाता है:**
यह उदाहरण [https://medium.com/@knownsec404team/java-deserialization-tool-gadgetinspector-first-glimpse-74e99e493649](https://medium.com/@knownsec404team/java-deserialization-tool-gadgetinspector-first-glimpse-74e99e493649) से लिया गया है।
जैसा कि आप इस बहुत ही मूलभूत उदाहरण में देख सकते हैं, यहां "सुरक्षा कमजोरी" इसलिए होती है क्योंकि **readObject** फ़ंक्शन **अन्य सुरक्षा कमजोर फ़ंक्शनों को कॉल कर रहा है**।
- क्या आप **साइबर सुरक्षा कंपनी** में काम करते हैं? क्या आप अपनी कंपनी को **HackTricks में विज्ञापित** देखना चाहते हैं? या क्या आपको **PEASS के नवीनतम संस्करण या HackTricks को PDF में डाउनलोड करने का उपयोग** करने की आवश्यकता है? [**सदस्यता योजनाएं**](https://github.com/sponsors/carlospolop) की जांच करें!