जेएसपी - सुरक्षा
JavaServer पेज और सर्वलेट वेब डेवलपर्स को एप्लिकेशन सुरक्षित करने के लिए कई मैकेनिज्म उपलब्ध कराते हैं। अनुप्रयोग परिनियोजन वर्णनकर्ता में उनकी पहचान करके और उन्हें एक भूमिका सौंपकर संसाधनों को घोषित रूप से संरक्षित किया जाता है।
प्रमाणीकरण के कई स्तर उपलब्ध हैं, मूल प्रमाणीकरण से लेकर सर्टिफिकेट का उपयोग करके परिष्कृत प्रमाणीकरण तक पासवर्ड और पासवर्ड।
भूमिका आधारित प्रमाणीकरण
सर्वलेट विनिर्देशन में प्रमाणीकरण तंत्र एक तकनीक का उपयोग करता है जिसे कहा जाता है role-based security। विचार यह है कि उपयोगकर्ता स्तर पर संसाधनों को प्रतिबंधित करने के बजाय, आप भूमिकाएँ बनाते हैं और भूमिका द्वारा संसाधनों को प्रतिबंधित करते हैं।
आप फ़ाइल में विभिन्न भूमिकाओं को परिभाषित कर सकते हैं tomcat-users.xml, जो टॉमकट के घर की निर्देशिका में स्थित है। इस फ़ाइल का एक उदाहरण नीचे दिखाया गया है -
<?xml version = '1.0' encoding = 'utf-8'?>
<tomcat-users>
<role rolename = "tomcat"/>
<role rolename = "role1"/>
<role rolename = "manager"/>
<role rolename = "admin"/>
<user username = "tomcat" password = "tomcat" roles = "tomcat"/>
<user username = "role1" password = "tomcat" roles = "role1"/>
<user username = "both" password = "tomcat" roles = "tomcat,role1"/>
<user username = "admin" password = "secret" roles = "admin,manager"/>
</tomcat-users>
इस फ़ाइल के बीच एक साधारण मानचित्रण को परिभाषित करता है username, password, तथा role। ध्यान दें कि किसी दिए गए उपयोगकर्ता की कई भूमिकाएँ हो सकती हैं; उदाहरण के लिए,username = "both" "टॉमकैट" भूमिका और "भूमिका 1" भूमिका में है।
एक बार जब आपने विभिन्न भूमिकाओं को पहचान लिया और परिभाषित कर लिया, तो भूमिका-आधारित सुरक्षा प्रतिबंधों का उपयोग करके विभिन्न वेब अनुप्रयोग संसाधनों पर रखा जा सकता है <security-constraint> में तत्व web.xml WEB-INF निर्देशिका में उपलब्ध फ़ाइल।
निम्नलिखित web.xml में एक नमूना प्रविष्टि है -
<web-app>
...
<security-constraint>
<web-resource-collection>
<web-resource-name>SecuredBookSite</web-resource-name>
<url-pattern>/secured/*</url-pattern>
<http-method>GET</http-method>
<http-method>POST</http-method>
</web-resource-collection>
<auth-constraint>
<description>
Let only managers use this app
</description>
<role-name>manager</role-name>
</auth-constraint>
</security-constraint>
<security-role>
<role-name>manager</role-name>
</security-role>
<login-config>
<auth-method>BASIC</auth-method>
</login-config>
...
</web-app>
उपरोक्त प्रविष्टियों का मतलब होगा -
किसी भी HTTP GET या POST का अनुरोध / सुरक्षित / * से मेल खाने वाले URL के लिए सुरक्षा प्रतिबंध के अधीन होगा।
एक प्रबंधक की भूमिका वाले व्यक्ति को सुरक्षित संसाधनों तक पहुंच दी जाती है।
login-config तत्व का वर्णन करने के लिए किया जाता है BASIC प्रमाणीकरण का रूप।
यदि आप किसी भी URL को ब्राउज़ करने का प्रयास करते हैं, जिसमें शामिल है /securityनिर्देशिका, निम्नलिखित संवाद बॉक्स उपयोगकर्ता नाम और पासवर्ड के लिए पूछते हुए प्रदर्शित किया जाएगा। यदि आप एक उपयोगकर्ता प्रदान करते हैं"admin" और पासवर्ड "secret", तब आपके पास मिलान किए गए URL पर पहुंच होगी /secured/* जैसा कि हमने उपयोगकर्ता व्यवस्थापक को प्रबंधक भूमिका के साथ परिभाषित किया है जिन्हें इस संसाधन तक पहुंचने की अनुमति है।
फॉर्म आधारित प्रमाणीकरण
जब आप FORM प्रमाणीकरण विधि का उपयोग करते हैं, तो आपको उपयोगकर्ता नाम और पासवर्ड के लिए संकेत देने के लिए एक लॉगिन फ़ॉर्म की आपूर्ति करनी चाहिए। निम्नलिखित का एक सरल कोड हैlogin.jsp। यह एक ही उद्देश्य के लिए एक फॉर्म बनाने में मदद करता है -
<html>
<body bgcolor = "#ffffff">
<form method = "POST" action ="j_security_check">
<table border = "0">
<tr>
<td>Login</td>
<td><input type = "text" name="j_username"></td>
</tr>
<tr>
<td>Password</td>
<td><input type = "password" name="j_password"></td>
</tr>
</table>
<input type = "submit" value = "Login!">
</form>
</body>
</html>
यहां आपको यह सुनिश्चित करना होगा कि लॉगिन फॉर्म में नाम के फार्म तत्व शामिल होने चाहिए j_username तथा j_password। में क्रिया<form> टैग होना चाहिए j_security_check। POSTफार्म विधि के रूप में इस्तेमाल किया जाना चाहिए। उसी समय, आपको संशोधित करना होगा<login-config> फॉर्म-विधि को FORM के रूप में निर्दिष्ट करने के लिए टैग -
<web-app>
...
<security-constraint>
<web-resource-collection>
<web-resource-name>SecuredBookSite</web-resource-name>
<url-pattern>/secured/*</url-pattern>
<http-method>GET</http-method>
<http-method>POST</http-method>
</web-resource-collection>
<auth-constraint>
<description>Let only managers use this app</description>
<role-name>manager</role-name>
</auth-constraint>
</security-constraint>
<security-role>
<role-name>manager</role-name>
</security-role>
<login-config>
<auth-method>FORM</auth-method>
<form-login-config>
<form-login-page>/login.jsp</form-login-page>
<form-error-page>/error.jsp</form-error-page>
</form-login-config>
</login-config>
...
</web-app>
अब जब आप किसी भी संसाधन को एक्सेस करने की कोशिश करेंगे URL /secured/*, यह उपर्युक्त फॉर्म को यूजर आईडी और पासवर्ड के लिए पूछेगा। जब कंटेनर देखता है "j_security_check"कार्रवाई, यह कॉलर को प्रमाणित करने के लिए कुछ आंतरिक तंत्र का उपयोग करता है।
यदि लॉगिन सफल होता है और कॉलर सुरक्षित संसाधन तक पहुंचने के लिए अधिकृत है, तो कंटेनर उस बिंदु से कॉलर के लिए लॉगिन सत्र की पहचान करने के लिए एक सत्र-आईडी का उपयोग करता है। कंटेनर सत्र-आईडी वाले कुकी के साथ लॉगिन सत्र को बनाए रखता है। सर्वर कुकी को क्लाइंट को वापस भेज देता है, और जब तक कॉलर इस कुकी को बाद के अनुरोधों के साथ प्रस्तुत करता है, तब कंटेनर को पता चल जाएगा कि कॉलर कौन है।
यदि लॉगिन विफल रहता है, तो सर्वर प्रपत्र-त्रुटि-पृष्ठ सेटिंग द्वारा पहचाने गए पृष्ठ को वापस भेजता है
यहाँ, j_security_checkवह क्रिया है जो फ़ॉर्म आधारित लॉगिन का उपयोग करने वाले अनुप्रयोगों को लॉगिन फ़ॉर्म के लिए निर्दिष्ट करना होता है। उसी रूप में, आपके पास एक टेक्स्ट इनपुट नियंत्रण भी होना चाहिए जिसे कहा जाता हैj_username और एक password input control बुलाया j_password। जब आप इसे देखते हैं, तो इसका मतलब है कि फॉर्म में निहित जानकारी सर्वर को सौंपी जाएगी, जो नाम और पासवर्ड की जांच करेगी। यह कैसे किया जाता है सर्वर विशिष्ट है।
कैसे समझने के लिए मानक दायरे कार्यान्वयन की जाँच करेंj_security_check Tomcat कंटेनर के लिए काम करता है ..
एक सर्वलेट / जेएसपी में प्रोग्रामेटिक सुरक्षा
HttpServletRequest ऑब्जेक्ट निम्न विधियाँ प्रदान करता है, जिनका उपयोग रनटाइम पर सुरक्षा जानकारी को देने के लिए किया जा सकता है -
क्र.सं. | विधि और विवरण |
---|---|
1 | String getAuthType() getAuthType() पद्धति एक स्टर्लिंग ऑब्जेक्ट देता है जो सर्वलेट की सुरक्षा के लिए उपयोग की जाने वाली प्रमाणीकरण योजना के नाम का प्रतिनिधित्व करता है। |
2 | boolean isUserInRole(java.lang.String role) isUserInRole() विधि एक बूलियन मान लौटाता है: यदि उपयोगकर्ता दी गई भूमिका में है या नहीं तो सही है। |
3 | String getProtocol() getProtocol()पद्धति उस प्रोटोकॉल का प्रतिनिधित्व करती है जो अनुरोध भेजने के लिए उपयोग किया गया था। यह मान निर्धारित करने के लिए जांचा जा सकता है कि क्या सुरक्षित प्रोटोकॉल का उपयोग किया गया था। |
4 | boolean isSecure() isSecure()यदि अनुरोध HTTPS का उपयोग करके किया गया था, तो विधि एक बूलियन मान लौटाती है। सही मान का अर्थ यह था और कनेक्शन सुरक्षित है। गलत मान का अर्थ अनुरोध नहीं था। |
5 | Principle getUserPrinciple() getUserPrinciple() विधि एक java.security.Principle ऑब्जेक्ट देता है जिसमें वर्तमान प्रमाणित उपयोगकर्ता का नाम होता है। |
उदाहरण के लिए, JavaServer पेज के लिए जो प्रबंधकों के लिए पृष्ठों से लिंक करता है, आपके पास निम्नलिखित कोड हो सकते हैं -
<% if (request.isUserInRole("manager")) { %>
<a href = "managers/mgrreport.jsp">Manager Report</a>
<a href = "managers/personnel.jsp">Personnel Records</a>
<% } %>
जेएसपी या सर्वलेट में उपयोगकर्ता की भूमिका की जांच करके, आप उपयोगकर्ता को केवल उन वस्तुओं को दिखाने के लिए वेबपृष्ठ को कस्टमाइज़ कर सकते हैं जो वह एक्सेस कर सकता है। यदि आपको उपयोगकर्ता के नाम की आवश्यकता है क्योंकि यह प्रमाणीकरण रूप में दर्ज किया गया था, तो आप कॉल कर सकते हैंgetRemoteUser अनुरोध वस्तु में विधि।