वेबसाइट विकास - सुरक्षा
अपने वेबपृष्ठों को सुरक्षित करना उतना ही महत्वपूर्ण है जितना इसे विकसित करना, क्योंकि कोई भी खतरा जो सुरक्षा से समझौता कर सकता है, आपकी व्यावसायिक प्रतिष्ठा को नुकसान पहुंचा सकता है, आपको आर्थिक रूप से नुकसान पहुंचा सकता है (आपकी ऑनलाइन जमा राशि चुराकर), आपके ग्राहकों को नुकसान पहुंचा सकता है जो आपकी वेबसाइट पर जाते हैं, आदि।
सुरक्षा विशेषज्ञों के अनुसार, वे वेबसाइट सुरक्षा जांच के आधार पर करने का सुझाव देंगे OWASP TOP 10, जो वेब एप्लिकेशन सुरक्षा के लिए एक शक्तिशाली जागरूकता दस्तावेज है। OWASP शीर्ष 10 सबसे महत्वपूर्ण वेब अनुप्रयोग सुरक्षा दोषों के बारे में एक व्यापक सहमति का प्रतिनिधित्व करता है।
एसक्यूएल इंजेक्शन
इंजेक्शन की खामियां, जैसे कि SQL, OS और LDAP इंजेक्शन तब होती हैं, जब बिना डेटा किसी कमांड या क्वेरी के हिस्से के रूप में एक दुभाषिया को भेजा जाता है। हमलावर के शत्रुतापूर्ण डेटा दुभाषिया को अनायास आदेशों को क्रियान्वित करने या उचित प्राधिकरण के बिना डेटा तक पहुंचने की कोशिश कर सकते हैं।
Solution - iSQL से अपने वेबपेज को सुरक्षित करने के लिए, आपको इनपुट और फ़िल्टरिंग सिंबल को मान्य करना होगा।
टूटा प्रमाणीकरण और सत्र प्रबंधन
प्रमाणीकरण और सत्र प्रबंधन से संबंधित अनुप्रयोग कार्यों को अक्सर सही ढंग से लागू नहीं किया जाता है, जो हमलावरों को पासवर्ड, चाबियाँ, सत्र टोकन से समझौता करने या यहां तक कि अन्य उपयोगकर्ताओं की पहचान मानने के लिए अन्य कार्यान्वयन दोषों का दोहन करने की अनुमति देता है।
Solution - अपनी साइट को इस दोष से सुरक्षित करने के लिए, आपको समय समाप्ति के साथ कुकीज़ और सत्र बनाने होंगे।
क्रॉस-साइट स्क्रिप्टिंग (XSS)
XSS दोष तब होता है जब कोई एप्लिकेशन अविश्वसनीय डेटा लेता है और इसे उचित सत्यापन या भागने के बिना वेब ब्राउज़र पर भेजता है। XSS हमलावरों को पीड़ित के ब्राउज़र में स्क्रिप्ट निष्पादित करने की अनुमति देता है, जो तब उपयोगकर्ता सत्रों को अपहृत कर सकता है, वेबसाइटों को खराब कर सकता है या उपयोगकर्ता को दुर्भावनापूर्ण साइटों पर पुनर्निर्देशित कर सकता है।
Solution - इससे सुरक्षा उसी तर्ज पर होती है, जैसा कि iSQL के लिए है।
असुरक्षित प्रत्यक्ष वस्तु संदर्भ
एक प्रत्यक्ष वस्तु संदर्भ तब होता है जब कोई डेवलपर किसी आंतरिक कार्यान्वयन ऑब्जेक्ट, जैसे फ़ाइल, निर्देशिका या डेटाबेस कुंजी के संदर्भ को उजागर करता है। एक्सेस कंट्रोल चेक या अन्य सुरक्षा के बिना, हमलावर अनधिकृत डेटा तक पहुंचने के लिए इन संदर्भों में हेरफेर कर सकते हैं।
Solution - आपको ऐसी फ़ाइलों की सुरक्षा के लिए विशिष्ट सुरक्षा तंत्र जैसे पासवर्ड को लागू करना चाहिए।
सुरक्षा गलतफहमी
अच्छी सुरक्षा के लिए एप्लिकेशन, फ्रेमवर्क, एप्लिकेशन सर्वर, वेब सर्वर, डेटाबेस सर्वर और प्लेटफॉर्म के लिए परिभाषित एक सुरक्षित कॉन्फ़िगरेशन की आवश्यकता होती है। सुरक्षित सेटिंग्स को परिभाषित, कार्यान्वित और बनाए रखा जाना चाहिए, क्योंकि चूक अक्सर असुरक्षित होती हैं।
Solution - सॉफ्टवेयर को अद्यतन रखा जाना चाहिए।
संवेदनशील डेटा एक्सपोजर
कई वेब एप्लिकेशन संवेदनशील डेटा, जैसे क्रेडिट कार्ड, कर आईडी और प्रमाणीकरण क्रेडेंशियल्स की सुरक्षा ठीक से नहीं करते हैं। हमलावर क्रेडिट कार्ड धोखाधड़ी, पहचान की चोरी या अन्य अपराधों का संचालन करने के लिए ऐसे कमजोर संरक्षित डेटा को चोरी या संशोधित कर सकते हैं।
Solution - संवेदनशील डेटा बाकी या पारगमन में एन्क्रिप्शन जैसे अतिरिक्त सुरक्षा के साथ-साथ ब्राउज़र के साथ आदान-प्रदान करते समय विशेष सावधानी बरतने का हकदार है।
गुम समारोह स्तर अभिगम नियंत्रण
अधिकांश वेब एप्लिकेशन UI में दिखाई देने वाली कार्यक्षमता को बनाने से पहले फ़ंक्शन स्तर पहुंच अधिकारों को सत्यापित करते हैं। हालाँकि, एप्लिकेशन को प्रत्येक फ़ंक्शन के एक्सेस होने पर सर्वर पर समान एक्सेस कंट्रोल चेक करने की आवश्यकता होती है। यदि अनुरोधों को सत्यापित नहीं किया जाता है, तो हमलावर उचित प्राधिकरण के बिना कार्यक्षमता तक पहुंचने के अनुरोधों को बनाने में सक्षम होंगे।
Solution - आपको प्रमाणीकरण के स्तरों की जांच करनी चाहिए।
क्रॉस-साइट अनुरोध क्षमा (CSRF)
CSRF हमला एक पीड़ित व्यक्ति के ब्राउज़र पर जाली HTTP अनुरोध भेजने के लिए मजबूर करता है, जिसमें पीड़ित का सत्र कुकी और अन्य किसी भी स्वचालित रूप से प्रमाणीकरण जानकारी शामिल है, जो एक कमजोर वेब अनुप्रयोग के लिए है। यह हमलावर को पीड़ित के ब्राउज़र को उन अनुरोधों को उत्पन्न करने के लिए मजबूर करने की अनुमति देता है जो कमजोर अनुप्रयोग को लगता है कि पीड़ित से वैध अनुरोध हैं।
Solution - सबसे अधिक इस्तेमाल की जाने वाली रोकथाम प्रत्येक अनुरोध के आधार पर कुछ अप्रत्याशित चुनौती को संलग्न करना है जो एक वेबसाइट से आती है और उन्हें उपयोगकर्ता के सत्र के साथ जोड़ती है।
ज्ञात कमजोरियों के साथ घटकों का उपयोग करना
लाइब्रेरी, फ्रेमवर्क और अन्य सॉफ्टवेयर मॉड्यूल जैसे घटक लगभग हमेशा पूर्ण विशेषाधिकारों के साथ चलते हैं। यदि एक असुरक्षित घटक का शोषण किया जाता है, तो ऐसा हमला गंभीर डेटा हानि या सर्वर अधिग्रहण की सुविधा प्रदान कर सकता है। ज्ञात कमजोरियों के साथ घटकों का उपयोग करने वाले अनुप्रयोग, अनुप्रयोग सुरक्षा को कमजोर कर सकते हैं और संभावित हमलों और प्रभावों की एक श्रृंखला को सक्षम कर सकते हैं।
Solution - जांचें कि क्या घटक संस्करण में कमजोरियां हैं और दूसरे संस्करण से बचने या बदलने की कोशिश करें।
अमान्य रीडायरेक्ट और फ़ॉर्वर्ड
वेब एप्लिकेशन अक्सर उपयोगकर्ताओं को अन्य पृष्ठों और वेबसाइटों पर पुनर्निर्देशित करते हैं। ये एप्लिकेशन गंतव्य पृष्ठों को निर्धारित करने के लिए अविश्वसनीय डेटा का उपयोग करते हैं। उचित सत्यापन के बिना, हमलावर फ़िशिंग या मैलवेयर साइटों पर पीड़ितों को पुनर्निर्देशित कर सकते हैं या अनधिकृत पृष्ठों तक पहुंचने के लिए आगे का उपयोग कर सकते हैं।
Solution - हमेशा एक URL को मान्य करें।
सुरक्षित प्रयुक्त प्रोटोकॉल
यह ऐसा मामला है जहां आपके पास VPS योजना है और आप अपने दम पर सब कुछ प्रबंधित करते हैं। जब सेवाएं स्थापित हो जाती हैं तो वे डिफ़ॉल्ट पोर्ट का उपयोग करते हैं। इससे हैकर के लिए काम आसान हो जाता है क्योंकि वह जानता है कि कहां देखना है।
वेबसाइटों की मेजबानी में उपयोग किए जाने वाले कुछ मुख्य सेवा बंदरगाह नीचे दिए गए हैं -
- एसएसएच - पोर्ट 22
- एफ़टीपी - पोर्ट २१
- MySQL - पोर्ट 3306
- डीएनएस - पोर्ट 53
- SMTP - पोर्ट 25
ऑपरेटिंग सिस्टम और उसके विभिन्न संस्करणों के आधार पर उन सेवाओं के पोर्ट में परिवर्तन होता है। इसके अतिरिक्त, आपको एक फ़ायरवॉल स्थापित करना होगा। यदि यह लिनक्स ओएस है, तो हम अनुशंसा करेंगेIPtablesऔर अन्य सभी अनावश्यक पोर्ट को ब्लॉक करें। यदि आपका ओएस विंडोज़ है, तो आप इसके सम्मिलित फ़ायरवॉल का उपयोग कर सकते हैं।
अपनी सेवाओं में ब्रूट फोर्स लॉगिन को ब्लॉक करने के लिए, आप उपयोग कर सकते हैं Fail2ban, जो एक लिनक्स आधारित सॉफ्टवेयर है और सभी आईपी पतों को ब्लॉक करता है जो कई विफल लॉगिन प्रयास करता है।