authorization - WCF declarative security using CodeAccessSecurity -
मैं मैं इसे इस तरह से उपयोग करता हूं: और मुझे उम्मीद थी कि अगर सीएलआर तंत्र जो कि पर आधारित सत्यापन की जांच करता है एक CodeAccessSecurityAttribute उपवर्ग उदाहरण केवल लक्ष्य विधियों के निष्पादन को रोक देगा, यदि अपवाद तब फेंका जाता है जब CreatePermission () द्वारा दिया गया अनुमति मूल्यांकन किया जाता है। चूंकि आप SecurityAction निर्दिष्ट कर रहे हैं। अनुमति क्रिया के रूप में मांग, इसका मतलब है कि अनुमति की डिमांड () विधि को लक्ष्य विधि के निष्पादन से बचने के लिए फेंक देना होगा। प्राधिकरण को संभाल करने के लिए बहुत सारे अन्य तरीके हैं परिदृश्य, जिनमें से कई आपको अधिक "सुरुचिपूर्ण" मिल सकते हैं हालांकि, वैकल्पिक तरीकों की तलाश शुरू करने से पहले, यह विचार करना सबसे अच्छा होगा कि प्राधिकरण से वंचित होने पर आपके सेवा कॉलर को क्या व्यवहार करना चाहिए। क्या आप विधि को सफल करना चाहते हैं, लेकिन रिक्त वापसी करें, या क्या आप कोई गलती वापस करना चाहेंगे? अगर बाद में, क्या आप चाहते हैं कि यह एक टाइप की गई गलती हो या नहीं? CodeAccessSecurity पर आधारित कस्टम अनुमति-आधारित घोषणात्मक प्राधिकरण तंत्र का उपयोग करने की योजना बना रहा हूं। इसे लागू करने के लिए मैंने
CodeAccessSecurityAttribute से प्राप्त निम्न उपवर्ग बनाया है:
[सेवा का संप्रेषण] सार्वजनिक वर्ग सेवा {[ऑपरेशन कॉन्ट्रैक्ट] [आवश्यकताप्रदर्शन (सुरक्षा क्रिया। डिमांड, अनुमति = "गेट एब्रेट्री प्रोडक्ट ")] सार्वजनिक उपयोगकर्ता GetProduct (स्ट्रिंग का नाम) {वापसी _productRepository.Get (नाम); }}
CreatePermission विधि रिटर्न
_deny तक पहुंच
GetProduct को प्रतिबंधित किया जाएगा। लेकिन ऐसा लगता है कि
CodeAccessSecurity इस तरह से काम नहीं करता है। क्या मुझे एक्सेस ठीक से प्रतिबंधित करने के लिए एक अपवाद फेंकना होगा? या हो सकता है कि इसे प्राप्त करने के लिए और अधिक सुंदर तरीका क्या है?
Comments
Post a Comment