Zend फ्रेमवर्क - प्रमाणीकरण

प्रमाणीकरण किसी भी वेब एप्लिकेशन में सबसे महत्वपूर्ण और आवश्यक विशेषता है। Zend फ्रेमवर्क प्रमाणीकरण को संभालने के लिए एक अलग घटक प्रदान करता है, जिसे कहा जाता हैzend-authentication

एक प्रमाणीकरण घटक स्थापित करें

प्रमाणीकरण घटक निम्नलिखित का उपयोग करके स्थापित किया जा सकता है Composer आदेश।

composer require zendframework/zend-authentication

संकल्पना

आमतौर पर, एक डेवलपर एक डेटा स्रोत के खिलाफ उपयोगकर्ता के विवरण को प्रमाणित करने के लिए एक php फ़ंक्शन लिखता है। प्रमाणीकरण पूरा हो जाने के बाद, प्रमाणीकरण विवरण बाद के अनुरोधों के लिए बने रहते हैं। Zend फ्रेमवर्क इस अवधारणा को सामान्य करता है और दो वर्गों को प्रदान करता है, जिन्हें नीचे समझाया गया है -

कक्षा 1 Zend \ Authentication \ Adapter \ AdaptorInterface

यह वर्ग एकल विधि प्रदान करता है, authenticateप्रमाणीकरण तर्क लिखने के लिए। प्रमाणित विधि का एक उदाहरण देता हैZend\Authentication\Result कक्षा।

यह Resultवस्तु प्रमाणीकरण स्थिति रखती है; प्रमाणीकरण विफल होने पर पहचान और त्रुटि संदेश, यदि प्रमाणीकरण विफल हो जाता है। प्रमाणीकृत इंटरफ़ेस और परिणाम वर्ग का हस्ताक्षर निम्नानुसार है -

AdaptorInterface

namespace Zend\Authentication\Adaptor; 
public function authenticate() { 
   // code 
}

Result class

namespace Zend\Authentication; 
class Result { 
   public function __construct($code, $identity, array $messages = []); 
}

Zend फ्रेमवर्क डेटाबेस, ldap, http बेसिक और डाइजेस्ट क्रेडेंशियल्स के खिलाफ प्रमाणित करने के लिए एक डिफ़ॉल्ट कार्यान्वयन प्रदान करता है। एकAdaptor प्रमाणित करता है, लेकिन भविष्य के किसी भी अनुरोध के लिए विवरण जारी नहीं रखता है।

कक्षा 2 Zend \ Authentication \ AuthenticationService

ऑथेंटिकेशनस्वाइस मुख्य घटक है, जो प्रमाणीकरण उद्देश्यों के लिए पहले से कॉन्फ़िगर किए गए एडाप्टर का उपयोग करता है। एक बार प्रमाणीकरण हो जाने के बाद, यह प्रमाणीकरण विवरण को बनाए रखता है और विधियाँ प्रदान करता है,hasIdentity() यह जाँचने के लिए कि क्या कोई पहचान उपलब्ध है, getIdentity() प्रमाणीकरण विवरण प्राप्त करने के लिए और clearIdentity() प्रमाणीकरण विवरण साफ़ करने के लिए।

इस प्रमाणीकरण सेवा का उपयोग करने के लिए आंशिक कोड सूची निम्नानुसार है -

$adap = new Adapter($username, $password);  
$auth = new AuthenticationService(); $result = $auth->authenticate($adap);  
if($result->isValid) { $identity = $auth->getIdentity(); } else { // process $result->getMessages() 
}  
// clear 
$auth->clearIdentity();

प्राधिकरण से संबंधित सामान को दो अलग-अलग मॉड्यूल के रूप में पैक किया जाता है, जो हैं - zend-permissions-acl तथा zend-permissions-rbac। Zend-अनुमतियाँ-acl पहुँच नियंत्रण सूची पर आधारित है और zend-अनुमतियाँ-rbac भूमिका आधारित पहुँच नियंत्रण सूची पर आधारित है। वे एंटरप्राइज़ ग्रेड एप्लिकेशन लिखने में ACL और RBAC अवधारणा और एड्स के उच्च-स्तरीय अमूर्तता प्रदान करते हैं।