एमवीसी फ्रेमवर्क - एक्शन फिल्टर्स
ASP.NET MVC में, नियंत्रक एक्शन विधियों को परिभाषित करते हैं और इन एक्शन विधियों में आम तौर पर UI नियंत्रणों के साथ एक-से-एक संबंध होता है, जैसे कि एक बटन या लिंक पर क्लिक करना, उदाहरण के लिए, हमारे पिछले उदाहरणों में से एक में, UserController कक्षा में शामिल तरीके UserAdd, UserDelete, आदि।
हालांकि, कई बार हम किसी विशेष ऑपरेशन से पहले या बाद में कुछ कार्रवाई करना चाहेंगे। इस कार्यक्षमता को प्राप्त करने के लिए, ASP.NET MVC नियंत्रक की क्रिया विधियों पर पूर्व और पोस्ट-एक्शन व्यवहार को जोड़ने के लिए एक सुविधा प्रदान करता है।
फिल्टर के प्रकार
ASP.NET MVC फ्रेमवर्क निम्नलिखित कार्रवाई फिल्टर का समर्थन करता है -
Action Filters- एक्शन फिल्टर का उपयोग तर्क को लागू करने के लिए किया जाता है जो नियंत्रक कार्रवाई से पहले और बाद में निष्पादित होता है। हम एक्शन फिल्टर्स को इस अध्याय में विस्तार से देखेंगे।
Authorization Filters - प्रमाणीकरण फिल्टर नियंत्रक क्रियाओं के लिए प्रमाणीकरण और प्राधिकरण को लागू करने के लिए उपयोग किया जाता है।
Result Filters- रिजल्ट फिल्टर में लॉजिक होता है जिसे व्यू रिजल्ट से पहले और बाद में निष्पादित किया जाता है। उदाहरण के लिए, आप दृश्य के ब्राउज़र में देखने से ठीक पहले एक दृश्य परिणाम को संशोधित करना चाह सकते हैं।
Exception Filters- अपवाद फ़िल्टर चलाने के लिए अंतिम प्रकार के फ़िल्टर हैं। आप अपने कंट्रोलर एक्शन या कंट्रोलर एक्शन रिजल्ट्स द्वारा उठाए गए एरर को हैंडल करने के लिए एक अपवाद फिल्टर का उपयोग कर सकते हैं। आप त्रुटियों को लॉग करने के लिए अपवाद फ़िल्टर का भी उपयोग कर सकते हैं।
एक्शन फ़िल्टर अतिरिक्त डेटा प्रोसेसिंग, या रिटर्न वैल्यू में हेरफेर करने या कार्रवाई के निष्पादन को रद्द करने या रन टाइम पर व्यू संरचना को संशोधित करने के लिए सबसे अधिक उपयोग किए जाने वाले फिल्टर में से एक हैं।
क्रिया फ़िल्टर
एक्शन फिल्टर्स अतिरिक्त विशेषताएँ हैं जिन्हें किसी नियंत्रक अनुभाग या संपूर्ण नियंत्रक पर लागू किया जा सकता है ताकि जिस तरीके से किसी कार्य को निष्पादित किया जाता है उसे संशोधित किया जा सके। ये विशेषताएँ विशेष .NET क्लास हैं जो System.Attribute से ली गई हैं, जिन्हें कक्षाओं, विधियों, गुणों और फ़ील्ड से जोड़ा जा सकता है।
ASP.NET MVC निम्नलिखित कार्रवाई फिल्टर प्रदान करता है -
Output Cache - यह क्रिया फ़िल्टर निर्दिष्ट समय के लिए नियंत्रक क्रिया के आउटपुट को कैश करता है।
Handle Error - यह क्रिया फ़िल्टर जब नियंत्रक क्रिया निष्पादित करता है तो उठाई गई त्रुटियों को संभालता है।
Authorize - यह एक्शन फ़िल्टर आपको किसी विशेष उपयोगकर्ता या भूमिका तक पहुंच को प्रतिबंधित करने में सक्षम बनाता है।
अब, हम इन फ़िल्टर को एक उदाहरण कंट्रोलर ActionFilterDemoController के उदाहरण पर लागू करने के लिए कोड उदाहरण देखेंगे। (ActionFilterDemoController सिर्फ एक उदाहरण के रूप में उपयोग किया जाता है। आप अपने किसी भी नियंत्रक पर इन फिल्टर का उपयोग कर सकते हैं।)
आउटपुट कैश
Example - 10 सेकंड के लिए कैश किए जाने वाले रिटर्न मान को निर्दिष्ट करता है।
public class ActionFilterDemoController : Controller {
[HttpGet]
OutputCache(Duration = 10)]
public string Index() {
return DateTime.Now.ToString("T");
}
}
त्रुटि को संभालें
Example - नियंत्रक द्वारा त्रुटि को ट्रिगर किए जाने पर एक कस्टम त्रुटि पेज पर एप्लिकेशन को रीडायरेक्ट करता है।
[HandleError]
public class ActionFilterDemoController : Controller {
public ActionResult Index() {
throw new NullReferenceException();
}
public ActionResult About() {
return View();
}
}
उपरोक्त कोड के साथ, यदि कार्रवाई निष्पादन के दौरान कोई त्रुटि होती है, तो यह दृश्य फ़ोल्डर में त्रुटि नामक एक दृश्य मिलेगा और उस पृष्ठ को उपयोगकर्ता को सौंप देगा।
अधिकृत
Example - आवेदन में लॉग इन करने के लिए केवल अधिकृत उपयोगकर्ताओं को अनुमति देना।
public class ActionFilterDemoController: Controller {
[Authorize]
public ActionResult Index() {
ViewBag.Message = "This can be viewed only by authenticated users only";
return View();
}
[Authorize(Roles="admin")]
public ActionResult AdminIndex() {
ViewBag.Message = "This can be viewed only by users in Admin role only";
return View();
}
}
उपरोक्त कोड के साथ, यदि आप बिना लॉग-इन किए एप्लिकेशन को एक्सेस करने का प्रयास करेंगे, तो यह निम्न स्क्रीनशॉट में दिखाए गए के समान त्रुटि फेंक देगा।