कई एप्लिकेशन
कभी-कभी एक प्रोजेक्ट को कई उप-प्रोजेक्टों में विभाजित किया जाता है, जैसे कि एक शॉपिंग मॉल को शॉपिंग मॉल मुख्य प्रोजेक्ट, शॉपिंग मॉल एपीआई इंटरफ़ेस, शॉपिंग मॉल प्रबंधन बैकएंड के 3 उप-प्रोजेक्टों में विभाजित किया जा सकता है, जो सभी समान डेटाबेस कॉन्फ़िगरेशन का उपयोग करते हैं।
webman आपको इस प्रकार एप्लिकेशन निर्देशिका की योजना बनाने की अनुमति देता है:
app
├── shop
│ ├── controller
│ ├── model
│ └── view
├── api
│ ├── controller
│ └── model
└── admin
├── controller
├── model
└── view
जब आप पता http://127.0.0.1:8787/shop/{नियंत्रक}/{विधि}
पर जाते हैं, तो यह app/shop/controller
में नियंत्रक और विधि को एक्सेस करता है।
जब आप पता http://127.0.0.1:8787/api/{नियंत्रक}/{विधि}
पर जाते हैं, तो यह app/api/controller
में नियंत्रक और विधि को एक्सेस करता है।
जब आप पता http://127.0.0.1:8787/admin/{नियंत्रक}/{विधि}
पर जाते हैं, तो यह app/admin/controller
में नियंत्रक और विधि को एक्सेस करता है।
webman में, आप एप्लिकेशन निर्देशिका को इस प्रकार भी व्यवस्थित कर सकते हैं।
app
├── controller
├── model
├── view
│
├── api
│ ├── controller
│ └── model
└── admin
├── controller
├── model
└── view
इस तरह, जब पता http://127.0.0.1:8787/{नियंत्रक}/{विधि}
पर जाता है, तो यह app/controller
में नियंत्रक और विधि को एक्सेस करेगा। जब पथ api
या admin
से शुरू होता है, तो यह संबंधित निर्देशिका में नियंत्रक और विधि को एक्सेस करेगा।
कई एप्लिकेशन में वर्ग का नाम स्थान psr4
के अनुरूप होना चाहिए, उदाहरण के लिए app/api/controller/FooController.php
फ़ाइल निम्नलिखित के समान हो सकती है:
<?php
namespace app\api\controller;
use support\Request;
class FooController
{
}
कई एप्लिकेशन मध्यवर्ती कॉन्फ़िगरेशन
कभी-कभी आप विभिन्न एप्लिकेशन के लिए विभिन्न मध्यवर्ती कॉन्फ़िगर करना चाहते हैं, उदाहरण के लिए, api
एप्लिकेशन को एक क्रॉस-डोमेन मध्यवर्ती की आवश्यकता हो सकती है, admin
को एक व्यवस्थापक लॉगिन की जांच करने वाले मध्यवर्ती की आवश्यकता हो सकती है, इसलिए config/midlleware.php
को इस प्रकार कॉन्फ़िगर किया जा सकता है:
return [
// वैश्विक मध्यवर्ती
'' => [
support\middleware\AuthCheck::class,
],
// api एप्लिकेशन मध्यवर्ती
'api' => [
support\middleware\AccessControl::class,
],
// admin एप्लिकेशन मध्यवर्ती
'admin' => [
support\middleware\AdminAuthCheck::class,
support\middleware\SomeOtherClass::class,
],
];
ऊपर दिए गए मध्यवर्ती संभवतः मौजूद नहीं हैं, यहाँ केवल यह उदाहरण देने के लिए हैं कि एप्लिकेशन के अनुसार मध्यवर्ती कैसे कॉन्फ़िगर करें
मध्यवर्ती क्रियान्वयन क्रम वैश्विक मध्यवर्ती
->एप्लिकेशन मध्यवर्ती
है।
मध्यवर्ती विकास का संदर्भ मध्यवर्ती अध्याय
कई एप्लिकेशन अपवाद प्रसंस्करण कॉन्फ़िगरेशन
इसी तरह, आप विभिन्न अनुप्रयोगों के लिए विभिन्न अपवाद प्रसंस्करण वर्गों को कॉन्फ़िगर करना चाहते हैं, उदाहरण के लिए, shop
एप्लिकेशन में अपवाद आने पर आप एक मित्रतापूर्ण सूचना पृष्ठ प्रदान करना चाहते हैं; api
एप्लिकेशन में अपवाद आने पर आप एक पृष्ठ नहीं लौटाना चाहते हैं, बल्कि एक json स्ट्रिंग लौटाना चाहेंगे। विभिन्न एप्लिकेशन के लिए विभिन्न अपवाद प्रसंस्करण वर्गों की कॉन्फ़िगरेशन फ़ाइल config/exception.php
इस प्रकार हो सकती है:
return [
'shop' => support\exception\Handler::class,
'api' => support\exception\ApiHandler::class,
];
मध्यवर्ती के विपरीत, प्रत्येक एप्लिकेशन केवल एक अपवाद प्रसंस्करण वर्ग को कॉन्फ़िगर कर सकता है।
ऊपर दिए गए अपवाद प्रसंस्करण वर्ग संभवतः मौजूद नहीं हैं, यहाँ केवल यह उदाहरण देने के लिए हैं कि एप्लिकेशन के अनुसार अपवाद प्रसंस्करण कैसे कॉन्फ़िगर करें
अपवाद प्रसंस्करण विकास का संदर्भ अपवाद प्रसंस्करण अध्याय