आम तौर पर मैं व्यक्तिपरक उत्तरों से बचने की कोशिश करता हूं, लेकिन यह वास्तव में एक महत्वपूर्ण बहस है। सबसे पहले मैं डिस्कवर उल्का ब्लॉग से उल्का विधियों बनाम क्लाइंट-साइड ऑपरेशंस पढ़ने की अनुशंसा करता हूं। ध्यान दें कि एडथेना में हम विशेष रूप से उन कारणों के लिए विधियों का उपयोग करते हैं जो स्पष्ट होना चाहिए।
तरीके
समर्थक
-
तरीके बाहरी पुस्तकालय की आवश्यकता के बिना मनमाने ढंग से जटिलता के स्कीमा और सत्यापन नियमों को सही ढंग से लागू कर सकते हैं। साइड नोट - आपके इनपुट की संरचना को सत्यापित करने के लिए चेक एक उत्कृष्ट उपकरण है।
-
आपके आवेदन में प्रत्येक विधि सत्य का एक स्रोत है। यदि आप 'posts.insert' विधि बनाते हैं, तो आप आसानी से सुनिश्चित कर सकते हैं कि आपके ऐप में पोस्ट डालने का यही एकमात्र तरीका है।
चोर
- विधियों को एक अनिवार्य शैली की आवश्यकता होती है, और वे एक ऑपरेशन के लिए आवश्यक सत्यापन की संख्या के संबंध में क्रियात्मक होते हैं।
क्लाइंट-साइड ऑपरेशंस
समर्थक
allow/denyएक सरल घोषणात्मक शैली है।
चोर
-
updateपर स्कीमा और अनुमतियों को मान्य करना ऑपरेशन असीम रूप से कठिन है। यदि आपको स्कीमा लागू करने की आवश्यकता है तो आपको संग्रह 2 जैसे बाहरी पुस्तकालय का उपयोग करने की आवश्यकता होगी। केवल यही कारण आपको विराम देना चाहिए। -
संशोधनों को आपके पूरे आवेदन में फैलाया जा सकता है। इसलिए, यह पहचानना मुश्किल हो सकता है कि कोई विशेष डेटाबेस ऑपरेशन क्यों हुआ।
सारांश
मेरी राय में, allow /deny अधिक सौंदर्यपूर्ण रूप से प्रसन्न है, हालांकि यह मौलिक कमजोरी अनुमतियों को लागू करने में है (विशेष रूप से अपडेट पर)। मैं ऐसे मामलों में क्लाइंट-साइड संचालन की अनुशंसा करता हूं जहां:
-
आपका कोडबेस अपेक्षाकृत छोटा है - इसलिए उन सभी उदाहरणों के लिए grep करना आसान है जहां कोई विशेष संशोधक होता है।
-
आपके पास कई डेवलपर नहीं हैं - इसलिए आपको सभी सहमत होने की आवश्यकता नहीं है कि X में सम्मिलित करने का एक और केवल एक ही तरीका है संग्रह।
-
आपके पास सरल अनुमति नियम हैं - उदा। केवल दस्तावेज़ का स्वामी ही इसके किसी भी पहलू को संशोधित कर सकता है।
मेरी राय में, एमवीपी बनाते समय क्लाइंट-साइड ऑपरेशंस का उपयोग करना एक उचित विकल्प है, लेकिन मैं अन्य सभी स्थितियों के लिए विधियों पर स्विच करूंगा।
अपडेट 2/22/15
सैशको स्टुबैलो ने अनुमति/अस्वीकार को सम्मिलित/अद्यतन/निकालने के तरीकों से बदलने का प्रस्ताव बनाया।
6/1/16 अपडेट करें
उल्का गाइड यह स्थिति लेता है कि allow/deny हमेशा बचना चाहिए।