लारवेल - त्वरित गाइड
लारवेल एक ओपन-सोर्स PHP फ्रेमवर्क है, जो मजबूत और समझने में आसान है। यह एक मॉडल-व्यू-कंट्रोलर डिज़ाइन पैटर्न का अनुसरण करता है। लारवेल विभिन्न चौखटे के मौजूदा घटकों का पुन: उपयोग करता है जो वेब एप्लिकेशन बनाने में मदद करता है। इस प्रकार तैयार किया गया वेब एप्लिकेशन अधिक संरचित और व्यावहारिक है।
लारवेल कार्यात्मकताओं का एक समृद्ध सेट प्रदान करता है जो PHPI फ्रेमवर्क की बुनियादी विशेषताओं को शामिल करता है जैसे कोडइग्निटर, वाईआईआई और अन्य प्रोग्रामिंग भाषा जैसे रूबी ऑन रेल्स। लारवेल में सुविधाओं का एक बहुत समृद्ध समूह है जो वेब विकास की गति को बढ़ावा देगा।
यदि आप Core PHP और Advanced PHP से परिचित हैं, तो Laravel आपके कार्य को आसान बना देगा। यह बहुत समय बचाता है यदि आप एक वेबसाइट को खरोंच से विकसित करने की योजना बना रहे हैं। इसके अलावा, लारवेल में निर्मित एक वेबसाइट सुरक्षित है और कई वेब हमलों को रोकती है।
लारवेल के फायदे
लारवेल आपको निम्नलिखित लाभ प्रदान करता है, जब आप इसके आधार पर एक वेब एप्लिकेशन तैयार कर रहे हैं -
वेब एप्लिकेशन अधिक स्केलेबल हो जाता है, लारवेल फ्रेमवर्क के कारण।
वेब एप्लिकेशन को डिजाइन करने में काफी समय बच जाता है, क्योंकि Laravel वेब एप्लिकेशन विकसित करने में अन्य ढांचे से घटकों का पुन: उपयोग करता है।
इसमें नाम स्थान और इंटरफेस शामिल हैं, इस प्रकार संसाधनों को व्यवस्थित और प्रबंधित करने में मदद मिलती है।
संगीतकार
संगीतकार एक उपकरण है जिसमें सभी निर्भरताएं और पुस्तकालय शामिल हैं। यह उपयोगकर्ता को उल्लिखित रूपरेखा के संबंध में एक परियोजना बनाने की अनुमति देता है (उदाहरण के लिए, लारवेल इंस्टॉलेशन में उपयोग किए गए)। संगीतकार की मदद से थर्ड पार्टी लाइब्रेरी आसानी से स्थापित की जा सकती है।
सभी निर्भरताओं में उल्लेख किया है composer.json फ़ाइल जो स्रोत फ़ोल्डर में रखी गई है।
शिल्पकार
लारवेल में प्रयुक्त कमांड लाइन इंटरफ़ेस को कहा जाता है Artisan। इसमें कमांड का एक सेट शामिल होता है जो वेब एप्लिकेशन बनाने में सहायता करता है। इन कमांडों को सिम्फनी फ्रेमवर्क से शामिल किया गया है, जिसके परिणामस्वरूप Laravel 5.1 (Laravel का नवीनतम संस्करण) में ऐड-ऑन सुविधाएँ हैं।
लारवेल की विशेषताएं
लारवेल निम्नलिखित प्रमुख विशेषताएं प्रदान करता है जो इसे वेब अनुप्रयोगों को डिजाइन करने के लिए एक आदर्श विकल्प बनाता है -
प्रतिरूपकता
लारवेल पुस्तकालयों और मॉड्यूलों में निर्मित 20 प्रदान करता है जो अनुप्रयोग को बढ़ाने में मदद करता है। प्रत्येक मॉड्यूल संगीतकार निर्भरता प्रबंधक के साथ एकीकृत है जो अपडेट को आसान बनाता है।
testability
लारवेल में ऐसी विशेषताएं और सहायक शामिल हैं जो विभिन्न परीक्षण मामलों के माध्यम से परीक्षण में मदद करते हैं। यह सुविधा आवश्यकताओं के अनुसार कोड को बनाए रखने में मदद करती है।
मार्ग
Laravel उपयोगकर्ता को वेब अनुप्रयोग में मार्गों को परिभाषित करने के लिए एक लचीला दृष्टिकोण प्रदान करता है। रूटिंग एक बेहतर तरीके से एप्लिकेशन को स्केल करने में मदद करता है और इसके प्रदर्शन को बढ़ाता है।
विन्यास प्रबंधन
लारवेल में डिज़ाइन किया गया एक वेब एप्लिकेशन विभिन्न वातावरणों पर चल रहा होगा, जिसका अर्थ है कि इसके कॉन्फ़िगरेशन में निरंतर परिवर्तन होगा। लारवेल एक कुशल तरीके से कॉन्फ़िगरेशन को संभालने के लिए एक सुसंगत दृष्टिकोण प्रदान करता है।
क्वेरी बिल्डर और ORM
लारवेल एक क्वेरी बिल्डर को शामिल करता है जो विभिन्न सरल श्रृंखला विधियों का उपयोग करके डेटाबेस को क्वेरी करने में मदद करता है। यह प्रावधानORM (ऑब्जेक्ट रिलेशनल मैपर) और ActiveRecord कार्यान्वयन जिसे एलोकेंट कहा जाता है।
स्कीमा बिल्डर
स्कीमा बिल्डर PHP कोड में डेटाबेस परिभाषा और स्कीमा को बनाए रखता है। यह डेटाबेस माइग्रेशन के संबंध में परिवर्तनों का ट्रैक भी रखता है।
साँचा इंजन
लारवेल का उपयोग करता है Blade Template इंजन, एक हल्के टेम्पलेट भाषा का उपयोग पदानुक्रमित ब्लॉक और पूर्वनिर्धारित ब्लॉकों के साथ लेआउट डिजाइन करने के लिए किया जाता है जिसमें गतिशील सामग्री शामिल होती है।
ईमेल
लारवेल में ए mail वर्ग जो वेब एप्लिकेशन से समृद्ध सामग्री और अनुलग्नकों के साथ मेल भेजने में मदद करता है।
प्रमाणीकरण
वेब अनुप्रयोगों में उपयोगकर्ता प्रमाणीकरण एक सामान्य विशेषता है। लारवेल डिजाइनिंग प्रमाणीकरण को आसान बनाता है क्योंकि इसमें ऐसी विशेषताएं शामिल हैंregister, forgot password तथा send password reminders।
Redis
लारवेल का उपयोग करता है Redisमौजूदा सत्र और सामान्य-उद्देश्य कैश से कनेक्ट करने के लिए। रेडिस सीधे सत्र के साथ बातचीत करते हैं।
कतारों
लारवेल में बड़ी संख्या में उपयोगकर्ताओं को ईमेल करने या एक निर्दिष्ट जैसी कतार सेवाएं शामिल हैं Cronकाम। ये कतारें पिछले कार्य के पूरा होने की प्रतीक्षा किए बिना आसान तरीके से कार्यों को पूरा करने में मदद करती हैं।
घटना और कमान बस
लारवेल 5.1 शामिल हैं Command Busजो साधारण तरीके से आदेशों को निष्पादित करने और घटनाओं को भेजने में मदद करता है। लारवेल में आदेश अनुप्रयोग के जीवनचक्र के अनुसार कार्य करते हैं।
निर्भरता के प्रबंधन के लिए, लारवेल उपयोग करता है composer। सुनिश्चित करें कि आपके पास Laravel स्थापित करने से पहले आपके सिस्टम पर एक संगीतकार स्थापित है। इस अध्याय में, आप लारवेल की स्थापना प्रक्रिया देखेंगे।
आपको अपने सिस्टम पर Laravel स्थापित करने के लिए नीचे दिए गए चरणों का पालन करना होगा -
Step 1 - अपने सिस्टम पर इसे स्थापित करने के लिए निम्न URL पर जाएं और संगीतकार डाउनलोड करें।
https://getcomposer.org/download/
Step 2 - कम्पोज़र इंस्टॉल होने के बाद, कमांड प्रॉम्प्ट में कम्पोज़र कमांड टाइप करके इंस्टॉलेशन की जाँच करें जैसा कि निम्नलिखित स्क्रीनशॉट में दिखाया गया है।
Step 3- अपने नए Laravel प्रोजेक्ट के लिए अपने सिस्टम में कहीं भी एक नई निर्देशिका बनाएं। उसके बाद, उस पथ पर जाएं जहां आपने नई निर्देशिका बनाई है और लारवेल को स्थापित करने के लिए निम्नलिखित कमांड टाइप करें।
composer create-project laravel/laravel –-prefer-dist
अब, हम संस्करण 5.7 की स्थापना पर ध्यान केंद्रित करेंगे। Laravel संस्करण 5.7 में, आप निम्नलिखित कमांड टाइप करके पूरा ढांचा स्थापित कर सकते हैं -
composer create-project laravel/laravel test dev-develop
कमांड का आउटपुट नीचे दिखाया गया है -
लारवेल ढांचे को सीधे विकसित शाखा के साथ स्थापित किया जा सकता है जिसमें नवीनतम ढांचा शामिल है।
Step 4- उपरोक्त कमांड करंट डायरेक्टरी में लारवेल को इंस्टॉल करेगा। निम्नलिखित कमांड निष्पादित करके लारवेल सेवा शुरू करें।
php artisan serve
Step 5 - उपरोक्त कमांड निष्पादित करने के बाद, आपको नीचे दिखाए गए अनुसार एक स्क्रीन दिखाई देगी -
Step 6- उपरोक्त स्क्रीनशॉट में भूरे रंग में रेखांकित URL को कॉपी करें और ब्राउज़र में उस URL को खोलें। यदि आप निम्न स्क्रीन देखते हैं, तो इसका अर्थ है कि लारवेल सफलतापूर्वक स्थापित किया गया है।
लारवेल में आवेदन संरचना मूल रूप से एक परियोजना में शामिल फ़ोल्डर्स, उप-फ़ोल्डर और फ़ाइलों की संरचना है। एक बार जब हम लारवेल में एक परियोजना बनाते हैं, तो हमें एप्लिकेशन संरचना का अवलोकन मिलता है जैसा कि यहां चित्र में दिखाया गया है।
यहाँ दिखाया गया स्नैपशॉट लारवेल के रूट फ़ोल्डर को संदर्भित करता है laravel-project। इसमें विभिन्न उप-फ़ोल्डर और फाइलें शामिल हैं। फ़ोल्डर्स और फ़ाइलों का विश्लेषण, उनके कार्यात्मक पहलुओं के साथ नीचे दिया गया है -
एप्लिकेशन
यह एप्लिकेशन फ़ोल्डर है और इसमें परियोजना का संपूर्ण स्रोत कोड शामिल है। इसमें ईवेंट, अपवाद और मिडलवेयर घोषणा शामिल हैं। एप्लिकेशन फ़ोल्डर में नीचे बताए गए विभिन्न उप फ़ोल्डर शामिल हैं -
कंसोल
कंसोल में लारवेल के लिए आवश्यक कारीगर कमांड शामिल हैं। इसमें एक निर्देशिका नाम शामिल हैCommands, जहां सभी आदेश उचित हस्ताक्षर के साथ घोषित किए जाते हैं। फ़ाइलKernal.php में घोषित आदेशों को कॉल करता है Inspire.php।
यदि हमें लारवेल में एक विशिष्ट कमांड को कॉल करने की आवश्यकता है, तो हमें इस निर्देशिका में उचित बदलाव करना चाहिए।
आयोजन
इस फ़ोल्डर में प्रोजेक्ट के लिए सभी ईवेंट शामिल हैं।
घटनाओं का उपयोग गतिविधियों को ट्रिगर करने, त्रुटियों या आवश्यक मान्यताओं को बढ़ाने और अधिक लचीलापन प्रदान करने के लिए किया जाता है। लारवेल सभी घटनाओं को एक निर्देशिका के अंतर्गत रखता है। शामिल डिफ़ॉल्ट फ़ाइल हैevent.php जहां सभी बुनियादी कार्यक्रम घोषित किए जाते हैं।
अपवाद
इस फ़ोल्डर में अपवादों को संभालने के लिए आवश्यक सभी विधियाँ हैं। इसमें फ़ाइल भी हैhandle.php जो सभी अपवादों को संभालता है।
एचटीटीपी
Httpफ़ोल्डर में नियंत्रक, मिडलवेयर और एप्लिकेशन अनुरोधों के लिए उप-फ़ोल्डर हैं। जैसा कि Laravel MVC डिज़ाइन पैटर्न का अनुसरण करता है, इस फ़ोल्डर में विशिष्ट निर्देशिकाओं के लिए परिभाषित मॉडल, नियंत्रक और विचार शामिल हैं।
Middleware उप-फ़ोल्डर में मिडिलवेयर तंत्र शामिल है, जिसमें प्रतिक्रिया और अनुरोध के बीच फिल्टर तंत्र और संचार शामिल है।
Requests उप-फ़ोल्डर में एप्लिकेशन के सभी अनुरोध शामिल हैं।
नौकरियां
Jobsनिर्देशिका लारवेल आवेदन के लिए कतारबद्ध गतिविधियों को बनाए रखती है। बेस क्लास सभी जॉब्स के बीच साझा किया जाता है और उन्हें एक छत के नीचे रखने के लिए एक केंद्रीय स्थान प्रदान करता है।
श्रोताओं
श्रोता घटना-आश्रित होते हैं और उनमें वे विधियाँ शामिल होती हैं जिनका उपयोग घटनाओं और अपवादों को संभालने के लिए किया जाता है। उदाहरण के लिए,login घोषित घटना में ए शामिल है LoginListener प्रतिस्पर्धा।
नीतियों
नीतियां PHP कक्षाएं हैं जिनमें प्राधिकरण तर्क शामिल हैं। लारवेल में इस उप फ़ोल्डर के अंदर नीति वर्गों के भीतर सभी प्राधिकरण तर्क बनाने की सुविधा शामिल है।
प्रदाताओं
इस फ़ोल्डर में कोर सर्वर के लिए घटनाओं को पंजीकृत करने और एक लारवेल एप्लिकेशन को कॉन्फ़िगर करने के लिए आवश्यक सभी सेवा प्रदाता शामिल हैं।
बूटस्ट्रैप
यह फ़ोल्डर सभी एप्लिकेशन बूटस्ट्रैप स्क्रिप्ट को संलग्न करता है। इसमें एक सब-फोल्डर शामिल हैcache, जिसमें एक वेब एप्लिकेशन को कैशिंग करने से जुड़ी सभी फाइलें शामिल हैं। आप फ़ाइल भी पा सकते हैंapp.php, जो बूटस्ट्रैप के लिए आवश्यक स्क्रिप्ट को इनिशियलाइज़ करता है।
कॉन्फ़िग
configफ़ोल्डर में विभिन्न विन्यास और संबद्ध पैरामीटर शामिल हैं जो लारवेल एप्लिकेशन के सुचारू संचालन के लिए आवश्यक हैं। कॉन्फिग फोल्डर के भीतर शामिल विभिन्न फाइलों को इमेज में दिखाया गया है। फ़ाइल नाम उनके साथ जुड़ी कार्यक्षमता के अनुसार काम करता है।
डेटाबेस
जैसा कि नाम से पता चलता है, इस निर्देशिका में डेटाबेस फ़ंक्शंस के लिए विभिन्न पैरामीटर शामिल हैं। इसमें नीचे दिए गए अनुसार तीन उप-निर्देशिकाएं शामिल हैं -
Seeds - इसमें यूनिट परीक्षण डेटाबेस के लिए उपयोग की जाने वाली कक्षाएं शामिल हैं।
Migrations - यह फ़ोल्डर वेब एप्लिकेशन में उपयोग होने वाले डेटाबेस को माइग्रेट करने के लिए क्वेरीज़ में मदद करता है।
Factories - इस फ़ोल्डर का उपयोग बड़ी संख्या में डेटा रिकॉर्ड बनाने के लिए किया जाता है।
जनता
यह रूट फ़ोल्डर है जो लारवेल एप्लिकेशन को आरंभ करने में मदद करता है। इसमें निम्न फाइलें और फ़ोल्डर्स शामिल हैं -
.htaccess - यह फाइल सर्वर कॉन्फ़िगरेशन देती है।
javascript and css - इन फाइलों को संपत्ति माना जाता है।
index.php - यह फ़ाइल एक वेब अनुप्रयोग के प्रारंभ के लिए आवश्यक है।
साधन
संसाधन निर्देशिका में वे फाइलें होती हैं जो आपके वेब एप्लिकेशन को बढ़ाती हैं। इस निर्देशिका में शामिल किए गए उप-फ़ोल्डर्स और उनके उद्देश्य को नीचे समझाया गया है -
assets - संपत्ति फ़ोल्डर में LESS और SCSS जैसी फाइलें शामिल हैं, जो वेब एप्लिकेशन को स्टाइल करने के लिए आवश्यक हैं।
lang - इस फ़ोल्डर में स्थानीयकरण या आंतरिककरण के लिए कॉन्फ़िगरेशन शामिल है।
views - दृश्य एचटीएमएल फाइलें या टेम्प्लेट हैं जो अंत उपयोगकर्ताओं के साथ बातचीत करते हैं और एमवीसी वास्तुकला में एक प्राथमिक भूमिका निभाते हैं।
देखें कि संपत्ति निर्देशिका होने के बजाय संसाधन निर्देशिका को समतल किया जाएगा। उसी का सचित्र प्रतिनिधित्व नीचे दिखाया गया है -
भंडारण
यह वह फ़ोल्डर है जो सभी लॉग और आवश्यक फ़ाइलों को संग्रहीत करता है जिनकी आवश्यकता तब होती है जब एक लारवेल परियोजना चल रही होती है। इस निर्देशिका में शामिल किए गए उप-फ़ोल्डर और उनका उद्देश्य नीचे दिया गया है -
app - इस फोल्डर में वे फाइलें होती हैं जिन्हें उत्तराधिकार में कहा जाता है।
framework - इसमें सत्र, कैश और विचार शामिल होते हैं जिन्हें अक्सर कहा जाता है।
Logs - सभी अपवाद और त्रुटि लॉग इस उप फ़ोल्डर में ट्रैक किए जाते हैं।
परीक्षण
इस निर्देशिका में सभी यूनिट परीक्षण मामलों को शामिल किया गया है। नामकरण परीक्षण केस कक्षाओं के नामकरण सम्मेलन हैcamel_case और कक्षा की कार्यक्षमता के अनुसार सम्मेलन का अनुसरण करता है।
विक्रेता
लारवेल पूरी तरह से कंपोजर निर्भरता पर आधारित है, उदाहरण के लिए लारवेल सेटअप को स्थापित करने के लिए या तीसरे पक्ष के पुस्तकालयों को शामिल करने के लिए, वेंडर फ़ोल्डर में सभी कंपोजर निर्भरताएं शामिल हैं।
उपर्युक्त फाइलों के अलावा, लारवेल में कुछ अन्य फाइलें भी शामिल हैं, जो विभिन्न कार्यात्मकताओं जैसे कि GitHub कॉन्फ़िगरेशन, पैकेज और तीसरे पक्ष के पुस्तकालयों में प्राथमिक भूमिका निभाती हैं।
एप्लिकेशन संरचना में शामिल फाइलें नीचे दिखाई गई हैं -
पिछले अध्याय में, हमने देखा है कि लारवेल की बुनियादी विन्यास फाइल में शामिल हैं configनिर्देशिका। इस अध्याय में, आइए विन्यास में शामिल श्रेणियों पर चर्चा करें।
पर्यावरण विन्यास
पर्यावरण चर वे हैं जो आपके वेब एप्लिकेशन को वेब सेवाओं की एक सूची प्रदान करते हैं। सभी पर्यावरण चर में घोषित किए गए हैं.env फ़ाइल जिसमें कॉन्फ़िगरेशन को शुरू करने के लिए आवश्यक पैरामीटर शामिल हैं।
डिफ़ॉल्ट रूप से, .env फ़ाइल में निम्नलिखित पैरामीटर शामिल हैं -
APP_ENV = local
APP_DEBUG = true
APP_KEY = base64:ZPt2wmKE/X4eEhrzJU6XX4R93rCwYG8E2f8QUA7kGK8 =
APP_URL = http://localhost
DB_CONNECTION = mysql
DB_HOST = 127.0.0.1
DB_PORT = 3306
DB_DATABASE = homestead
DB_USERNAME = homestead
DB_PASSWORD = secret
CACHE_DRIVER = file
SESSION_DRIVER = file
QUEUE_DRIVER = sync
REDIS_HOST = 127.0.0.1
REDIS_PASSWORD = null
REDIS_PORT = 6379
MAIL_DRIVER = smtp
MAIL_HOST = mailtrap.ioMAIL_PORT = 2525
MAIL_USERNAME = null
MAIL_PASSWORD = null
MAIL_ENCRYPTION = null
महत्वपूर्ण बिंदु
लारवेल की बुनियादी विन्यास फाइलों के साथ काम करते समय, निम्नलिखित बातों पर ध्यान दिया जाना चाहिए -
.env फ़ाइल को एप्लिकेशन स्रोत नियंत्रण के लिए प्रतिबद्ध नहीं होना चाहिए, क्योंकि प्रत्येक डेवलपर या उपयोगकर्ता के पास वेब एप्लिकेशन के लिए कुछ पूर्वनिर्धारित पर्यावरण कॉन्फ़िगरेशन है।
बैकअप विकल्पों के लिए, विकास टीम में शामिल होना चाहिए .env.example फ़ाइल, जिसमें डिफ़ॉल्ट कॉन्फ़िगरेशन होना चाहिए।
पर्यावरण चर की पुनर्प्राप्ति
में घोषित सभी पर्यावरण चर .env फ़ाइल द्वारा पहुँचा जा सकता है env-helperफ़ंक्शन जो संबंधित पैरामीटर को कॉल करेगा। इन चरों को भी सूचीबद्ध किया गया है$_ENVवैश्विक चर जब भी एप्लिकेशन को उपयोगकर्ता के अंत से अनुरोध प्राप्त होता है। आप नीचे दिखाए अनुसार पर्यावरण चर का उपयोग कर सकते हैं -
'env' => env('APP_ENV', 'production'),
env-helper कार्यों में कहा जाता है app.php में शामिल फ़ाइल configफ़ोल्डर। ऊपर दिया गया उदाहरण मूल स्थानीय पैरामीटर के लिए कॉल कर रहा है।
कॉन्फ़िगरेशन मान एक्सेस करना
आप वैश्विक कॉन्फ़िगरेशन सहायक फ़ंक्शन का उपयोग करके एप्लिकेशन में कहीं भी कॉन्फ़िगरेशन मान आसानी से एक्सेस कर सकते हैं। यदि कॉन्फ़िगरेशन मान आरंभ नहीं किए गए हैं, तो डिफ़ॉल्ट मान लौटाए जाते हैं।
उदाहरण के लिए, डिफ़ॉल्ट समय क्षेत्र सेट करने के लिए, निम्नलिखित कोड का उपयोग किया जाता है -
config(['app.timezone' => 'Asia/Kolkata']);
विन्यास की कैशिंग
प्रदर्शन को बढ़ाने और वेब एप्लिकेशन को बढ़ावा देने के लिए, सभी कॉन्फ़िगरेशन मानों को कैश करना महत्वपूर्ण है। कॉन्फ़िगरेशन मूल्यों को कैशिंग करने के लिए कमांड है -
config:cache
निम्न स्क्रीनशॉट एक व्यवस्थित दृष्टिकोण में कैशिंग दिखाता है -
रखरखाव मोड
कभी-कभी आपको कुछ कॉन्फ़िगरेशन मूल्यों को अपडेट करने या अपनी वेबसाइट पर रखरखाव करने की आवश्यकता हो सकती है। ऐसे मामलों में, इसे अंदर रखनाmaintenance mode, यह आपके लिए आसान बनाता है। ऐसे वेब एप्लिकेशन जो रखरखाव मोड में रखे जाते हैं, अपवाद छोड़ देते हैंMaintenanceModeException 503 की स्थिति कोड के साथ।
आप निम्न कमांड का उपयोग करके अपने लारवेल वेब एप्लिकेशन पर रखरखाव मोड को सक्षम कर सकते हैं -
php artisan down
निम्न स्क्रीनशॉट से पता चलता है कि नीचे होने पर वेब एप्लिकेशन कैसा दिखता है -
एक बार जब आप अपडेट और अन्य रखरखाव पर काम करना समाप्त कर लेते हैं, तो आप निम्नलिखित आदेश का उपयोग करके अपने वेब एप्लिकेशन पर रखरखाव मोड को अक्षम कर सकते हैं -
php artisan up
अब, आप पा सकते हैं कि वेबसाइट उचित कार्यप्रणाली के साथ आउटपुट दिखाती है और दर्शाती है कि रखरखाव मोड अब नीचे दिखाए अनुसार हटा दिया गया है -
लारवेल में, सभी अनुरोधों को मार्गों की सहायता से मैप किया जाता है। बुनियादी मार्ग संबंधित नियंत्रकों के लिए अनुरोध मार्ग। इस अध्याय में लारवेल में रूटिंग पर चर्चा की गई है।
लारवेल में रूटिंग में निम्नलिखित श्रेणियां शामिल हैं -
- बेसिक रूटिंग
- रूट पैरामीटर
- जिसका नाम रूट्स रखा गया है
बेसिक रूटिंग
सभी आवेदन मार्गों के भीतर पंजीकृत हैं app/routes.phpफ़ाइल। यह फ़ाइल URI के लिए लारवेल को बताती है कि उसे इसका जवाब देना चाहिए और संबंधित नियंत्रक इसे एक विशेष कॉल देगा। स्वागत पृष्ठ के लिए नमूना मार्ग नीचे दिए गए स्क्रीनशॉट में दिखाया जा सकता है -
Route::get ('/', function () {
return view('welcome');});
उदाहरण
रूटिंग के बारे में अधिक समझने के लिए निम्नलिखित उदाहरण देखें -
app/Http/routes.php
<?php
Route::get('/', function () {
return view('welcome');
});
resources/view/welcome.blade.php
<!DOCTYPE html>
<html>
<head>
<title>Laravel</title>
<link href = "https://fonts.googleapis.com/css?family=Lato:100" rel = "stylesheet"
type = "text/css">
<style>
html, body {
height: 100%;
}
body {
margin: 0;
padding: 0;
width: 100%;
display: table;
font-weight: 100;
font-family: 'Lato';
}
.container {
text-align: center;
display: table-cell;
vertical-align: middle;
}
.content {
text-align: center;
display: inline-block;
}
.title {
font-size: 96px;
}
</style>
</head>
<body>
<div class = "container">
<div class = "content">
<div class = "title">Laravel 5.1</div>
</div>
</div>
</body>
</html>
रूटिंग तंत्र को नीचे दी गई छवि में दिखाया गया है -
आइए अब रूटिंग तंत्र में शामिल चरणों को विस्तार से समझते हैं -
Step 1 - शुरू में, हमें एप्लिकेशन के रूट URL को निष्पादित करना चाहिए।
Step 2 - अब, निष्पादित URL उपयुक्त विधि से मेल खाना चाहिए route.phpफ़ाइल। वर्तमान स्थिति में, यह विधि और रूट ('/') URL से मेल खाना चाहिए। यह संबंधित फ़ंक्शन को निष्पादित करेगा।
Step 3 - फ़ंक्शन टेम्प्लेट फ़ाइल को कॉल करता है resources/views/welcome.blade.php. अगला, फ़ंक्शन कॉल करता है view() तर्क के साथ कार्य करें ‘welcome’ का उपयोग किए बिना blade.php।
यह नीचे दिए गए चित्र में दिखाए गए अनुसार HTML आउटपुट का उत्पादन करेगा -
मार्ग पैरामीटर
कभी-कभी वेब एप्लिकेशन में, आपको URL के साथ दिए गए मापदंडों को पकड़ना पड़ सकता है। इसके लिए, आपको कोड को संशोधित करना चाहिएroutes.php फ़ाइल।
आप मापदंडों को कैप्चर कर सकते हैं routes.php दो तरीकों से फ़ाइल के रूप में यहाँ चर्चा की -
आवश्यक पैरामीटर
ये पैरामीटर वे हैं जिन्हें वेब एप्लिकेशन को रूट करने के लिए अनिवार्य रूप से कैप्चर किया जाना चाहिए। उदाहरण के लिए, URL से उपयोगकर्ता की पहचान संख्या को कैप्चर करना महत्वपूर्ण है। नीचे दिखाए गए अनुसार मार्ग मापदंडों को परिभाषित करके यह संभव हो सकता है -
Route::get('ID/{id}',function($id) {
echo 'ID: '.$id;
});
वैकल्पिक पैरामीटर
कभी-कभी डेवलपर्स पैरामीटर को वैकल्पिक के रूप में उत्पादन कर सकते हैं और यह शामिल करना संभव है ?URL में पैरामीटर नाम के बाद। पैरामीटर नाम के रूप में उल्लिखित डिफ़ॉल्ट मान को रखना महत्वपूर्ण है। निम्न उदाहरण देखें जो दिखाता है कि वैकल्पिक पैरामीटर को कैसे परिभाषित किया जाए -
Route::get('user/{name?}', function ($name = 'TutorialsPoint') { return $name;});
ऊपर का उदाहरण जाँच करता है कि मान किससे मेल खाता है TutorialsPoint और तदनुसार परिभाषित URL के लिए मार्ग।
जिसका नाम रूट्स रखा गया है
नामित मार्ग मार्गों को बनाने का एक सुविधाजनक तरीका प्रदान करते हैं। मार्ग परिभाषा पर नाम पद्धति का उपयोग करके मार्गों की जंजीर को निर्दिष्ट किया जा सकता है। निम्न कोड नियंत्रक के साथ नामित मार्गों को बनाने के लिए एक उदाहरण दिखाता है -
Route::get('user/profile', 'UserController@showProfile')->name('profile');
उपयोगकर्ता नियंत्रक फ़ंक्शन के लिए कॉल करेगा showProfile पैरामीटर के साथ profile। मापदंडों का उपयोग करेंname मार्ग परिभाषा पर विधि।
मिडलवेयर अनुरोध और प्रतिक्रिया के बीच एक सेतु का काम करता है। यह एक प्रकार का फ़िल्टरिंग तंत्र है। यह अध्याय आपको लारवेल में मिडिलवेयर तंत्र की व्याख्या करता है।
लारवेल में एक मिडलवेयर शामिल है जो यह सत्यापित करता है कि एप्लिकेशन का उपयोगकर्ता प्रमाणित है या नहीं। यदि उपयोगकर्ता प्रमाणित है, तो यह होम पेज पर रीडायरेक्ट करता है, यदि नहीं, तो यह लॉगिन पेज पर रीडायरेक्ट करता है।
मिडिलवेयर निम्नलिखित कमांड को निष्पादित करके बनाया जा सकता है -
php artisan make:middleware <middleware-name>
बदलो <middleware-name>अपने मिडलवेयर के नाम के साथ। आपके द्वारा बनाए जाने वाले मिडलवेयर को देखा जा सकता हैapp/Http/Middleware निर्देशिका।
उदाहरण
मिडलवेयर तंत्र को समझने के लिए निम्नलिखित उदाहरण देखें -
Step 1- अब हम AgeMiddleware बनाते हैं। इसे बनाने के लिए, हमें निम्नलिखित कमांड निष्पादित करने की आवश्यकता है -
php artisan make:middleware AgeMiddleware
Step 2 - कमांड के सफल निष्पादन के बाद, आपको निम्न आउटपुट प्राप्त होंगे -
Step 3 - AgeMiddleware पर बनाया जाएगा app/Http/Middleware। नई बनाई गई फ़ाइल में आपके लिए पहले से बना हुआ कोड होगा।
<?php
namespace App\Http\Middleware;
use Closure;
class AgeMiddleware {
public function handle($request, Closure $next) { return $next($request);
}
}
मिडिलवेयर का पंजीकरण
हमें इसका उपयोग करने से पहले प्रत्येक मिडलवेयर को पंजीकृत करना होगा। लारवेल में दो प्रकार के मिडलवेयर हैं।
- ग्लोबल मिडिलवेयर
- रूट मिडिलवेयर
Global Middleware आवेदन के हर HTTP अनुरोध पर चलेगा, जबकि Route Middlewareएक विशिष्ट मार्ग को सौंपा जाएगा। मिडलवेयर में पंजीकृत किया जा सकता हैapp/Http/Kernel.php. इस फ़ाइल में दो गुण हैं $middleware तथा $routeMiddleware। $middleware संपत्ति का उपयोग ग्लोबल मिडलवेयर और रजिस्टर करने के लिए किया जाता है $routeMiddleware संपत्ति का उपयोग मार्ग विशिष्ट मिडलवेयर को पंजीकृत करने के लिए किया जाता है।
वैश्विक मिडलवेयर को पंजीकृत करने के लिए, $ मिडलवेयर प्रॉपर्टी के अंत में क्लास को सूचीबद्ध करें।
protected $middleware = [
\Illuminate\Foundation\Http\Middleware\CheckForMaintenanceMode::class,
\App\Http\Middleware\EncryptCookies::class,
\Illuminate\Cookie\Middleware\AddQueuedCookiesToResponse::class,
\Illuminate\Session\Middleware\StartSession::class,
\Illuminate\View\Middleware\ShareErrorsFromSession::class,
\App\Http\Middleware\VerifyCsrfToken::class,
];
मार्ग विशिष्ट मिडिलवेयर को पंजीकृत करने के लिए, $ मार्गमाडेलवेयर संपत्ति के लिए कुंजी और मूल्य जोड़ें।
protected $routeMiddleware = [
'auth' => \App\Http\Middleware\Authenticate::class,
'auth.basic' => \Illuminate\Auth\Middleware\AuthenticateWithBasicAuth::class,
'guest' => \App\Http\Middleware\RedirectIfAuthenticated::class,
];
उदाहरण
हमने बनाया है AgeMiddlewareपिछले उदाहरण में। अब हम इसे रूट विशिष्ट मिडलवेयर प्रॉपर्टी में पंजीकृत कर सकते हैं। उस पंजीकरण का कोड नीचे दिखाया गया है।
निम्नलिखित के लिए कोड है app/Http/Kernel.php -
<?php
namespace App\Http;
use Illuminate\Foundation\Http\Kernel as HttpKernel;
class Kernel extends HttpKernel {
protected $middleware = [
\Illuminate\Foundation\Http\Middleware\CheckForMaintenanceMode::class,
\App\Http\Middleware\EncryptCookies::class,
\Illuminate\Cookie\Middleware\AddQueuedCookiesToResponse::class,
\Illuminate\Session\Middleware\StartSession::class,
\Illuminate\View\Middleware\ShareErrorsFromSession::class,
\App\Http\Middleware\VerifyCsrfToken::class,
];
protected $routeMiddleware = [
'auth' => \App\Http\Middleware\Authenticate::class,
'auth.basic' => \Illuminate\Auth\Middleware\AuthenticateWithBasicAuth::class,
'guest' => \App\Http\Middleware\RedirectIfAuthenticated::class,
'Age' => \App\Http\Middleware\AgeMiddleware::class,
];
}
मिडलवेयर पैरामीटर्स
हम मिडलवेयर के साथ पैरामीटर भी पास कर सकते हैं। उदाहरण के लिए, यदि आपके एप्लिकेशन में उपयोगकर्ता, व्यवस्थापक, सुपर व्यवस्थापक आदि जैसी विभिन्न भूमिकाएं हैं और आप भूमिका के आधार पर कार्रवाई को प्रमाणित करना चाहते हैं, तो इसे मिडलवेयर के साथ पैरामीटर पास करके प्राप्त किया जा सकता है। हमारे द्वारा बनाए जाने वाले मिडलवेयर में निम्नलिखित फ़ंक्शन होते हैं और हम अपने कस्टम तर्क को पास कर सकते हैं$next बहस।
public function handle($request, Closure $next) {
return $next($request);
}
उदाहरण
Step 1 - निम्नलिखित कमांड निष्पादित करके रोलमेडवेयर बनाएं -
php artisan make:middleware RoleMiddleware
Step 2 - सफल निष्पादन के बाद, आपको निम्न आउटपुट प्राप्त होंगे -
Step 3 - नए बनाए गए रोलमाइडलवेट के हैंडल विधि में निम्नलिखित कोड जोड़ें app/Http/Middleware/RoleMiddleware.php.
<?php
namespace App\Http\Middleware;
use Closure;
class RoleMiddleware {
public function handle($request, Closure $next, $role) { echo "Role: ".$role;
return $next($request);
}
}
Step 4 - में रोलमेडवेयर रजिस्टर करें app\Http\Kernel.phpफ़ाइल। भूमिका फ़ाइल को हाइलाइट करने के लिए उस फ़ाइल में ग्रे कलर में हाइलाइट की गई पंक्ति को जोड़ें।
Step 5 - बनाने के लिए निम्न कमांड निष्पादित करें TestController -
php artisan make:controller TestController --plain
Step 6 - उपरोक्त चरण के सफल निष्पादन के बाद, आपको निम्न आउटपुट प्राप्त होंगे -
Step 7 - कोड की निम्नलिखित पंक्तियों को कॉपी करें app/Http/TestController.php फ़ाइल।
app/Http/TestController.php
<?php
namespace App\Http\Controllers;
use Illuminate\Http\Request;
use App\Http\Requests;
use App\Http\Controllers\Controller;
class TestController extends Controller {
public function index() {
echo "<br>Test Controller.";
}
}
Step 8 - कोड की निम्नलिखित पंक्ति जोड़ें app/Http/routes.php फ़ाइल।
app/Http/routes.php
Route::get('role',[
'middleware' => 'Role:editor',
'uses' => 'TestController@index',
]);
Step 9 - मापदंडों के साथ मिडलवेयर का परीक्षण करने के लिए निम्न URL पर जाएं
http://localhost:8000/role
Step 10 - आउटपुट निम्न छवि में दिखाए गए अनुसार दिखाई देगा।
टर्मिनेबल मिडलवेयर
ब्राउज़र में प्रतिक्रिया भेजे जाने के बाद टर्मिनेबल मिडलवेयर कुछ कार्य करता है। इसके साथ एक मिडलवेयर बनाकर इसे पूरा किया जा सकता हैterminateमिडलवेयर में विधि। टर्मिनेबल मिडलवेयर को वैश्विक मिडलवेयर के साथ पंजीकृत होना चाहिए। समाप्ति की विधि दो तर्क प्राप्त करेगी$request तथा $response. समाप्ति विधि निम्न कोड में दिखाए अनुसार बनाई जा सकती है।
उदाहरण
Step 1 - बनाएं TerminateMiddleware नीचे दिए गए कमांड को निष्पादित करके।
php artisan make:middleware TerminateMiddleware
Step 2 - उपरोक्त चरण निम्न आउटपुट का उत्पादन करेगा -
Step 3 - नए बनाए गए में निम्न कोड को कॉपी करें TerminateMiddleware पर app/Http/Middleware/TerminateMiddleware.php.
<?php
namespace App\Http\Middleware;
use Closure;
class TerminateMiddleware {
public function handle($request, Closure $next) {
echo "Executing statements of handle method of TerminateMiddleware.";
return $next($request);
}
public function terminate($request, $response) {
echo "<br>Executing statements of terminate method of TerminateMiddleware.";
}
}
Step 4 - रजिस्टर करें TerminateMiddleware में app\Http\Kernel.phpफ़ाइल। TerminateMiddleware रजिस्टर करने के लिए उस फ़ाइल में ग्रे रंग में हाइलाइट की गई लाइन जोड़ें।
Step 5 - बनाने के लिए निम्न कमांड निष्पादित करें ABCController।
php artisan make:controller ABCController --plain
Step 6 - URL के सफल निष्पादन के बाद, आपको निम्न आउटपुट प्राप्त होंगे -
Step 7 - निम्न कोड को कॉपी करें app/Http/ABCController.php फ़ाइल।
app/Http/ABCController.php
<?php
namespace App\Http\Controllers;
use Illuminate\Http\Request;
use App\Http\Requests;
use App\Http\Controllers\Controller;
class ABCController extends Controller {
public function index() {
echo "<br>ABC Controller.";
}
}
Step 8 - कोड की निम्नलिखित पंक्ति जोड़ें app/Http/routes.php फ़ाइल।
app/Http/routes.php
Route::get('terminate',[
'middleware' => 'terminate',
'uses' => 'ABCController@index',
]);
Step 9 - टर्मिनेबल मिडलवेयर का परीक्षण करने के लिए निम्न URL पर जाएं।
http://localhost:8000/terminate
Step 10 - आउटपुट निम्न छवि में दिखाए गए अनुसार दिखाई देगा।
Namespaces को तत्वों के एक वर्ग के रूप में परिभाषित किया जा सकता है जिसमें प्रत्येक तत्व का उस संबद्ध वर्ग के लिए एक विशिष्ट नाम होता है। इसे अन्य वर्गों में तत्वों के साथ साझा किया जा सकता है।
नाम स्थान की घोषणा
use कीवर्ड डेवलपर्स को नामस्थान को छोटा करने की अनुमति देता है।
use <namespace-name>;
Laravel में प्रयुक्त डिफ़ॉल्ट नामस्थान ऐप है, हालांकि उपयोगकर्ता वेब एप्लिकेशन के साथ मिलान करने के लिए नाम स्थान को बदल सकता है। कारीगर कमांड के साथ उपयोगकर्ता परिभाषित नाम स्थान बनाना निम्नानुसार है -
php artisan app:name SocialNet
एक बार बनाए गए नाम स्थान में विभिन्न कार्यात्मकताएं शामिल हो सकती हैं जिनका उपयोग नियंत्रकों और विभिन्न वर्गों में किया जा सकता है।
एमवीसी ढांचे में, 'सी' अक्षर नियंत्रक के लिए खड़ा है। यह दृश्य और मॉडल के बीच निर्देशन यातायात के रूप में कार्य करता है। इस अध्याय में, आप लारवेल में नियंत्रकों के बारे में जानेंगे।
एक नियंत्रक बनाना
आपके द्वारा उपयोग किए जा रहे ऑपरेटिंग सिस्टम के आधार पर कमांड प्रॉम्प्ट या टर्मिनल खोलें और कारीगर CLI (कमांड लाइन इंटरफ़ेस) का उपयोग करके नियंत्रक बनाने के लिए निम्न कमांड टाइप करें।
php artisan make:controller <controller-name> --plain
अपने नियंत्रक के नाम के साथ <नियंत्रक-नाम> बदलें। जैसा कि हम तर्क दे रहे हैं, इससे एक सादा निर्माण होगा -plain। यदि आप एक सादा कंस्ट्रक्टर नहीं बनाना चाहते हैं, तो आप केवल तर्क को अनदेखा कर सकते हैं। बनाए गए निर्माण को देखा जा सकता हैapp/Http/Controllers।
आप देखेंगे कि कुछ बुनियादी कोडिंग आपके लिए पहले ही हो चुकी है और आप अपनी कस्टम कोडिंग जोड़ सकते हैं। निर्मित नियंत्रक को निम्नलिखित सिंटैक्स द्वारा मार्गों से कहा जा सकता है।
वाक्य - विन्यास
Route::get(‘base URI’,’controller@method’);
उदाहरण
Step 1 - बनाने के लिए निम्न कमांड निष्पादित करें UserController।
php artisan make:controller UserController --plain
Step 2 - सफल निष्पादन के बाद, आप निम्न आउटपुट प्राप्त करेंगे।
Step 3 - आप बनाया नियंत्रक पर देख सकते हैं app/Http/Controller/UserController.php आपके लिए पहले से ही लिखी गई कुछ बुनियादी कोडिंग के साथ और आप अपनी जरूरत के आधार पर अपनी खुद की कोडिंग जोड़ सकते हैं।
<?php
namespace App\Http\Controllers;
use Illuminate\Http\Request;
use App\Http\Requests;
use App\Http\Controllers\Controller;
class UserController extends Controller {
//
}
नियंत्रक मिडिलवेयर
हमने पहले मिडलवेयर देखा है और इसे कंट्रोलर के साथ भी इस्तेमाल किया जा सकता है। मिडलवेयर को कंट्रोलर के रूट या आपके कंट्रोलर के कंस्ट्रक्टर के भीतर भी सौंपा जा सकता है। कंट्रोलर को मिडिलवेयर असाइन करने के लिए आप मिडलवेयर विधि का उपयोग कर सकते हैं। पंजीकृत मिडलवेयर को कंट्रोलर की कुछ विधि तक भी सीमित रखा जा सकता है।
मार्ग के लिए मिडिलवेयर असाइन करना
Route::get('profile', [
'middleware' => 'auth',
'uses' => 'UserController@showProfile'
]);
यहाँ हम प्रोफाइल मार्ग में UserController को मिडिलवेयर असाइन कर रहे हैं।
कंट्रोलर के कंस्ट्रक्टर के भीतर मिडिलवेयर असाइन करना
<?php
namespace App\Http\Controllers;
use Illuminate\Http\Request;
use App\Http\Requests;
use App\Http\Controllers\Controller;
class UserController extends Controller {
public function __construct() {
$this->middleware('auth');
}
}
यहां हम असाइन कर रहे हैं auth में मिडिलवेयर विधि का उपयोग कर मिडलवेयर UserController निर्माता।
उदाहरण
Step 1 - कोड की निम्नलिखित पंक्तियों को इसमें जोड़ें app/Http/routes.php फ़ाइल करें और इसे सहेजें।
routes.php
<?php
Route::get('/usercontroller/path',[
'middleware' => 'First',
'uses' => 'UserController@showPath'
]);
Step 2 - नामक एक मिडलवेयर बनाएं FirstMiddleware कोड की निम्नलिखित पंक्ति निष्पादित करके।
php artisan make:middleware FirstMiddleware
Step 3 - में निम्नलिखित कोड जोड़ें handle नव निर्मित FirstMiddleware की विधि app/Http/Middleware।
FirstMiddleware.php
<?php
namespace App\Http\Middleware;
use Closure;
class FirstMiddleware {
public function handle($request, Closure $next) { echo '<br>First Middleware'; return $next($request);
}
}
Step 4 - नामक एक मिडलवेयर बनाएं SecondMiddleware निम्नलिखित कमांड निष्पादित करके।
php artisan make:middleware SecondMiddleware
Step 5 - नव निर्मित SecondMiddleware के हैंडल विधि में निम्नलिखित कोड जोड़ें app/Http/Middleware।
SecondMiddleware.php
<?php
namespace App\Http\Middleware;
use Closure;
class SecondMiddleware {
public function handle($request, Closure $next) { echo '<br>Second Middleware'; return $next($request);
}
}
Step 6 - एक नियंत्रक बनाएँ UserController निम्नलिखित पंक्ति निष्पादित करके।
php artisan make:controller UserController --plain
Step 7 - URL के सफल निष्पादन के बाद, आपको निम्न आउटपुट प्राप्त होंगे -
Step 8 - निम्न कोड को कॉपी करें app/Http/UserController.php फ़ाइल।
app/Http/UserController.php
<?php
namespace App\Http\Controllers;
use Illuminate\Http\Request;
use App\Http\Requests;
use App\Http\Controllers\Controller;
class UserController extends Controller {
public function __construct() {
$this->middleware('Second');
}
public function showPath(Request $request) { $uri = $request->path(); echo '<br>URI: '.$uri;
$url = $request->url();
echo '<br>';
echo 'URL: '.$url; $method = $request->method(); echo '<br>'; echo 'Method: '.$method;
}
}
Step 9 - अगर आपने अभी तक इसे निष्पादित नहीं किया है, तो निम्न कमांड को निष्पादित करके php के आंतरिक वेब सर्वर को लॉन्च करें।
php artisan serve
Step 10 - निम्न URL पर जाएं।
http://localhost:8000/usercontroller/path
Step 11 - आउटपुट निम्न छवि में दिखाए गए अनुसार दिखाई देगा।
रेस्टफुल रिसोर्स कंट्रोलर्स
अक्सर एक आवेदन करते समय हमें प्रदर्शन करने की आवश्यकता होती है CRUD (Create, Read, Update, Delete)संचालन। लारवेल हमारे लिए इस काम को आसान बनाता है। बस एक नियंत्रक बनाएं और लारवेल स्वचालित रूप से सीआरयूडी संचालन के लिए सभी तरीके प्रदान करेगा। आप सभी विधियों के लिए एक एकल मार्ग भी पंजीकृत कर सकते हैं।
उदाहरण
Step 1 - एक नियंत्रक बनाएँ MyController निम्नलिखित कमांड निष्पादित करके।
php artisan make:controller MyController
Step 2 - निम्नलिखित कोड जोड़ें
app/Http/Controllers/MyController.php फ़ाइल।
app/Http/Controllers/MyController.php
<?php
namespace App\Http\Controllers;
use Illuminate\Http\Request;
use App\Http\Requests;
use App\Http\Controllers\Controller;
class MyController extends Controller {
public function index() {
echo 'index';
}
public function create() {
echo 'create';
}
public function store(Request $request) { echo 'store'; } public function show($id) {
echo 'show';
}
public function edit($id) { echo 'edit'; } public function update(Request $request, $id) { echo 'update'; } public function destroy($id) {
echo 'destroy';
}
}
Step 3 - कोड की निम्नलिखित पंक्ति जोड़ें app/Http/routes.php फ़ाइल।
app/Http/routes.php
Route::resource('my','MyController');
Step 4- हम अब संसाधन के साथ एक नियंत्रक को पंजीकृत करके MyController के सभी तरीकों को पंजीकृत कर रहे हैं। नीचे संसाधन नियंत्रक द्वारा नियंत्रित कार्यों की तालिका है।
क्रिया | पथ | कार्य | मार्ग का नाम |
---|---|---|---|
प्राप्त | /मेरे | सूची | my.index |
प्राप्त | / मेरी / बनाने | सृजन करना | my.create |
पद | /मेरे | दुकान | मेरी दुकान |
प्राप्त | /वाह वाह} | प्रदर्शन | मेरा कार्यक्रम |
प्राप्त | / मेरी / {मेरी} / संपादित करें | संपादित करें | मेरा सम्पादन |
PUT / PATCH | /वाह वाह} | अपडेट करें | my.update |
हटाएँ | /वाह वाह} | नष्ट | my.destroy |
Step 5 - निम्नलिखित तालिका में दिखाए गए URL को निष्पादित करने का प्रयास करें।
यूआरएल | विवरण | आउटपुट छवि |
---|---|---|
http: // localhost: 8000 / मेरी | MyController.php की अनुक्रमणिका विधि निष्पादित करता है | सूची |
http: // localhost: 8000 / मेरी / बनाने | निष्पादन MyController.php की विधि बनाते हैं | सृजन करना |
http: // localhost: 8000 / मेरी / 1 | निष्पादित MyController.php की विधि दिखाते हैं | प्रदर्शन |
http: // localhost: 8000 / मेरी / 1 / संपादित करें | निष्पादन MyController.php की विधि संपादित करें | संपादित करें |
प्रभावकारी नियंत्रक
नियंत्रक नियंत्रकों आपको नियंत्रक में हर क्रिया को संभालने के लिए एक मार्ग को परिभाषित करने की अनुमति देते हैं। आप इसे path.php फ़ाइल के साथ परिभाषित कर सकते हैंRoute:controller तरीका नीचे दिखाया गया है।
Route::controller(‘base URI’,’<class-name-of-the-controller>’);
अपने नियंत्रक को दिए गए वर्ग नाम के साथ <वर्ग-नाम-की-नियंत्रक> बदलें।
कंट्रोलर की विधि का नाम HTTP क्रिया के साथ शुरू होना चाहिए जैसे कि प्राप्त करें या पोस्ट करें। यदि आप इसे प्राप्त करना शुरू करते हैं, तो यह केवल अनुरोध प्राप्त करने का काम करेगा और यदि यह पोस्ट से शुरू होता है, तो यह पोस्ट अनुरोध को संभाल लेगा। HTTP वर्ब के बाद, आप विधि को कोई भी नाम दे सकते हैं लेकिन उसे URI के शीर्षक केस संस्करण का पालन करना चाहिए।
उदाहरण
Step 1- नियंत्रक बनाने के लिए नीचे दिए गए आदेश को निष्पादित करें। हमने क्लास का नाम रखा हैImplicitController। आप अपनी पसंद का कोई भी नाम कक्षा को दे सकते हैं।
php artisan make:controller ImplicitController --plain
Step 2 - चरण 1 के सफल निष्पादन के बाद, आपको निम्न आउटपुट प्राप्त होंगे -
Step 3 - निम्न कोड को कॉपी करें
app/Http/Controllers/ImplicitController.php फ़ाइल।
app/Http/Controllers/ImplicitController.php
<?php
namespace App\Http\Controllers;
use Illuminate\Http\Request;
use App\Http\Requests;
use App\Http\Controllers\Controller;
class ImplicitController extends Controller {
/**
* Responds to requests to GET /test
*/
public function getIndex() {
echo 'index method';
}
/**
* Responds to requests to GET /test/show/1
*/
public function getShow($id) {
echo 'show method';
}
/**
* Responds to requests to GET /test/admin-profile
*/
public function getAdminProfile() {
echo 'admin profile method';
}
/**
* Responds to requests to POST /test/profile
*/
public function postProfile() {
echo 'profile method';
}
}
Step 4 - निम्न पंक्ति को इसमें जोड़ें app/Http/routes.php निर्दिष्ट नियंत्रक के अनुरोधों को रूट करने के लिए फ़ाइल।
app/Http/routes.php
Route::controller('test','ImplicitController');
कंस्ट्रक्टर इंजेक्शन
Laravel सर्विस कंटेनर का उपयोग सभी Laravel नियंत्रकों को हल करने के लिए किया जाता है। नतीजतन, आप किसी भी निर्भरता को टाइप करने में सक्षम हैं जो आपके नियंत्रक को इसके निर्माता में आवश्यकता हो सकती है। निर्भरताएँ स्वचालित रूप से हल हो जाएंगी और नियंत्रक उदाहरण में इंजेक्ट की जाएंगी।
उदाहरण
Step 1 - निम्न कोड को इसमें जोड़ें app/Http/routes.php फ़ाइल।
app/Http/routes.php
class MyClass{
public $foo = 'bar';
}
Route::get('/myclass','ImplicitController@index');
Step 2 - निम्न कोड को इसमें जोड़ें
app/Http/Controllers/ImplicitController.php फ़ाइल।
app/Http/Controllers/ImplicitController.php
<?php
namespace App\Http\Controllers;
use Illuminate\Http\Request;
use App\Http\Requests;
use App\Http\Controllers\Controller;
class ImplicitController extends Controller {
private $myclass; public function __construct(\MyClass $myclass) {
$this->myclass = $myclass;
}
public function index() {
dd($this->myclass);
}
}
Step 3 - कंस्ट्रक्टर इंजेक्शन का परीक्षण करने के लिए निम्न URL पर जाएं।
http://localhost:8000/myclass
Step 4 - आउटपुट निम्न छवि में दिखाए गए अनुसार दिखाई देगा।
विधि इंजेक्शन
कंस्ट्रक्टर इंजेक्शन के अलावा, आप अपने कंट्रोलर के एक्शन तरीकों पर निर्भरता भी टाइप कर सकते हैं।
उदाहरण
Step 1 - निम्न कोड को इसमें जोड़ें app/Http/routes.php फ़ाइल।
app/Http/routes.php
class MyClass{
public $foo = 'bar';
}
Route::get('/myclass','ImplicitController@index');
Step 2 - निम्न कोड को इसमें जोड़ें
app/Http/Controllers/ImplicitController.php फ़ाइल।
app/Http/Controllers/ImplicitController.php
<?php
namespace App\Http\Controllers;
use Illuminate\Http\Request;
use App\Http\Requests;
use App\Http\Controllers\Controller;
class ImplicitController extends Controller {
public function index(\MyClass $myclass) { dd($myclass);
}
}
Step 3 - कंस्ट्रक्टर इंजेक्शन का परीक्षण करने के लिए निम्न URL पर जाएं।
http://localhost:8000/myclass
यह निम्नलिखित उत्पादन का उत्पादन करेगा -
इस अध्याय में, आप लारवेल में अनुरोधों के बारे में विस्तार से जानेंगे।
URI का अनुरोध पुनः प्राप्त कर रहा है
The “path” method is used to retrieve the requested URI. The is method is used to retrieve the requested URI which matches the particular pattern specified in the argument of the method. To get the full URL, we can use the url method.
Example
Step 1 − Execute the below command to create a new controller called UriController.
php artisan make:controller UriController –plain
Step 2 − After successful execution of the URL, you will receive the following output −
Step 3 − After creating a controller, add the following code in that file.
app/Http/Controllers/UriController.php
<?php
namespace App\Http\Controllers;
use Illuminate\Http\Request;
use App\Http\Requests;
use App\Http\Controllers\Controller;
class UriController extends Controller {
public function index(Request $request) { // Usage of path method $path = $request->path(); echo 'Path Method: '.$path;
echo '<br>';
// Usage of is method
$pattern = $request->is('foo/*');
echo 'is Method: '.$pattern; echo '<br>'; // Usage of url method $url = $request->url(); echo 'URL method: '.$url;
}
}
Step 4 - में निम्न पंक्ति जोड़ें app/Http/route.php फ़ाइल।
app/Http/route.php
Route::get('/foo/bar','UriController@index');
Step 5 - निम्न URL पर जाएं।
http://localhost:8000/foo/bar
Step 6 - आउटपुट निम्न छवि में दिखाए गए अनुसार दिखाई देगा।
पुनः प्राप्त इनपुट
लारवेल में इनपुट मूल्यों को आसानी से प्राप्त किया जा सकता है। कोई फर्क नहीं पड़ता कि किस विधि का उपयोग किया गया था“get” या “post”, लारवेल विधि दोनों तरीकों के लिए इनपुट मानों को उसी तरह से पुनः प्राप्त करेगी। इनपुट मानों को पुनः प्राप्त करने के दो तरीके हैं।
- इनपुट () विधि का उपयोग करना
- अनुरोध उदाहरण के गुणों का उपयोग करना
इनपुट () विधि का उपयोग करना
input()विधि एक तर्क, रूप में क्षेत्र का नाम लेती है। उदाहरण के लिए, यदि फ़ॉर्म में उपयोगकर्ता नाम फ़ील्ड है तो हम इसे निम्न तरीके से एक्सेस कर सकते हैं।
$name = $request->input('username');
अनुरोध उदाहरण के गुणों का उपयोग करना
की तरह input() विधि, हम उपयोगकर्ता नाम सीधे अनुरोध उदाहरण से प्राप्त कर सकते हैं।
$request->username
उदाहरण
अनुरोधों के बारे में अधिक समझने के लिए निम्न उदाहरण देखें -
Step 1 - एक पंजीकरण फॉर्म बनाएं, जहां उपयोगकर्ता खुद को पंजीकृत कर सकता है और फॉर्म को स्टोर कर सकता है resources/views/register.php
<html>
<head>
<title>Form Example</title>
</head>
<body>
<form action = "/user/register" method = "post">
<input type = "hidden" name = "_token" value = "<?php echo csrf_token() ?>">
<table>
<tr>
<td>Name</td>
<td><input type = "text" name = "name" /></td>
</tr>
<tr>
<td>Username</td>
<td><input type = "text" name = "username" /></td>
</tr>
<tr>
<td>Password</td>
<td><input type = "text" name = "password" /></td>
</tr>
<tr>
<td colspan = "2" align = "center">
<input type = "submit" value = "Register" />
</td>
</tr>
</table>
</form>
</body>
</html>
Step 2 - बनाने के लिए नीचे दिए गए आदेश का निष्पादन करें UserRegistration नियंत्रक।
php artisan make:controller UserRegistration --plain
Step 3 - उपरोक्त चरण के सफल निष्पादन के बाद, आपको निम्न आउटपुट प्राप्त होंगे -
Step 4 - निम्नलिखित कोड को कॉपी करें
app/Http/Controllers/UserRegistration.php नियंत्रक।
app/Http/Controllers/UserRegistration.php
<?php
namespace App\Http\Controllers;
use Illuminate\Http\Request;
use App\Http\Requests;
use App\Http\Controllers\Controller;
class UserRegistration extends Controller {
public function postRegister(Request $request) {
//Retrieve the name input field
$name = $request->input('name');
echo 'Name: '.$name; echo '<br>'; //Retrieve the username input field $username = $request->username; echo 'Username: '.$username;
echo '<br>';
//Retrieve the password input field
$password = $request->password;
echo 'Password: '.$password;
}
}
Step 5 - निम्नलिखित पंक्ति को इसमें जोड़ें app/Http/routes.php फ़ाइल।
app/Http/routes.php
Route::get('/register',function() {
return view('register');
});
Route::post('/user/register',array('uses'=>'UserRegistration@postRegister'));
Step 6- निम्नलिखित URL पर जाएं और नीचे दिए गए चित्र में दिखाए अनुसार पंजीकरण फॉर्म देखेंगे। पंजीकरण विवरण टाइप करें और रजिस्टर पर क्लिक करें और आप दूसरे पृष्ठ पर देखेंगे जिसे हमने उपयोगकर्ता पंजीकरण विवरण पुनर्प्राप्त और प्रदर्शित किया है।
http://localhost:8000/register
Step 7 - आउटपुट कुछ ऐसा दिखाई देगा जैसा कि नीचे दी गई छवियों में दिखाया गया है।
किसी वेब एप्लिकेशन पर उपयोगकर्ता के सत्र का संचालन करते समय कुकीज़ एक महत्वपूर्ण भूमिका निभाती हैं। इस अध्याय में, आप लारवेल आधारित वेब अनुप्रयोगों में कुकीज़ के साथ काम करने के बारे में जानेंगे।
कुकी बनाना
कुकी को लारवेल के वैश्विक कुकी हेल्पर द्वारा बनाया जा सकता है। इसका एक उदाहरण हैSymfony\Component\HttpFoundation\Cookie। कुकी withCookie () पद्धति का उपयोग करके प्रतिक्रिया से जुड़ी जा सकती है। का एक प्रतिक्रिया उदाहरण बनाएँIlluminate\Http\Responseक्लास को कॉची () विधि से कॉल करें। Laravel द्वारा उत्पन्न कुकी एन्क्रिप्टेड और हस्ताक्षरित हैं और इसे क्लाइंट द्वारा संशोधित या पढ़ा नहीं जा सकता है।
यहाँ स्पष्टीकरण के साथ एक नमूना कोड है।
//Create a response instance
$response = new Illuminate\Http\Response('Hello World');
//Call the withCookie() method with the response method
$response->withCookie(cookie('name', 'value', $minutes));
//return the response
return $response;
कुकी () विधि में 3 तर्क होंगे। पहला तर्क कुकी का नाम है, दूसरा तर्क कुकी का मूल्य है और तीसरा तर्क कुकी की अवधि है जिसके बाद कुकी स्वचालित रूप से हटा दी जाएगी।
नीचे दिए गए कोड में दिखाए अनुसार हमेशा के लिए विधि का उपयोग करके कुकी को हमेशा के लिए सेट किया जा सकता है।
$response->withCookie(cookie()->forever('name', 'value'));
एक कुकी को पुनः प्राप्त करना
एक बार जब हम कुकी सेट कर लेते हैं, तो हम कुकी () विधि द्वारा कुकी को पुनः प्राप्त कर सकते हैं। यह कुकी () विधि केवल एक तर्क लेगी जो कुकी का नाम होगा। के उदाहरण का उपयोग करके कुकी विधि को बुलाया जा सकता हैIlluminate\Http\Request।
यहाँ एक नमूना कोड है।
//’name’ is the name of the cookie to retrieve the value of
$value = $request->cookie('name');
उदाहरण
कुकीज़ के बारे में अधिक समझने के लिए निम्नलिखित उदाहरण देखें -
Step 1 - नियंत्रक बनाने के लिए नीचे दिए गए आदेश को निष्पादित करें जिसमें हम कुकी में हेरफेर करेंगे।
php artisan make:controller CookieController --plain
Step 2 - सफल निष्पादन के बाद, आपको निम्न आउटपुट प्राप्त होंगे -
Step 3 - निम्नलिखित कोड को कॉपी करें
app/Http/Controllers/CookieController.php फ़ाइल।
app/Http/Controllers/CookieController.php
<?php
namespace App\Http\Controllers;
use Illuminate\Http\Request;
use Illuminate\Http\Response;
use App\Http\Requests;
use App\Http\Controllers\Controller;
class CookieController extends Controller {
public function setCookie(Request $request) { $minutes = 1;
$response = new Response('Hello World'); $response->withCookie(cookie('name', 'virat', $minutes)); return $response;
}
public function getCookie(Request $request) { $value = $request->cookie('name'); echo $value;
}
}
Step 4 - निम्नलिखित पंक्ति को इसमें जोड़ें app/Http/routes.php file।
app/Http/routes.php
Route::get('/cookie/set','CookieController@setCookie');
Route::get('/cookie/get','CookieController@getCookie');
Step 5 - कुकी सेट करने के लिए निम्न URL पर जाएं।
http://localhost:8000/cookie/set
Step 6- आउटपुट नीचे दिखाए गए अनुसार दिखाई देगा। स्क्रीनशॉट में दिखाई देने वाली विंडो फ़ायरफ़ॉक्स से ली गई है, लेकिन आपके ब्राउज़र के आधार पर, कुकी विकल्प से कुकी को भी चेक किया जा सकता है।
Step 7 - उपरोक्त URL से कुकी प्राप्त करने के लिए निम्न URL पर जाएं।
http://localhost:8000/cookie/get
Step 8 - आउटपुट निम्न छवि में दिखाए गए अनुसार दिखाई देगा।
एक वेब एप्लिकेशन कई तरीकों के आधार पर उपयोगकर्ता के अनुरोध पर कई तरह से प्रतिक्रिया करता है। यह अध्याय आपको लारवेल वेब अनुप्रयोगों में प्रतिक्रियाओं के बारे में विस्तार से बताता है।
मूल प्रतिक्रिया
लारवेल प्रतिक्रिया वापस करने के लिए कई अलग-अलग तरीके प्रदान करता है। प्रतिक्रिया या तो मार्ग से या नियंत्रक से भेजी जा सकती है। मूल प्रतिक्रिया जो भेजी जा सकती है वह सरल स्ट्रिंग है जैसा कि नीचे दिए गए नमूना कोड में दिखाया गया है। यह स्ट्रिंग स्वचालित रूप से उचित HTTP प्रतिक्रिया में बदल जाएगी।
उदाहरण
Step 1 - निम्न कोड को इसमें जोड़ें app/Http/routes.php फ़ाइल।
app/Http/routes.php
Route::get('/basic_response', function () {
return 'Hello World';
});
Step 2 - Visit मूल प्रतिक्रिया का परीक्षण करने के लिए निम्न URL।
http://localhost:8000/basic_response
Step 3 - आउटपुट निम्न छवि में दिखाए गए अनुसार दिखाई देगा।
संलग्न हेडर
हेडर () विधि का उपयोग करके हेडर से प्रतिक्रिया संलग्न की जा सकती है। हम नीचे दिए गए नमूना कोड में दिखाए गए अनुसार हेडर की श्रृंखला भी संलग्न कर सकते हैं।
return response($content,$status)
->header('Content-Type', $type)
->header('X-Header-One', 'Header Value')
->header('X-Header-Two', 'Header Value');
उदाहरण
प्रतिक्रिया के बारे में अधिक समझने के लिए निम्न उदाहरण देखें -
Step 1 - निम्न कोड को इसमें जोड़ें app/Http/routes.php फ़ाइल।
app/Http/routes.php
Route::get('/header',function() {
return response("Hello", 200)->header('Content-Type', 'text/html');
});
Step 2 - मूल प्रतिक्रिया का परीक्षण करने के लिए निम्न URL पर जाएं।
http://localhost:8000/header
Step 3 - आउटपुट निम्न छवि में दिखाए गए अनुसार दिखाई देगा।
कुकीज़ संलग्न करना
withcookie()कुकीज़ को संलग्न करने के लिए सहायक विधि का उपयोग किया जाता है। इस पद्धति से उत्पन्न कुकी को कॉल करके संलग्न किया जा सकता हैwithcookie()प्रतिक्रिया उदाहरण के साथ विधि। डिफ़ॉल्ट रूप से, लारवेल द्वारा उत्पन्न सभी कुकीज़ एन्क्रिप्टेड और हस्ताक्षरित हैं ताकि उन्हें क्लाइंट द्वारा संशोधित या पढ़ा नहीं जा सके।
उदाहरण
कुकीज़ संलग्न करने के बारे में अधिक समझने के लिए निम्नलिखित उदाहरण देखें -
Step 1 - निम्न कोड को इसमें जोड़ें app/Http/routes.php फ़ाइल।
app/Http/routes.php
Route::get('/cookie',function() {
return response("Hello", 200)->header('Content-Type', 'text/html')
->withcookie('name','Virat Gandhi');
});
Step 2 - Visit मूल प्रतिक्रिया का परीक्षण करने के लिए निम्न URL।
http://localhost:8000/cookie
Step 3 - आउटपुट निम्न छवि में दिखाए गए अनुसार दिखाई देगा।
JSON प्रतिक्रिया
JSON प्रतिक्रिया को json पद्धति का उपयोग करके भेजा जा सकता है। यह विधि सामग्री-प्रकार हेडर को स्वतः ही सेट कर देगीapplication/json। json विधि स्वचालित रूप से सरणी को उपयुक्त में बदल देगी json प्रतिक्रिया।
उदाहरण
JSON रिस्पांस के बारे में अधिक समझने के लिए निम्न उदाहरण देखें -
Step 1 - निम्नलिखित पंक्ति को इसमें जोड़ें app/Http/routes.php फ़ाइल।
app/Http/routes.php
Route::get('json',function() {
return response()->json(['name' => 'Virat Gandhi', 'state' => 'Gujarat']);
});
Step 2 - json प्रतिक्रिया का परीक्षण करने के लिए निम्न URL पर जाएं।
http://localhost:8000/json
Step 3 - आउटपुट निम्न छवि में दिखाए गए अनुसार दिखाई देगा।
एमवीसी ढांचे में, पत्र “V” के लिए खड़ा है Views। यह एप्लिकेशन लॉजिक और प्रेजेंटेशन लॉजिक को अलग करता है। दृश्य संग्रहीत हैंresources/viewsनिर्देशिका। आम तौर पर, दृश्य में HTML होता है जिसे एप्लिकेशन द्वारा परोसा जाएगा।
उदाहरण
दृश्य के बारे में अधिक समझने के लिए निम्न उदाहरण देखें -
Step 1 - निम्नलिखित कोड की प्रतिलिपि बनाएँ और इसे सहेजें resources/views/test.php
<html>
<body>
<h1>Hello, World</h1>
</body>
</html>
Step 2 - निम्नलिखित पंक्ति को इसमें जोड़ें app/Http/routes.php उपरोक्त दृश्य के लिए मार्ग सेट करने के लिए फ़ाइल।
app/Http/routes.php
Route::get('/test', function() {
return view('test');
});
Step 3 - दृश्य का आउटपुट देखने के लिए निम्न URL पर जाएं।
http://localhost:8000/test
Step 4 - आउटपुट निम्न छवि में दिखाए गए अनुसार दिखाई देगा।
पासिंग डेटा टू व्यू
एप्लिकेशन का निर्माण करते समय, विचारों को डेटा पास करना आवश्यक हो सकता है। सहायक फ़ंक्शन देखने के लिए एक सरणी पास करें। एक सरणी से गुजरने के बाद, हम उस कुंजी का मान HTML फ़ाइल में प्राप्त करने के लिए उपयोग कर सकते हैं।
उदाहरण
विचारों को पास करने के बारे में अधिक समझने के लिए निम्नलिखित उदाहरण देखें -
Step 1 - निम्नलिखित कोड की प्रतिलिपि बनाएँ और इसे सहेजें resources/views/test.php
<html>
<body>
<h1><?php echo $name; ?></h1>
</body>
</html>
Step 2 - निम्नलिखित पंक्ति को इसमें जोड़ें app/Http/routes.php उपरोक्त दृश्य के लिए मार्ग सेट करने के लिए फ़ाइल।
app/Http/routes.php
Route::get('/test', function() {
return view('test',[‘name’=>’Virat Gandhi’]);
});
Step 3 - कुंजी नाम के मान को test.php फ़ाइल में पास कर दिया जाएगा और $ नाम को उस मान से बदल दिया जाएगा।
Step 4 - दृश्य का आउटपुट देखने के लिए निम्न URL पर जाएं।
http://localhost:8000/test
Step 5 - आउटपुट निम्न छवि में दिखाए गए अनुसार दिखाई देगा।
सभी दृश्यों के साथ डेटा साझा करना
हमने देखा है कि कैसे हम विचारों को डेटा पास कर सकते हैं लेकिन कई बार, सभी विचारों को डेटा पास करने की आवश्यकता होती है। लारवेल इसे सरल बनाता है। नामक एक विधि हैshare()जिसका उपयोग इस उद्देश्य के लिए किया जा सकता है। share()विधि दो तर्क, कुंजी और मूल्य लेगी। आम तौर परshare()सेवा प्रदाता की बूट विधि से विधि को बुलाया जा सकता है। हम किसी भी सेवा प्रदाता का उपयोग कर सकते हैं,AppServiceProvider या हमारे अपने सेवा प्रदाता।
उदाहरण
सभी विचारों के साथ डेटा साझा करने के बारे में अधिक समझने के लिए निम्न उदाहरण देखें -
Step 1 - निम्नलिखित पंक्ति को इसमें जोड़ें app/Http/routes.php फ़ाइल।
app/Http/routes.php
Route::get('/test', function() {
return view('test');
});
Route::get('/test2', function() {
return view('test2');
});
Step 2 - दो दृश्य फ़ाइलें बनाएँ - test.php तथा test2.phpएक ही कोड के साथ। ये दो फाइलें हैं जो डेटा साझा करेंगी। दोनों फाइलों में निम्न कोड को कॉपी करें।resources/views/test.php & resources/views/test2.php
<html>
<body>
<h1><?php echo $name; ?></h1>
</body>
</html>
Step 3 - फाइल में बूट विधि का कोड बदलें app/Providers/AppServiceProvider.phpजैसा की नीचे दिखाया गया। (यहां, हमने साझा पद्धति का उपयोग किया है और जो डेटा हमने पास किया है, उसे सभी विचारों के साथ साझा किया जाएगा।)app/Providers/AppServiceProvider.php
<?php
namespace App\Providers;
use Illuminate\Support\ServiceProvider;
class AppServiceProvider extends ServiceProvider {
/**
* Bootstrap any application services.
*
* @return void
*/
public function boot() {
view()->share('name', 'Virat Gandhi');
}
/**
* Register any application services.
*
* @return void
*/
public function register() {
//
}
}
Step 4 - Visit निम्नलिखित URL
http://localhost:8000/test
http://localhost:8000/test2
Step 5 - आउटपुट निम्न छवि में दिखाए गए अनुसार दिखाई देगा।
लारवेल 5.1 का उपयोग करने की अवधारणा का परिचय देता है Blade, एक अद्वितीय लेआउट डिजाइन करने के लिए एक अस्थायी इंजन। इस प्रकार डिज़ाइन किया गया लेआउट अन्य विचारों द्वारा उपयोग किया जा सकता है, और इसमें एक सुसंगत डिज़ाइन और संरचना शामिल है।
जब अन्य टेंपलेटिंग इंजनों की तुलना में, ब्लेड निम्नलिखित तरीकों से अद्वितीय है -
यह डेवलपर को विचारों में सादे PHP कोड का उपयोग करने से प्रतिबंधित नहीं करता है।
इस प्रकार डिज़ाइन किए गए ब्लेड दृश्य, संकलित और संकलित किए जाते हैं जब तक कि वे संशोधित न हों।
Laravel की पूरी निर्देशिका संरचना यहाँ दिए गए स्क्रीनशॉट में दिखाई गई है।
आप देख सकते हैं कि सभी दृश्य इसमें संग्रहीत हैं resources/views निर्देशिका और लारवेल ढांचे के लिए डिफ़ॉल्ट दृश्य है welcome.blade.php।
कृपया ध्यान दें कि अन्य ब्लेड टेम्पलेट भी इसी तरह बनाए जाते हैं।
ब्लेड टेम्पलेट लेआउट बनाने के लिए चरण
ब्लेड टेम्पलेट लेआउट बनाने के लिए आपको निम्नलिखित चरणों का उपयोग करना होगा -
चरण 1
अंदर एक लेआउट फ़ोल्डर बनाएँ resources/viewsफ़ोल्डर। हम सभी लेआउट को एक साथ संग्रहीत करने के लिए इस फ़ोल्डर का उपयोग करने जा रहे हैं।
एक फ़ाइल नाम बनाएँ master.blade.php जिसके साथ निम्न कोड जुड़ा होगा -
<html>
<head>
<title>DemoLaravel - @yield('title')</title>
</head>
<body>
@yield('content')
</body>
</html>
चरण 2
इस चरण में, आपको लेआउट का विस्तार करना चाहिए। लेआउट को विस्तारित करने में बाल तत्वों को परिभाषित करना शामिल है। लारवेल का उपयोग करता हैBlade @extends बाल तत्वों को परिभाषित करने का निर्देश।
जब आप एक लेआउट का विस्तार कर रहे हैं, तो कृपया निम्नलिखित बिंदुओं पर ध्यान दें -
ब्लेड लेआउट में परिभाषित दृश्य एक अनोखे तरीके से कंटेनर को इंजेक्ट करता है।
देखने के विभिन्न वर्गों को बाल तत्वों के रूप में बनाया जाता है।
बाल तत्वों को लेआउट फ़ोल्डर में संग्रहीत किया जाता है child.blade.php
एक उदाहरण जो ऊपर बनाए गए लेआउट का विस्तार दिखाता है, उसे यहां दिखाया गया है -
@extends('layouts.app')
@section('title', 'Page Title')
@section('sidebar')
@parent
<p>This refers to the master sidebar.</p>
@endsection
@section('content')
<p>This is my body content.</p>
@endsection
चरण 3
विचारों में बाल तत्वों को लागू करने के लिए, आपको लेआउट को उस तरीके से परिभाषित करना चाहिए जिस तरह से इसकी आवश्यकता है।
यहां दिखाए गए स्क्रीनशॉट को ध्यान से देखें। आप पा सकते हैं कि लैंडिंग पृष्ठ में उल्लिखित प्रत्येक लिंक हाइपरलिंक है। कृपया ध्यान दें कि आप ऊपर दिए गए प्रक्रिया का उपयोग करके उन्हें ब्लेड टेम्पलेट की मदद से बाल तत्व के रूप में भी बना सकते हैं।
नामित मार्ग का उपयोग किसी मार्ग को विशिष्ट नाम देने के लिए किया जाता है। नाम का उपयोग करके सौंपा जा सकता है“as” सरणी कुंजी।
Route::get('user/profile', ['as' => 'profile', function () {
//
}]);
Note - यहां, हमने नाम दिया है profile एक मार्ग के लिए user/profile।
जिसका नाम बदलकर रूट रखा गया है
उदाहरण
नामित मार्गों के पुनर्निर्देशन के बारे में अधिक समझने के लिए निम्नलिखित उदाहरण देखें -
Step 1 - test.php नामक एक दृश्य बनाएं और इसे सहेजें
resources/views/test.php।
<html>
<body>
<h1>Example of Redirecting to Named Routes</h1>
</body>
</html>
Step 2 - में routes.php, हमने इसके लिए मार्ग निर्धारित किया है test.phpफ़ाइल। हमने इसका नाम बदल दिया हैtesting। हमने एक और मार्ग भी तय किया हैredirect जो नामित मार्ग के अनुरोध को पुनर्निर्देशित करेगा testing।
app/Http/routes.php
Route::get('/test', ['as'=>'testing',function() {
return view('test2');
}]);
Route::get('redirect',function() {
return redirect()->route('testing');
});
Step 3 - नामित मार्ग उदाहरण का परीक्षण करने के लिए निम्न URL पर जाएं।
http://localhost:8000/redirect
Step 4 - उपरोक्त URL के निष्पादन के बाद, आपको http: // localhost: 8000 / test पर पुनर्निर्देशित किया जाएगा क्योंकि हम नामित मार्ग पर पुनः निर्देशित कर रहे हैं testing।
Step 5 - URL के सफल निष्पादन के बाद, आपको निम्न आउटपुट प्राप्त होंगे -
नियंत्रक क्रियाओं को पुनर्निर्देशित करना
न केवल नामित मार्ग बल्कि हम नियंत्रक क्रियाओं को भी अनुप्रेषित कर सकते हैं। हमें बस नियंत्रक और के नाम को पारित करने की आवश्यकता हैactionनिम्न उदाहरण में दिखाया गया है। यदि आप एक पैरामीटर पास करना चाहते हैं, तो आप इसे एक्शन विधि के दूसरे तर्क के रूप में पास कर सकते हैं।
return redirect()->action(‘NameOfController@methodName’,[parameters]);
उदाहरण
Step 1 - नियंत्रक नामक एक नियंत्रक बनाने के लिए निम्न आदेश निष्पादित करें RedirectController।
php artisan make:controller RedirectController --plain
Step 2 - सफल निष्पादन के बाद, आपको निम्न आउटपुट प्राप्त होंगे -
Step 3 - फाइल करने के लिए निम्न कोड को कॉपी करें
app/Http/Controllers/RedirectController.php।
app/Http/Controllers/RedirectController.php
<?php
namespace App\Http\Controllers;
use Illuminate\Http\Request;
use App\Http\Requests;
use App\Http\Controllers\Controller;
class RedirectController extends Controller {
public function index() {
echo "Redirecting to controller's action.";
}
}
Step 4 - निम्नलिखित पंक्तियों को जोड़ें app/Http/routes.php।
app/Http/routes.php
Route::get('rr','RedirectController@index');
Route::get('/redirectcontroller',function() {
return redirect()->action('RedirectController@index');
});
Step 5 - उदाहरण का परीक्षण करने के लिए निम्न URL पर जाएं।
http://localhost:8000/redirectcontroller
Step 6 - आउटपुट निम्न छवि में दिखाए गए अनुसार दिखाई देगा।
लारवेल ने डेटाबेस के साथ प्रसंस्करण को बहुत आसान बना दिया है। लारवेल वर्तमान में 4 डेटाबेसों का समर्थन करता है -
- MySQL
- Postgres
- SQLite
- एस क्यू एल सर्वर
डेटाबेस में क्वेरी को कच्चे एसक्यूएल, धाराप्रवाह क्वेरी बिल्डर और एलोक्वेंट ओआरएम का उपयोग करके निकाल दिया जा सकता है। लारवेल के साथ सभी CRUD (क्रिएट, रीड, अपडेट, डिलीट) ऑपरेशंस को समझने के लिए, हम सिंपल स्टूडेंट मैनेजमेंट सिस्टम का इस्तेमाल करेंगे।
डेटाबेस से जुड़ना
में डेटाबेस कॉन्फ़िगर करें config/database.php निम्न तालिका में दिखाए गए अनुसार MySQL में संरचना के साथ कॉलेज डेटाबेस बनाएँ और बनाएँ।
Database: College
Table: student
आम नाम | कॉलम डेटाटाइप | अतिरिक्त |
---|---|---|
ईद | पूर्णांक (11) | प्राथमिक कुंजी | स्वयं वेतन वृद्धि |
नाम | varchar (25) |
हम छात्र तालिका में लारवेल का उपयोग करके डेटाबेस से रिकॉर्ड जोड़ने, हटाने, अद्यतन करने और पुनर्प्राप्त करने का तरीका देखेंगे।
अनु क्रमांक। | रिकॉर्ड और विवरण |
---|---|
1 | रिकॉर्ड डालें हम डीबी मुखौटा का उपयोग कर डालने की विधि के साथ रिकॉर्ड सम्मिलित कर सकते हैं। |
2 | कीर्तिमान प्राप्त किया डेटाबेस को कॉन्फ़िगर करने के बाद, हम चुनिंदा विधि के साथ DB मुखौटा का उपयोग करके रिकॉर्ड को पुनः प्राप्त कर सकते हैं। |
3 | रिकॉर्ड अपडेट करें हम अद्यतन विधि के साथ DB मुखौटा का उपयोग करके रिकॉर्ड को अपडेट कर सकते हैं। |
4 | रिकॉर्ड हटाएं हम डीबी मुखौटा का उपयोग करके रिकॉर्ड विधि को हटा सकते हैं। |
यह अध्याय लारवेल परियोजनाओं में त्रुटियों और लॉगिंग और उन पर काम करने के तरीके से संबंधित है।
त्रुटियाँ
एक परियोजना चल रही है, कुछ त्रुटियों के लिए वहन किया जाता है। जब आप एक नया लारवेल प्रोजेक्ट शुरू करते हैं तो आपके लिए त्रुटियां और अपवाद हैंडलिंग पहले से कॉन्फ़िगर की गई हैं। आम तौर पर, स्थानीय वातावरण में हमें डीबगिंग उद्देश्यों के लिए त्रुटियों को देखने की आवश्यकता होती है। हमें उत्पादन वातावरण में उपयोगकर्ताओं से इन त्रुटियों को छिपाने की आवश्यकता है। यह चर के साथ प्राप्त किया जा सकता हैAPP_DEBUG पर्यावरण फ़ाइल में सेट करें .env आवेदन की जड़ में संग्रहीत।
स्थानीय पर्यावरण के लिए मूल्य APP_DEBUG होना चाहिए true लेकिन उत्पादन के लिए इसे स्थापित करने की आवश्यकता है false त्रुटियों को छिपाने के लिए।
Note - बदलने के बाद APP_DEBUG चर, आपको लारवेल सर्वर को पुनरारंभ करना चाहिए।
लॉगिंग
लॉगिंग एक महत्वपूर्ण तंत्र है जिसके द्वारा सिस्टम त्रुटियों को उत्पन्न कर सकता है। यह प्रणाली की विश्वसनीयता में सुधार करने के लिए उपयोगी है। Laravel एकल, दैनिक, syslog, और Errorlog मोड जैसे विभिन्न लॉगिंग मोड का समर्थन करता है। आप इन मोड को सेट कर सकते हैंconfig/app.php फ़ाइल।
'log' => 'daily'
आप जनरेटेड लॉग एंट्रीज को देख सकते हैं storage/logs/laravel.log फ़ाइल।
Laravel HTML रूपों को आसानी से और सुरक्षित रूप से संभालने के लिए विभिन्न निर्मित टैग प्रदान करता है। HTML के सभी प्रमुख तत्व Laravel का उपयोग करके उत्पन्न होते हैं। इसका समर्थन करने के लिए, हमें संगीतकार का उपयोग करके लारवेल में HTML पैकेज जोड़ना होगा।
उदाहरण 1
Step 1 - उसी के साथ आगे बढ़ने के लिए निम्न आदेश निष्पादित करें।
composer require illuminate/html
Step 2 - यह Laravel में HTML पैकेज जोड़ देगा जैसा कि निम्नलिखित छवि में दिखाया गया है।
Step 3 - अब, हमें Laravel कॉन्फ़िगरेशन फ़ाइल के ऊपर दिखाए गए पैकेज को जोड़ने की आवश्यकता है जो कि संग्रहीत है config/app.php.इस फ़ाइल को खोलें और आपको Laravel सेवा प्रदाताओं की एक सूची दिखाई देगी जैसा कि निम्नलिखित छवि में दिखाया गया है। निम्न छवि में उल्लिखित बॉक्स में बताए अनुसार HTML सेवा प्रदाता जोड़ें।
Step 4- HTML और फॉर्म के लिए एक ही फाइल में उपनाम जोड़ें। निम्नलिखित छवि में उल्लिखित बॉक्स में इंगित की गई दो पंक्तियों को नोट करें और उन दो पंक्तियों को जोड़ दें।
Step 5- अब सब कुछ सेटअप है। आइए देखें कि कैसे हम Laravel टैग का उपयोग करके विभिन्न HTML तत्वों का उपयोग कर सकते हैं।
एक फॉर्म खोलना
{{ Form::open(array('url' => 'foo/bar')) }}
//
{{ Form::close() }}
एक लेबल तत्व उत्पन्न करना
echo Form::label('email', 'E-Mail Address');
एक पाठ इनपुट उत्पन्न करना
echo Form::text('username');
एक डिफ़ॉल्ट मान निर्दिष्ट करना
echo Form::text('email', '[email protected]');
पासवर्ड इनपुट जनरेट करना
echo Form::password('password');
फ़ाइल इनपुट बनाना
echo Form::file('image');
एक चेकबॉक्स या रेडियो इनपुट उत्पन्न करना
echo Form::checkbox('name', 'value');
echo Form::radio('name', 'value');
एक चेकबॉक्स या रेडियो इनपुट उत्पन्न करना जो जांचा गया हो
echo Form::checkbox('name', 'value', true);
echo Form::radio('name', 'value', true);
ड्रॉप-डाउन सूची बनाना
echo Form::select('size', array('L' => 'Large', 'S' => 'Small'));
एक सबमिट बटन जनरेट करना
echo Form::submit('Click Me!');
उदाहरण 2
Step 1 - नामक दृश्य बनाने के लिए निम्न कोड की प्रतिलिपि बनाएँ
resources/views/form.php।
resources/views/form.php
<html>
<body>
<?php
echo Form::open(array('url' => 'foo/bar'));
echo Form::text('username','Username');
echo '<br/>';
echo Form::text('email', '[email protected]');
echo '<br/>';
echo Form::password('password');
echo '<br/>';
echo Form::checkbox('name', 'value');
echo '<br/>';
echo Form::radio('name', 'value');
echo '<br/>';
echo Form::file('image');
echo '<br/>';
echo Form::select('size', array('L' => 'Large', 'S' => 'Small'));
echo '<br/>';
echo Form::submit('Click Me!');
echo Form::close();
?>
</body>
</html>
Step 2 - निम्नलिखित पंक्ति को इसमें जोड़ें app/Http/routes.php देखने के लिए एक मार्ग जोड़ने के लिए
app/Http/routes.php
Route::get('/form',function() {
return view('form');
});
Step 3 - फॉर्म देखने के लिए निम्न URL पर जाएं।
http://localhost:8000/form
Step 4 - आउटपुट निम्न छवि में दिखाए गए अनुसार दिखाई देगा।
लारवेल की स्थानीयकरण विशेषता आवेदन में उपयोग की जाने वाली विभिन्न भाषा का समर्थन करती है। आपको एक फ़ाइल में विभिन्न भाषा के सभी तारों को संग्रहीत करने की आवश्यकता है और ये फाइलें संग्रहीत हैंresources/viewsनिर्देशिका। आपको प्रत्येक समर्थित भाषा के लिए एक अलग निर्देशिका बनानी चाहिए। सभी भाषा फ़ाइलों को नीचे दिखाए अनुसार कीरिंग स्ट्रिंग्स की एक सरणी को वापस करना चाहिए।
<?php
return [
'welcome' => 'Welcome to the application'
];
उदाहरण
Step 1 - भाषाओं के लिए 3 फाइलें बनाएं - English, French, तथा German। पर अंग्रेजी फ़ाइल सहेजेंresources/lang/en/lang.php
<?php
return [
'msg' => 'Laravel Internationalization example.'
];
?>
Step 2 - पर फ्रेंच फ़ाइल सहेजें resources/lang/fr/lang.php।
<?php
return [
'msg' => 'Exemple Laravel internationalisation.'
];
?>
Step 3 - पर जर्मन फ़ाइल सहेजें resources/lang/de/lang.php।
<?php
return [
'msg' => 'Laravel Internationalisierung Beispiel.'
];
?>
Step 4 - एक नियंत्रक बनाएँ LocalizationController निम्नलिखित कमांड निष्पादित करके।
php artisan make:controller LocalizationController --plain
Step 5 - सफल निष्पादन के बाद, आपको निम्न आउटपुट प्राप्त होंगे -
Step 6 - फाइल करने के लिए निम्न कोड को कॉपी करें
app/Http/Controllers/LocalizationController.php
app/Http/Controllers/LocalizationController.php
<?php
namespace App\Http\Controllers;
use Illuminate\Http\Request;
use App\Http\Requests;
use App\Http\Controllers\Controller;
class LocalizationController extends Controller {
public function index(Request $request,$locale) {
//set’s application’s locale
app()->setLocale($locale);
//Gets the translated message and displays it
echo trans('lang.msg');
}
}
Step 7 - में LocalizationController के लिए एक मार्ग जोड़ें app/Http/routes.phpफ़ाइल। ध्यान दें कि हम स्थानीयकरण के बाद {लोकेल} तर्क पास कर रहे हैं / जिसे हम विभिन्न भाषा में आउटपुट देखने के लिए उपयोग करेंगे।
app/Http/routes.php
Route::get('localization/{locale}','LocalizationController@index');
Step 8- अब, हम सभी अलग-अलग भाषाओं को देखने के लिए अलग-अलग URL पर जाएँ। अंग्रेजी भाषा में आउटपुट देखने के लिए नीचे दिए गए URL को निष्पादित करें।
http://localhost:8000/localization/en
Step 9 - आउटपुट निम्न छवि में दिखाए गए अनुसार दिखाई देगा।
Step 10 - फ्रेंच भाषा में आउटपुट देखने के लिए नीचे दिए गए URL को निष्पादित करें।
http://localhost:8000/localization/fr
Step 11 - आउटपुट निम्न छवि में दिखाए गए अनुसार दिखाई देगा।
Step 12 - जर्मन भाषा में आउटपुट देखने के लिए नीचे दिए गए URL को निष्पादित करें
http://localhost:8000/localization/de
Step 13 - आउटपुट निम्न छवि में दिखाए गए अनुसार दिखाई देगा।
अनुरोधों में उपयोगकर्ता के बारे में जानकारी संग्रहीत करने के लिए सत्र का उपयोग किया जाता है। लारवेल विभिन्न ड्राइवरों को प्रदान करता हैfile, cookie, apc, array, Memcached, Redis, तथा databaseसत्र डेटा को संभालने के लिए। डिफ़ॉल्ट रूप से, फ़ाइल ड्राइवर का उपयोग किया जाता है क्योंकि यह हल्का होता है। पर संग्रहीत फ़ाइल में सत्र को कॉन्फ़िगर किया जा सकता हैconfig/session.php।
सत्र डेटा तक पहुँचना
सत्र डेटा तक पहुंचने के लिए, हमें सत्र के एक उदाहरण की आवश्यकता है जिसे HTTP अनुरोध के माध्यम से एक्सेस किया जा सकता है। उदाहरण प्राप्त करने के बाद, हम उपयोग कर सकते हैंget() विधि, जो एक तर्क लेगी, “key”, सत्र डेटा प्राप्त करने के लिए।
$value = $request->session()->get('key');
आप उपयोग कर सकते हैं all() के बजाय सभी सत्र डेटा प्राप्त करने के लिए विधि get() तरीका।
भंडारण सत्र डेटा
डेटा का उपयोग करके सत्र में संग्रहीत किया जा सकता है put()तरीका। put() विधि दो तर्क लेगा, “key” और यह “value”।
$request->session()->put('key', 'value');
सत्र डेटा हटाना
forget()विधि का उपयोग सत्र से किसी आइटम को हटाने के लिए किया जाता है। यह तरीका लगेगा“key” तर्क के रूप में।
$request->session()->forget('key');
उपयोग flush() के बजाय विधि forget()सभी सत्र डेटा को हटाने के लिए विधि। उपयोगpull()विधि सत्र से डेटा पुनर्प्राप्त करने और बाद में इसे हटाने के लिए। पुल () विधि भी ले जाएगाkeyतर्क के रूप में। के बीच का अंतरforget() और यह pull() विधि वह है forget() विधि सत्र का मान नहीं लौटाएगी pull() विधि इसे वापस करेगी और सत्र से उस मान को हटा देगी।
उदाहरण
Step 1 - एक नियंत्रक बनाएँ SessionController निम्नलिखित कमांड निष्पादित करके।
php artisan make:controller SessionController --plain
Step 2 - सफल निष्पादन के बाद, आपको निम्न आउटपुट प्राप्त होंगे -
Step 3 - फाइल में निम्नलिखित कोड को कॉपी करें
app/Http/Controllers/SessionController.php.
app/Http/Controllers/SessionController.php
<?php
namespace App\Http\Controllers;
use Illuminate\Http\Request;
use App\Http\Requests;
use App\Http\Controllers\Controller;
class SessionController extends Controller {
public function accessSessionData(Request $request) {
if($request->session()->has('my_name')) echo $request->session()->get('my_name');
else
echo 'No data in the session';
}
public function storeSessionData(Request $request) { $request->session()->put('my_name','Virat Gandhi');
echo "Data has been added to session";
}
public function deleteSessionData(Request $request) { $request->session()->forget('my_name');
echo "Data has been removed from session.";
}
}
Step 4 - निम्नलिखित पंक्तियों को इसमें जोड़ें app/Http/routes.php फ़ाइल।
app/Http/routes.php
Route::get('session/get','SessionController@accessSessionData');
Route::get('session/set','SessionController@storeSessionData');
Route::get('session/remove','SessionController@deleteSessionData');
Step 5 - निम्न URL पर जाएं set data in session।
http://localhost:8000/session/set
Step 6 - आउटपुट निम्न छवि में दिखाए गए अनुसार दिखाई देगा।
Step 7 - निम्न URL पर जाएं get data from session।
http://localhost:8000/session/get
Step 8 - आउटपुट निम्न छवि में दिखाए गए अनुसार दिखाई देगा।
Step 9 - निम्न URL पर जाएं remove session data।
http://localhost:8000/session/remove
Step 10 - आपको एक छवि दिखाई देगी जैसा कि निम्नलिखित छवि में दिखाया गया है।
एप्लिकेशन डिजाइन करते समय सत्यापन सबसे महत्वपूर्ण पहलू है। यह आने वाले डेटा को मान्य करता है। डिफ़ॉल्ट रूप से, आधार नियंत्रक वर्ग एक का उपयोग करता हैValidatesRequests लक्षण जो कई शक्तिशाली सत्यापन नियमों के साथ आने वाले HTTP अनुरोधों को मान्य करने के लिए एक सुविधाजनक तरीका प्रदान करता है।
लारवेल में उपलब्ध मान्यता नियम
लारवेल हमेशा सत्र डेटा में त्रुटियों के लिए जाँच करेंगे, और यदि वे उपलब्ध हैं तो स्वचालित रूप से उन्हें दृश्य में बाँध देंगे। तो, यह ध्यान रखना महत्वपूर्ण है कि ए$errors चर हमेशा आपके अनुरोध पर आपके सभी विचारों में उपलब्ध होगा, जिससे आप आसानी से मान सकते हैं $errorsचर को हमेशा परिभाषित किया जाता है और सुरक्षित रूप से उपयोग किया जा सकता है। निम्न तालिका लारवेल में सभी उपलब्ध सत्यापन नियमों को दर्शाती है।
लारवेल में उपलब्ध मान्यता नियम | ||
---|---|---|
स्वीकार किए जाते हैं | सक्रिय URL | (दिनांक) के बाद |
अल्फा | अल्फा डैश | अल्फा न्यूमेरिक |
सरणी | पहले (तिथि) | के बीच |
बूलियन | की पुष्टि की | दिनांक |
डेटा प्रारूप | विभिन्न | अंक |
अंकों के बीच | ईमेल | अस्तित्व (डेटाबेस) |
छवि फ़ाइल) | में | पूर्णांक |
आईपी पता | JSON | मैक्स |
MIME प्रकार (फ़ाइल) | मिनट | अंदर नही |
संख्यात्मक | नियमित अभिव्यक्ति | अपेक्षित |
यदि आवश्यक हो | जब तक आवश्यक न हो | के साथ आवश्यक है |
सभी के साथ आवश्यक | बिना आवश्यक | सभी के बिना आवश्यक |
वही | आकार | तार |
समय क्षेत्र | अनोखा (डेटाबेस) | यूआरएल |
$errors चर का एक उदाहरण होगा Illuminate\Support\MessageBag। नीचे दिए गए कोड को जोड़कर त्रुटि संदेश दृश्य फ़ाइल में प्रदर्शित किया जा सकता है।
@if (count($errors) > 0)
<div class = "alert alert-danger">
<ul>
@foreach ($errors->all() as $error)
<li>{{ $error }}</li>
@endforeach
</ul>
</div>
@endif
उदाहरण
Step 1 - एक नियंत्रक बनाएँ ValidationController निम्नलिखित कमांड निष्पादित करके।
php artisan make:controller ValidationController --plain
Step 2 - सफल निष्पादन के बाद, आपको निम्न आउटपुट प्राप्त होंगे -
Step 3 - निम्नलिखित कोड को कॉपी करें
app/Http/Controllers/ValidationController.php फ़ाइल।
app/Http/Controllers/ValidationController.php
<?php
namespace App\Http\Controllers;
use Illuminate\Http\Request;
use App\Http\Requests;
use App\Http\Controllers\Controller;
class ValidationController extends Controller {
public function showform() {
return view('login');
}
public function validateform(Request $request) {
print_r($request->all()); $this->validate($request,[
'username'=>'required|max:8',
'password'=>'required'
]);
}
}
Step 4 - नामक एक व्यू फाइल बनाएं resources/views/login.blade.php और उस फ़ाइल में निम्न कोड कॉपी करें।
resources/views/login.blade.php
<html>
<head>
<title>Login Form</title>
</head>
<body>
@if (count($errors) > 0)
<div class = "alert alert-danger">
<ul>
@foreach ($errors->all() as $error)
<li>{{ $error }}</li>
@endforeach
</ul>
</div>
@endif
<?php
echo Form::open(array('url'=>'/validation'));
?>
<table border = '1'>
<tr>
<td align = 'center' colspan = '2'>Login</td>
</tr>
<tr>
<td>Username</td>
<td><?php echo Form::text('username'); ?></td>
</tr>
<tr>
<td>Password</td>
<td><?php echo Form::password('password'); ?></td>
</tr>
<tr>
<td align = 'center' colspan = '2'
><?php echo Form::submit('Login'); ? ></td>
</tr>
</table>
<?php
echo Form::close();
?>
</body>
</html>
Step 5 - निम्नलिखित पंक्तियों को जोड़ें app/Http/routes.php।
app/Http/routes.php
Route::get('/validation','ValidationController@showform');
Route::post('/validation','ValidationController@validateform');
Step 6 - सत्यापन का परीक्षण करने के लिए निम्न URL पर जाएं।
http://localhost:8000/validation
Step 7 - क्लिक करें “Login”पाठ क्षेत्र में कुछ भी दर्ज किए बिना बटन। आउटपुट निम्न छवि में दिखाया जाएगा।
Laravel में फ़ाइलें अपलोड करना बहुत आसान है। हमें केवल एक दृश्य फ़ाइल बनानी होगी, जहाँ कोई उपयोगकर्ता अपलोड की जाने वाली फ़ाइल का चयन कर सकता है और एक नियंत्रक जहाँ अपलोड की गई फ़ाइलों पर कार्रवाई की जाएगी।
एक दृश्य फ़ाइल में, हमें कोड की निम्नलिखित पंक्ति जोड़कर एक फ़ाइल इनपुट उत्पन्न करना होगा।
Form::file('file_name');
फॉर्म :: ओपन () में, हमें जोड़ना होगा ‘files’=>’true’जैसा की नीचे दिखाया गया। यह फॉर्म को कई हिस्सों में अपलोड करने की सुविधा देता है।
Form::open(array('url' => '/uploadfile','files'=>'true'));
उदाहरण
Step 1 - नामक एक व्यू फाइल बनाएं resources/views/uploadfile.php और उस फ़ाइल में निम्न कोड कॉपी करें।
resources/views/uploadfile.php
<html>
<body>
<?php
echo Form::open(array('url' => '/uploadfile','files'=>'true'));
echo 'Select the file to upload.';
echo Form::file('image');
echo Form::submit('Upload File');
echo Form::close();
?>
</body>
</html>
Step 2 - एक नियंत्रक बनाएँ UploadFileController निम्नलिखित कमांड निष्पादित करके।
php artisan make:controller UploadFileController --plain
Step 3 - सफल निष्पादन के बाद, आपको निम्न आउटपुट प्राप्त होंगे -
Step 4 - निम्नलिखित कोड को कॉपी करें
app/Http/Controllers/UploadFileController.php फ़ाइल।
app/Http/Controllers/UploadFileController.php
<?php
namespace App\Http\Controllers;
use Illuminate\Http\Request;
use App\Http\Requests;
use App\Http\Controllers\Controller;
class UploadFileController extends Controller {
public function index() {
return view('uploadfile');
}
public function showUploadFile(Request $request) {
$file = $request->file('image');
//Display File Name
echo 'File Name: '.$file->getClientOriginalName(); echo '<br>'; //Display File Extension echo 'File Extension: '.$file->getClientOriginalExtension();
echo '<br>';
//Display File Real Path
echo 'File Real Path: '.$file->getRealPath(); echo '<br>'; //Display File Size echo 'File Size: '.$file->getSize();
echo '<br>';
//Display File Mime Type
echo 'File Mime Type: '.$file->getMimeType(); //Move Uploaded File $destinationPath = 'uploads';
$file->move($destinationPath,$file->getClientOriginalName());
}
}
Step 5 - निम्नलिखित पंक्तियों को जोड़ें app/Http/routes.php।
app/Http/routes.php
Route::get('/uploadfile','UploadFileController@index');
Route::post('/uploadfile','UploadFileController@showUploadFile');
Step 6 - अपलोड फ़ाइल की कार्यक्षमता का परीक्षण करने के लिए निम्न URL पर जाएं।
http://localhost:8000/uploadfile
Step 7 - आपको निम्न चित्र में दिखाए अनुसार एक संकेत मिलेगा।
लारवेल मुफ्त सुविधा युक्त पुस्तकालय का उपयोग करता है SwiftMailerईमेल भेजने के लिए। लाइब्रेरी फंक्शन का उपयोग करके, हम बहुत अधिक परेशानियों के बिना आसानी से ईमेल भेज सकते हैं। ई-मेल टेम्पलेट्स को उसी तरह से लोड किया जाता है जैसे कि दृश्य, जिसका अर्थ है कि आप ब्लेड सिंटैक्स का उपयोग कर सकते हैं और डेटा को अपने टेम्पलेट में इंजेक्ट कर सकते हैं।
निम्न तालिका सिंटैक्स और विशेषताओं को दिखाती है send कार्य -
वाक्य - विन्यास | शून्य भेजें (स्ट्रिंग | सरणी $ दृश्य, सरणी $data, Closure|string $वापस कॉल करें) |
मापदंडों |
|
रिटर्न | कुछ भी तो नहीं |
विवरण | ईमेल भेजता है। |
तीसरे तर्क में, $ कॉलबैक क्लोजर संदेश संदेश प्राप्त किया और उस उदाहरण के साथ हम निम्नलिखित कार्यों को भी कॉल कर सकते हैं और संदेश को नीचे दिखाए अनुसार बदल सकते हैं।
- $ संदेश → विषय ('ट्यूटोरियल प्वाइंट में आपका स्वागत है');
- $ संदेश → (''मेल @example.com', 'श्री उदाहरण') से;
- $ संदेश → ([email protected] ’, 'मिस्टर उदाहरण’);
कुछ सामान्य तरीकों में शामिल हैं -
- $ संदेश → प्रेषक (ailमेल @example.com ’, 'मिस्टर उदाहरण’);
- $ संदेश → रिटर्नपाथ ([email protected] ’);
- $ संदेश → cc ([email protected] ’, 'Mr. Example’);
- $ संदेश → bcc ([email protected] ’, 'Mr. Example’);
- $ संदेश → रिप्ल्ट्टो (ailमेल_एक्सप्लिंग.कॉम ’, 'मिस्टर उदाहरण’);
- $ संदेश → प्राथमिकता (2);
फ़ाइलों को संलग्न या एम्बेड करने के लिए, आप निम्न विधियों का उपयोग कर सकते हैं -
- $ संदेश → अटैच ('पाथ / टू / अटैचमेंट.टेक्स्ट');
- $ संदेश → एम्बेड ('पाथ / टू / अटैचमेंट.जेपीजी');
मेल HTML या पाठ के रूप में भेजा जा सकता है। आप नीचे दिखाए गए अनुसार एक सरणी पास करके पहले तर्क में भेजे जाने वाले मेल के प्रकार को इंगित कर सकते हैं। डिफ़ॉल्ट प्रकार HTML है। यदि आप सादा पाठ मेल भेजना चाहते हैं तो निम्न सिंटैक्स का उपयोग करें।
वाक्य - विन्यास
Mail::send([‘text’=>’text.view’], $data, $callback);
इस वाक्य रचना में, पहला तर्क एक सरणी लेता है। उपयोगtext कुंजी के मूल्य के रूप में दृश्य का मुख्य नाम।
उदाहरण
Step 1 - अब हम जीमेल अकाउंट से एक ईमेल भेजेंगे और इसके लिए आपको लारवेल एनवायरमेंट फाइल में अपने जीमेल अकाउंट को कॉन्फ़िगर करना होगा - .envफ़ाइल। अपने जीमेल खाते में 2-चरणीय सत्यापन सक्षम करें और नीचे दिखाए गए अनुसार .env मापदंडों को बदलकर एक एप्लिकेशन विशिष्ट पासवर्ड बनाएं।
.env
MAIL_DRIVER = smtp
MAIL_HOST = smtp.gmail.com
MAIL_PORT = 587
MAIL_USERNAME = your-gmail-username
MAIL_PASSWORD = your-application-specific-password
MAIL_ENCRYPTION = tls
Step 2 - बदलने के बाद .env फ़ाइल कैश को खाली करने और लारवेल सर्वर को पुनरारंभ करने के लिए नीचे दिए गए दो आदेशों को निष्पादित करें।
php artisan config:cache
Step 3 - एक नियंत्रक बनाएँ MailController निम्नलिखित कमांड निष्पादित करके।
php artisan make:controller MailController --plain
Step 4 - सफल निष्पादन के बाद, आपको निम्न आउटपुट प्राप्त होंगे -
Step 5 - निम्नलिखित कोड को कॉपी करें
app/Http/Controllers/MailController.php फ़ाइल।
app/Http/Controllers/MailController.php
<?php
namespace App\Http\Controllers;
use Illuminate\Http\Request;
use Mail;
use App\Http\Requests;
use App\Http\Controllers\Controller;
class MailController extends Controller {
public function basic_email() {
$data = array('name'=>"Virat Gandhi");
Mail::send(['text'=>'mail'], $data, function($message) {
$message->to('[email protected]', 'Tutorials Point')->subject ('Laravel Basic Testing Mail'); $message->from('[email protected]','Virat Gandhi');
});
echo "Basic Email Sent. Check your inbox.";
}
public function html_email() {
$data = array('name'=>"Virat Gandhi"); Mail::send('mail', $data, function($message) { $message->to('[email protected]', 'Tutorials Point')->subject
('Laravel HTML Testing Mail');
$message->from('[email protected]','Virat Gandhi'); }); echo "HTML Email Sent. Check your inbox."; } public function attachment_email() { $data = array('name'=>"Virat Gandhi");
Mail::send('mail', $data, function($message) {
$message->to('[email protected]', 'Tutorials Point')->subject ('Laravel Testing Mail with Attachment'); $message->attach('C:\laravel-master\laravel\public\uploads\image.png');
$message->attach('C:\laravel-master\laravel\public\uploads\test.txt'); $message->from('[email protected]','Virat Gandhi');
});
echo "Email Sent with attachment. Check your inbox.";
}
}
Step 6 - निम्नलिखित कोड को कॉपी करें resources/views/mail.blade.php फ़ाइल।
resources/views/mail.blade.php
<h1>Hi, {{ $name }}</h1>
l<p>Sending Mail from Laravel.</p>
Step 7 - निम्नलिखित पंक्तियों को जोड़ें app/Http/routes.php.
app/Http/routes.php
Route::get('sendbasicemail','MailController@basic_email');
Route::get('sendhtmlemail','MailController@html_email');
Route::get('sendattachmentemail','MailController@attachment_email');
Step 8 - मूल ईमेल का परीक्षण करने के लिए निम्न URL पर जाएं।
http://localhost:8000/sendbasicemail
Step 9- आउटपुट स्क्रीन कुछ इस तरह दिखाई देगी। मूल ईमेल आउटपुट देखने के लिए अपना इनबॉक्स देखें।
Step 10 - HTML ईमेल का परीक्षण करने के लिए निम्न URL पर जाएं।
http://localhost:8000/sendhtmlemail
Step 11- आउटपुट स्क्रीन कुछ इस तरह दिखाई देगी। Html ईमेल आउटपुट देखने के लिए अपना इनबॉक्स देखें।
Step 12 - अनुलग्नक के साथ HTML ईमेल का परीक्षण करने के लिए निम्न URL पर जाएं।
http://localhost:8000/sendattachmentemail
Step 13 - आप निम्न आउटपुट देख सकते हैं
Note - में MailController.phpईमेल एड्रेस को मेथड से फाइल करें, वह ईमेल एड्रेस होना चाहिए जिससे आप ईमेल एड्रेस भेज सकते हैं। आम तौर पर, यह आपके सर्वर पर कॉन्फ़िगर किया गया ईमेल पता होना चाहिए।
Ajax (Asynchronous JavaScript and XML)वेब विकास तकनीकों का एक सेट है जो अतुल्यकालिक वेब अनुप्रयोगों को बनाने के लिए क्लाइंट-साइड पर उपयोग की जाने वाली कई वेब तकनीकों का उपयोग करता है। Jquery के ajax फ़ंक्शंस का उपयोग करने के लिए आपकी दृश्य फ़ाइल में jquery लाइब्रेरी आयात करें, जिसका उपयोग सर्वर से ajax का उपयोग करके डेटा भेजने और प्राप्त करने के लिए किया जाएगा। सर्वर की ओर से आप ग्राहक को प्रतिक्रिया भेजने के लिए प्रतिक्रिया () फ़ंक्शन का उपयोग कर सकते हैं और JSON प्रारूप में प्रतिक्रिया भेजने के लिए आप प्रतिक्रिया समारोह को जसन () फ़ंक्शन के साथ चेन कर सकते हैं।
json () फ़ंक्शन सिंटैक्स
json(string|array $data = array(), int $status = 200, array $headers = array(), int $options)
उदाहरण
Step 1 - नामक एक व्यू फाइल बनाएं resources/views/message.php और उस फ़ाइल में निम्न कोड कॉपी करें।
<html>
<head>
<title>Ajax Example</title>
<script src = "https://ajax.googleapis.com/ajax/libs/jquery/2.1.3/jquery.min.js">
</script>
<script>
function getMessage() {
$.ajax({
type:'POST',
url:'/getmsg',
data:'_token = <?php echo csrf_token() ?>',
success:function(data) {
$("#msg").html(data.msg);
}
});
}
</script>
</head>
<body>
<div id = 'msg'>This message will be replaced using Ajax.
Click the button to replace the message.</div>
<?php
echo Form::button('Replace Message',['onClick'=>'getMessage()']);
?>
</body>
</html>
Step 2 - एक नियंत्रक बनाएँ AjaxController निम्नलिखित कमांड निष्पादित करके।
php artisan make:controller AjaxController --plain
Step 3 - सफल निष्पादन के बाद, आपको निम्न आउटपुट प्राप्त होंगे -
Step 4 - निम्नलिखित कोड को कॉपी करें
app/Http/Controllers/AjaxController.php फ़ाइल।
app/Http/Controllers/AjaxController.php
<?php
namespace App\Http\Controllers;
use Illuminate\Http\Request;
use App\Http\Requests;
use App\Http\Controllers\Controller;
class AjaxController extends Controller {
public function index() {
$msg = "This is a simple message.";
return response()->json(array('msg'=> $msg), 200);
}
}
Step 5 - निम्नलिखित पंक्तियों को जोड़ें app/Http/routes.php।
app/Http/routes.php
Route::get('ajax',function() {
return view('message');
});
Route::post('/getmsg','AjaxController@index');
Step 6 - अजाक्स कार्यक्षमता का परीक्षण करने के लिए निम्न URL पर जाएं।
http://localhost:8000/ajax
Step 7 - आपको एक पृष्ठ पर पुनः निर्देशित किया जाएगा जहां आपको एक संदेश दिखाई देगा जैसा कि निम्नलिखित छवि में दिखाया गया है।
Step 8 - बटन पर क्लिक करने के बाद आउटपुट निम्न छवि में दिखाया गया है।
अधिकांश वेब अनुप्रयोगों में त्रुटि से निपटने के लिए विशिष्ट तंत्र होते हैं। इनका उपयोग करते हुए, वे त्रुटियों और अपवादों को ट्रैक करते हैं, और प्रदर्शन का विश्लेषण करने के लिए उन्हें लॉग करते हैं। इस अध्याय में, आप लारवेल अनुप्रयोगों में त्रुटि से निपटने के बारे में पढ़ेंगे।
महत्वपूर्ण बिंदु
लारवेल में त्रुटि से निपटने के बारे में विस्तार से जानने के लिए आगे बढ़ने से पहले, कृपया निम्नलिखित महत्वपूर्ण बिंदुओं पर ध्यान दें -
किसी भी नए प्रोजेक्ट के लिए, Laravel त्रुटियों और अपवादों को लॉग इन करता है App\Exceptions\Handlerकक्षा, डिफ़ॉल्ट रूप से। फिर उन्हें विश्लेषण के लिए उपयोगकर्ता को वापस भेज दिया जाता है।
जब आपका लारवेल एप्लिकेशन डिबग मोड में सेट होता है, तो स्टैक ट्रैस के साथ विस्तृत त्रुटि संदेश आपके वेब एप्लिकेशन के भीतर होने वाली प्रत्येक त्रुटि पर दिखाई देगा।
डिफ़ॉल्ट रूप से, डिबग मोड सेट है false और आप इसे बदल सकते हैं true। यह उपयोगकर्ता को स्टैक के निशान के साथ सभी त्रुटियों को ट्रैक करने में सक्षम बनाता है।
लारवेल परियोजना के विन्यास में शामिल हैं debugविकल्प जो यह निर्धारित करता है कि उपयोगकर्ता को किसी त्रुटि के बारे में कितनी जानकारी प्रदर्शित करनी है। वेब एप्लिकेशन में डिफ़ॉल्ट रूप से, विकल्प पर्यावरण के चर में परिभाषित मूल्य पर सेट होता है.env फ़ाइल।
मान सेट किया गया है true एक स्थानीय विकास के माहौल में और करने के लिए तैयार है false एक उत्पादन वातावरण में।
यदि मान सेट है true एक उत्पादन वातावरण में, अंतिम उपयोगकर्ताओं के साथ संवेदनशील जानकारी साझा करने का जोखिम अधिक होता है।
त्रुटि संग्रह
वेब एप्लिकेशन में त्रुटियों को लॉग इन करने से उन्हें ट्रैक करने में मदद मिलती है और उन्हें हटाने के लिए रणनीति तैयार करने में मदद मिलती है। लॉग जानकारी को वेब एप्लिकेशन में कॉन्फ़िगर किया जा सकता हैconfig/app.phpफ़ाइल। लारवेल में त्रुटि लॉग से निपटने के दौरान कृपया निम्नलिखित बातों पर ध्यान दें -
लारवेल मोनोलॉग पीएचपी लॉगिंग लाइब्रेरी का उपयोग करता है।
त्रुटि ट्रैकिंग के लिए उपयोग किए जाने वाले लॉगिंग पैरामीटर हैं single, daily, syslog तथा errorlog।
उदाहरण के लिए, यदि आप लॉग फ़ाइलों में त्रुटि संदेशों को लॉग इन करना चाहते हैं, तो आपको अपने ऐप कॉन्फ़िगरेशन में लॉग वैल्यू को सेट करना चाहिए daily जैसा कि नीचे कमांड में दिखाया गया है -
'log' => env('APP_LOG',’daily’),
अगर द daily लॉग मोड को पैरामीटर के रूप में लिया जाता है, लारवेल की अवधि के लिए त्रुटि लॉग लेता है 5 days, डिफ़ॉल्ट रूप से। यदि आप लॉग फ़ाइल की अधिकतम संख्या को बदलना चाहते हैं, तो आपको पैरामीटर सेट करना होगाlog_max_files एक वांछित मान के लिए कॉन्फ़िगरेशन फ़ाइल में।
‘log_max_files’ => 25;
गंभीर स्तर
जैसा कि लारवेल मोनोलॉग पीएचपी लॉगिंग लाइब्रेरी का उपयोग करता है, विभिन्न स्तरों का विश्लेषण गंभीरता स्तर के विश्लेषण के लिए किया जाता है। उपलब्ध होने वाले विभिन्न गंभीरता स्तर हैंerror, critical, alert तथा emergency messages। आप नीचे दिए गए कमांड में दिखाए गए अनुसार गंभीरता स्तर सेट कर सकते हैं -
'log_level' => env('APP_LOG_LEVEL', 'error')
ईवेंट एक सरल पर्यवेक्षक कार्यान्वयन प्रदान करते हैं जो उपयोगकर्ता को वेब एप्लिकेशन में ट्रिगर की गई विभिन्न घटनाओं की सदस्यता लेने और सुनने की अनुमति देता है। लारवेल में सभी घटना वर्गों में संग्रहीत हैंapp/Events फ़ोल्डर और श्रोताओं में संग्रहीत हैं app/Listeners फ़ोल्डर।
आपके वेब एप्लिकेशन में घटनाओं और श्रोताओं को उत्पन्न करने के लिए कारीगर कमांड नीचे दिखाया गया है -
php artisan event:generate
यह कमांड ऊपर चर्चा की गई घटनाओं और श्रोताओं को संबंधित फ़ोल्डर में उत्पन्न करता है।
ईवेंट और श्रोता वेब एप्लिकेशन को डिकोड करने का एक शानदार तरीका प्रदान करते हैं, क्योंकि एक ईवेंट में कई श्रोता हो सकते हैं जो एक दूसरे से स्वतंत्र होते हैं। कारीगर कमांड द्वारा बनाए गए ईवेंट फ़ोल्डर में निम्नलिखित दो फाइलें शामिल हैं: event.php और SomeEvent.php। उन्हें यहाँ दिखाया गया है -
Event.php
<?php
namespace App\Events;
abstract class Event{
//
}
जैसा कि ऊपर उल्लेख किया गया है, event.php वर्ग की मूल परिभाषा शामिल है Event और नाम स्थान के लिए कॉल करता है App\Events। कृपया ध्यान दें कि इस फ़ाइल में उपयोगकर्ता परिभाषित या कस्टम ईवेंट बनाए गए हैं।
SomeEvent.php
<?php
namespace App\Events;
use App\Events\Event;
use Illuminate\Queue\SerializesModels;
use Illuminate\Contracts\Broadcasting\ShouldBroadcast;
class SomeEvent extends Event{
use SerializesModels;
/**
* Create a new event instance.
*
* @return void
*/
public function __construct() {
//
}
/**
* Get the channels the event should be broadcast on.
*
* @return array
*/
public function broadcastOn() {
return [];
}
}
देखें कि यह फ़ाइल किसी वेब अनुप्रयोग में घटनाओं के प्रसारण के लिए क्रमांकन का उपयोग करती है और आवश्यक पैरामीटर भी इस फ़ाइल में आरंभिक हैं।
उदाहरण के लिए, अगर हमें किसी घटना को दर्ज करने के लिए कंस्ट्रक्टर में ऑर्डर वैरिएबल को इनिशियलाइज़ करना है, तो हम इसे निम्न तरीके से कर सकते हैं -
public function __construct(Order $order) {
$this->order = $order;
}
श्रोताओं
श्रोता पंजीकृत होने वाली किसी घटना में उल्लिखित सभी गतिविधियों को संभालते हैं। कारीगर की आज्ञाevent:generate सभी बनाता है listeners में app/listenersनिर्देशिका। श्रोता फ़ोल्डर में एक फ़ाइल शामिल हैEventListener.php जिसमें श्रोताओं को संभालने के लिए आवश्यक सभी तरीके हैं।
EventListener.php
<?php
namespace App\Listeners;
use App\Events\SomeEvent;
use Illuminate\Queue\InteractsWithQueue;
use Illuminate\Contracts\Queue\ShouldQueue;
class EventListener{
/**
* Create the event listener.
*
* @return void
*/
public function __construct() {
//
}
/**
* Handle the event.
*
* @param SomeEvent $event * @return void */ public function handle(SomeEvent $event) {
//
}
}
जैसा कि कोड में बताया गया है, इसमें शामिल है handleविभिन्न घटनाओं के प्रबंधन के लिए कार्य करते हैं। हम विभिन्न स्वतंत्र श्रोताओं को बना सकते हैं जो किसी एक घटना को लक्षित करते हैं।
Facades एक प्रदान करते हैं staticवर्गों के लिए इंटरफ़ेस जो एप्लिकेशन के सर्विस कंटेनर में उपलब्ध हैं। laravelfacades के रूप में सेवा static proxies सेवा कंटेनर में अंतर्निहित कक्षाएं, पारंपरिक स्थैतिक विधियों की तुलना में अधिक परीक्षण क्षमता और लचीलेपन को बनाए रखते हुए, एक कविता, अभिव्यंजक वाक्यविन्यास का लाभ प्रदान करती हैं।
मुखौटा कैसे बनाएँ
लारावेल में मुखौटा बनाने के लिए निम्नलिखित कदम हैं -
Step 1 - PHP क्लास फ़ाइल बनाएँ।
Step 2 - उस वर्ग को सेवा प्रदाता से बांधें।
Step 3 - उस ServiceProvider को पंजीकृत करें
प्रदाताओं के रूप में कॉन्फ़िग \ app.php।
Step 4 - क्लास बनाएँ जो यह क्लास फैली हुई है
lluminate \ Support \ Facades \ फसाड।
Step 5 - एलियंस के रूप में config \ app.php के लिए बिंदु 4 रजिस्टर।
मुखौटा वर्ग संदर्भ
कई पहलुओं के साथ लारावेल जहाज। निम्न तालिका में निर्मित मुखौटा वर्ग संदर्भ दिखाया गया है -
मुखौटा | कक्षा | सेवा कंटेनर बाइंडिंग |
---|---|---|
एप्लिकेशन | रोशन \ फाउंडेशन \ Application | एप्लिकेशन |
शिल्पकार | रोशन \ संविदा \ कंसोल \ कर्नेल | शिल्पकार |
प्रमाणीकरण | रोशन \ प्रमाणीकरण \ AuthManager | प्रमाणन |
प्रामाणिक (उदाहरण) | रोशन \ प्रमाणीकरण \ गार्ड | |
ब्लेड | रोशन \ देखें \ संकलनकर्ता \ BladeCompiler | blade.compiler |
बस | रोशन \ संविदा \ बस \ डिस्पैचर | |
कैश | रोशन \ कैश \ भंडार | कैश |
कॉन्फ़िग | रोशन \ Config \ भंडार | कॉन्फ़िग |
कुकी | रोशन \ कुकी \ CookieJar | कुकी |
तहखाने | रोशन \ एन्क्रिप्शन \ encrypter | encrypter |
डाटाबेस | रोशन \ डाटाबेस \ DatabaseManager | डाटाबेस |
DB (उदाहरण) | रोशन \ डाटाबेस \ कनेक्शन | |
प्रतिस्पर्धा | रोशन \ घटनाक्रम \ डिस्पैचर | आयोजन |
फ़ाइल | रोशन \ फाइलसिस्टम \ फ़ाइल | फ़ाइलें |
द्वार | रोशन \ संविदा \ प्रमाणीकरण \ पहुँच \ गेट | |
हैश | रोशन \ संविदा \ हैशिंग \ क़मी बनाने की मशीन | हैश |
इनपुट | रोशन \ http \ अनुरोध | निवेदन |
लैंग | रोशन \ अनुवाद \ अनुवादक | अनुवादक |
लॉग | रोशन \ लॉग \ लेखक | लॉग |
मेल | रोशन \ मेल \ मेलर | मेलर |
कुंजिका | रोशन \ प्रमाणीकरण \ पासवर्ड \ PasswordBroker | auth.password |
कतार | रोशन \ कतार \ QueueManager | कतार |
कतार (उदाहरण) | रोशन \ कतार \ QueueInterface | |
कतार (बेस क्लास) | रोशन \ कतार \ कतार | |
पुनर्निर्देशन | रोशन \ रूटिंग \ पुनर्निर्देशक | रीडायरेक्ट |
Redis | रोशन \ Redis \ डाटाबेस | redis |
निवेदन | रोशन \ http \ अनुरोध | निवेदन |
प्रतिक्रिया | रोशन \ संविदा \ रूटिंग \ ResponseFactory | |
मार्ग | रोशन \ रूटिंग \ रूटर | रूटर |
योजना | रोशन \ डाटाबेस \ स्कीमा \ खाका | |
अधिवेशन | रोशन \ सत्र \ SessionManager | अधिवेशन |
सत्र (उदाहरण) | रोशन \ सत्र \ स्टोर | |
भंडारण | रोशन \ संविदा \ फाइलसिस्टम \ फैक्टरी | फाइल सिस्टम |
यूआरएल | रोशन \ रूटिंग \ UrlGenerator | यूआरएल |
सत्यापनकर्ता | रोशन \ मान्यता \ फैक्टरी | सत्यापनकर्ता |
सत्यापनकर्ता (उदाहरण) | रोशन \ मान्यता \ सत्यापनकर्ता | |
राय | रोशन \ देखें \ फैक्टरी | राय |
देखें (उदाहरण) | रोशन \ देखें \ देखें |
उदाहरण
Step 1 - नामक एक सेवा प्रदाता बनाएं TestFacadesServiceProvider निम्नलिखित कमांड निष्पादित करके।
php artisan make:provider TestFacadesServiceProvider
Step 2 - सफल निष्पादन के बाद, आपको निम्न आउटपुट प्राप्त होंगे -
Step 3 - नामक एक कक्षा बनाएँ TestFacades.php पर App/Test।
App/Test/TestFacades.php
<?php
namespace App\Test;
class TestFacades{
public function testingFacades() {
echo "Testing the Facades in Laravel.";
}
}
?>
Step 4 - नाम से एक मुखौटा वर्ग बनाएँ “TestFacades.php” पर “App/Test/Facades”।
App/Test/Facades/TestFacades.php
<?php
namespace app\Test\Facades;
use Illuminate\Support\Facades\Facade;
class TestFacades extends Facade {
protected static function getFacadeAccessor() { return 'test'; }
}
Step 5 - नाम से एक मुखौटा वर्ग बनाएँ TestFacadesServiceProviders.php पर App/Test/Facades.
App/Providers/TestFacadesServiceProviders.php
<?php
namespace App\Providers;
use App;
use Illuminate\Support\ServiceProvider;
class TestFacadesServiceProvider extends ServiceProvider {
public function boot() {
//
}
public function register() {
App::bind('test',function() {
return new \App\Test\TestFacades;
});
}
}
Step 6 - किसी फ़ाइल में एक सेवा प्रदाता जोड़ें config/app.php जैसा कि नीचे दिए गए आंकड़े में दिखाया गया है।
config/app.php
Step 7 - एक फ़ाइल में एक उपनाम जोड़ें config/app.php जैसा कि नीचे दिए गए आंकड़े में दिखाया गया है।
config/app.php
Step 8 - निम्नलिखित पंक्तियों को जोड़ें app/Http/routes.php.
app/Http/routes.php
Route::get('/facadeex', function() {
return TestFacades::testingFacades();
});
Step 9 - Facade का परीक्षण करने के लिए निम्न URL पर जाएं।
http://localhost:8000/facadeex
Step 10 - URL पर जाने के बाद, आपको निम्न आउटपुट प्राप्त होंगे -
लारवेल कॉन्ट्रैक्ट फ्रेमवर्क द्वारा प्रदान की गई विभिन्न कार्यात्मकताओं और कोर सेवाओं के साथ इंटरफेस का एक सेट है।
उदाहरण के लिए, Illuminate\Contracts\Queue\Queue अनुबंध एक विधि का उपयोग करता है जिसकी आवश्यकता नौकरियों की कतार के लिए होती है और Illuminate\Contracts\Mail\Mailer ईमेल भेजने के लिए विधि का उपयोग करता है।
परिभाषित प्रत्येक अनुबंध में फ्रेमवर्क का संगत कार्यान्वयन शामिल है। सभी लारवेल अनुबंध GitHub रिपॉजिटरी में उपलब्ध हैं जैसा कि नीचे बताया गया है -
https://github.com/illuminate/contracts
यह रिपॉजिटरी लारवेल ढांचे में उपलब्ध विभिन्न प्रकार के अनुबंध प्रदान करता है जिन्हें डाउनलोड और तदनुसार उपयोग किया जा सकता है।
महत्वपूर्ण बिंदु
लारवेल कॉन्ट्रैक्ट के साथ काम करते समय कृपया निम्नलिखित महत्वपूर्ण बिंदुओं पर ध्यान दें -
एक वर्ग के निर्माता में facades को परिभाषित करना अनिवार्य है।
कॉन्ट्रैक्ट को स्पष्ट रूप से कक्षाओं में परिभाषित किया गया है और आपको कंस्ट्रक्टरों में अनुबंध को परिभाषित करने की आवश्यकता नहीं है।
उदाहरण
लारवेल में प्राधिकरण के लिए इस्तेमाल अनुबंध पर विचार करें जो नीचे उल्लिखित है -
<?php
namespace Illuminate\Contracts\Auth\Access;
interface Authorizable{
/**
* Determine if the entity has a given ability.
*
* @param string $ability * @param array|mixed $arguments
* @return bool
*/
public function can($ability, $arguments = []);
}
अनुबंध एक फ़ंक्शन का उपयोग करता है जिसमें एक शामिल है parameter नामित ability तथा arguments जो एक के रूप में उपयोगकर्ता की पहचान का उपयोग करता है array।
आपको एक अनुबंध को परिभाषित करना होगा जैसा कि नीचे सिंटैक्स में दिखाया गया है -
interface <contract-name>
अनुबंधों का उपयोग मजबूत, अच्छी तरह से परीक्षण किए गए लारवेल अनुप्रयोगों को बनाने के लिए facades की तरह किया जाता है। विभिन्न हैंpractical differences अनुबंध और facades के उपयोग के साथ।
निम्नलिखित कोड एक भंडार को कैशिंग के लिए अनुबंध का उपयोग करके दिखाता है -
<?php
namespace App\Orders;
use Illuminate\Contracts\Cache\Repository as Cache;
class Repository{
/**
* The cache instance.
*/
protected $cache; /** * Create a new repository instance. * * @param Cache $cache
* @return void
*/
public function __construct(Cache $cache) { $this->cache = $cache;
}
}
अनुबंध में कोई कार्यान्वयन और नई निर्भरताएं नहीं हैं; एक निर्दिष्ट अनुबंध के वैकल्पिक कार्यान्वयन को लिखना आसान है, इस प्रकार एक उपयोगकर्ता किसी भी कोड आधार को संशोधित किए बिना कैश कार्यान्वयन को बदल सकता है।
CSRF वेब अनुप्रयोगों पर क्रॉस साइट फ़ॉगररी हमलों को संदर्भित करता है। CSRF हमले अनधिकृत गतिविधियाँ हैं जो सिस्टम के प्रमाणित उपयोगकर्ता करते हैं। जैसे, कई वेब एप्लिकेशन इन हमलों से ग्रस्त हैं।
लारवेल ने सीएसआरएफ सुरक्षा निम्न प्रकार से प्रदान की है -
लारवेल में एक निर्मित सीएसआरएफ प्लग-इन शामिल है, जो प्रत्येक सक्रिय उपयोगकर्ता सत्र के लिए टोकन उत्पन्न करता है। ये टोकन सत्यापित करते हैं कि परिचालन या अनुरोध संबंधित प्रमाणित उपयोगकर्ता द्वारा भेजे गए हैं।
कार्यान्वयन
लारवेल में सीएसआरएफ संरक्षण के कार्यान्वयन पर इस खंड में विस्तार से चर्चा की गई है। सीएसआरएफ सुरक्षा पर आगे बढ़ने से पहले निम्नलिखित बिंदु उल्लेखनीय हैं -
CSRF वेब अनुप्रयोगों के अंदर घोषित किए गए HTML रूपों में लागू किया जाता है। आपको प्रपत्र में एक छिपा हुआ सीएसआरएफ टोकन शामिल करना होगा, ताकि लारवेल के सीएसआरएफ संरक्षण मिडलवेयर अनुरोध को मान्य कर सके। वाक्य रचना नीचे दिखाया गया है -
<form method = "POST" action="/profile">
{{ csrf_field() }}
...
</form>
आप आसानी से जावास्क्रिप्ट HTTP पुस्तकालय का उपयोग करके जावास्क्रिप्ट संचालित अनुप्रयोगों का निर्माण कर सकते हैं, क्योंकि इसमें सीएसआरएफ टोकन हर आउटगोइंग अनुरोध शामिल है।
फ़ाइल अर्थात् resources/assets/js/bootstrap.js लारवेल अनुप्रयोगों के लिए सभी टोकन रजिस्टर करता है और शामिल करता है meta टैग जो संग्रहीत करता है csrf-token साथ में Axios HTTP library।
CSRF टोकन के बिना फॉर्म
कोड की निम्नलिखित पंक्तियों पर विचार करें। वे एक रूप दिखाते हैं जो इनपुट के रूप में दो पैरामीटर लेता है:email तथा message।
<form>
<label> Email </label>
<input type = "text" name = "email"/>
<br/>
<label> Message </label> <input type="text" name = "message"/>
<input type = ”submit” name = ”submitButton” value = ”submit”>
</form>
उपरोक्त कोड का परिणाम नीचे दिखाया गया रूप है जिसे अंतिम उपयोगकर्ता देख सकता है -
ऊपर दिखाया गया रूप अधिकृत उपयोगकर्ता की किसी भी इनपुट जानकारी को स्वीकार करेगा। इससे वेब एप्लिकेशन को विभिन्न हमलों का खतरा हो सकता है।
कृपया ध्यान दें कि सबमिट बटन में नियंत्रक अनुभाग में कार्यक्षमता शामिल है। postContactफ़ंक्शन का उपयोग नियंत्रकों में उस संबद्ध विचारों के लिए किया जाता है। यह नीचे दिखाया गया है -
public function postContact(Request $request) {
return $request-> all();
}
ध्यान रखें कि फ़ॉर्म में कोई भी CSRF टोकन शामिल नहीं हैं, इसलिए इनपुट मापदंडों के रूप में साझा की गई संवेदनशील जानकारी विभिन्न हमलों से ग्रस्त हैं।
CSRF टोकन के साथ फॉर्म
कोड की निम्नलिखित पंक्तियाँ आपको CSRF टोकन का उपयोग करके फिर से तैयार किया गया फॉर्म दिखाती हैं -
<form method = ”post” >
{{ csrf_field() }}
<label> Email </label>
<input type = "text" name = "email"/>
<br/>
<label> Message </label>
<input type = "text" name = "message"/>
<input type = ”submit” name = ”submitButton” value = ”submit”>
</form>
प्राप्त आउटपुट JSON को नीचे दिए गए टोकन के साथ लौटाएगा -
{
"token": "ghfleifxDSUYEW9WE67877CXNVFJKL",
"name": "TutorialsPoint",
"email": "[email protected]"
}
यह सबमिट बटन पर क्लिक करने पर बना सीएसआरएफ टोकन है।
प्रमाणीकरण उपयोगकर्ता की पहचान करने की प्रक्रिया है। वेब एप्लिकेशन में, प्रमाणीकरण को सत्रों द्वारा प्रबंधित किया जाता है जो उपयोगकर्ता पहचान के लिए ईमेल या उपयोगकर्ता नाम और पासवर्ड जैसे इनपुट मापदंडों को लेते हैं। यदि ये पैरामीटर मेल खाते हैं, तो उपयोगकर्ता को प्रमाणित कहा जाता है।
आदेश
Laravel प्रमाणीकरण बनाने के लिए प्रपत्र और संबंधित नियंत्रकों को बनाने के लिए निम्न आदेश का उपयोग करता है -
php artisan make:auth
यह कमांड सफलतापूर्वक प्रमाणीकरण मचान बनाने में मदद करता है, जैसा कि निम्नलिखित स्क्रीनशॉट में दिखाया गया है -
नियंत्रक
नियंत्रक जो प्रमाणीकरण प्रक्रिया के लिए उपयोग किया जाता है HomeController।
<?php
namespace App\Http\Controllers;
use App\Http\Requests;
use Illuminate\Http\Request;
class HomeController extends Controller{
/**
* Create a new controller instance.
*
* @return void
*/
public function __construct() {
$this->middleware('auth');
}
/**
* Show the application dashboard.
*
* @return \Illuminate\Http\Response
*/
public function index() {
return view('home');
}
}
नतीजतन, उत्पन्न पाड़ आवेदन प्रमाणीकरण करने के लिए लॉगिन पृष्ठ और पंजीकरण पृष्ठ बनाता है। वे नीचे दिखाए गए हैं -
लॉग इन करें
पंजीकरण
मैन्युअल रूप से उपयोगकर्ताओं का प्रमाणीकरण
लारवेल का उपयोग करता है Authfaçade जो उपयोगकर्ताओं को मैन्युअल रूप से प्रमाणित करने में मदद करता है। इसमें शामिल हैattempt उनके ईमेल और पासवर्ड को सत्यापित करने की विधि।
के लिए कोड की निम्नलिखित पंक्तियों पर विचार करें LoginController जिसमें प्रमाणीकरण के लिए सभी कार्य शामिल हैं -
<?php
// Authentication mechanism
namespace App\Http\Controllers;
use Illuminate\Support\Facades\Auth;
class LoginController extends Controller{
/**
* Handling authentication request
*
* @return Response
*/
public function authenticate() {
if (Auth::attempt(['email' => $email, 'password' => $password])) {
// Authentication passed...
return redirect()->intended('dashboard');
}
}
}
पिछले अध्याय में, हमने लारवेल में प्रमाणीकरण प्रक्रिया के बारे में अध्ययन किया है। यह अध्याय आपको लारवेल में प्राधिकरण प्रक्रिया की व्याख्या करता है।
प्रमाणीकरण और प्राधिकरण के बीच अंतर
लारवेल में प्राधिकरण प्रक्रिया के बारे में जानने से पहले, हम प्रमाणीकरण और प्राधिकरण के बीच के अंतर को समझते हैं।
में authentication, सिस्टम या वेब एप्लिकेशन अपने उपयोगकर्ताओं को उनके द्वारा प्रदान की जाने वाली साख के माध्यम से पहचानता है। यदि यह पता चलता है कि क्रेडेंशियल्स वैध हैं, तो वे प्रमाणित हैं, अन्यथा वे नहीं हैं।
में authorization, सिस्टम या वेब एप्लिकेशन यह जांचता है कि क्या प्रमाणीकृत उपयोगकर्ता उन संसाधनों तक पहुंच सकते हैं, जिनके लिए वे एक्सेस करने का प्रयास कर रहे हैं या उनके लिए अनुरोध कर रहे हैं। दूसरे शब्दों में, यह अनुरोधित संसाधनों पर उनके अधिकारों और अनुमतियों की जाँच करता है। यदि यह पता चलता है कि वे संसाधनों तक पहुंच सकते हैं, तो इसका मतलब है कि वे अधिकृत हैं।
इस प्रकार, authentication उपयोगकर्ता क्रेडेंशियल्स की वैधता की जाँच करना शामिल है, और authorization एक प्रामाणिक उपयोगकर्ता के पास संसाधनों पर अधिकारों और अनुमतियों की जाँच करना शामिल है।
लारवेल में प्राधिकरण तंत्र
लारवेल प्राधिकरण के लिए एक सरल तंत्र प्रदान करता है जिसमें दो प्राथमिक तरीके होते हैं, अर्थात् Gates तथा Policies।
गेट्स और नीतियां लिखना
यह निर्धारित करने के लिए गेट्स का उपयोग किया जाता है कि उपयोगकर्ता किसी निर्दिष्ट कार्रवाई को करने के लिए अधिकृत है या नहीं। वे आम तौर पर में परिभाषित होते हैंApp/Providers/AuthServiceProvider.phpगेट मुखौटा का उपयोग करना। गेट भी ऐसे कार्य हैं जो प्राधिकरण तंत्र के प्रदर्शन के लिए घोषित किए जाते हैं।
नीतियां एक सरणी के भीतर घोषित की जाती हैं और कक्षाओं और विधियों के भीतर उपयोग की जाती हैं जो प्राधिकरण तंत्र का उपयोग करती हैं।
कोड की निम्नलिखित पंक्तियाँ आपको बताती हैं कि लारावेल वेब एप्लिकेशन में उपयोगकर्ता को अधिकृत करने के लिए गेट्स और नीतियां का उपयोग कैसे करें। ध्यान दें कि इस उदाहरण में,boot फ़ंक्शन का उपयोग उपयोगकर्ताओं को अधिकृत करने के लिए किया जाता है।
<?php
namespace App\Providers;
use Illuminate\Contracts\Auth\Access\Gate as GateContract;
use Illuminate\Foundation\Support\Providers\AuthServiceProvider as ServiceProvider;
class AuthServiceProvider extends ServiceProvider{
/**
* The policy mappings for the application.
*
* @var array
*/
protected $policies = [ 'App\Model' => 'App\Policies\ModelPolicy', ]; /** * Register any application authentication / authorization services. * * @param \Illuminate\Contracts\Auth\Access\Gate $gate
* @return void
*/
public function boot(GateContract $gate) { $this->registerPolicies($gate);
//
}
}
Laravel फ्रेमवर्क, लाइन-कमांड के माध्यम से सहभागिता के लिए तीन प्राथमिक उपकरण प्रदान करता है: Artisan, Ticker तथा REPL। इस अध्याय में कारीगर के बारे में विस्तार से बताया गया है।
कारीगर का परिचय
कारीगर कमांड लाइन इंटरफ़ेस है जिसका उपयोग अक्सर लारवेल में किया जाता है और इसमें वेब एप्लिकेशन विकसित करने के लिए सहायक कमांड का एक सेट शामिल होता है।
उदाहरण
यहाँ कारीगरों में कुछ आदेशों की एक सूची दी गई है।
To start Laravel project
php artisan serve
To enable caching mechanism
php artisan route:cache
To view the list of available commands supported by Artisan
php artisan list
To view help about any command and view the available options and arguments
php artisan help serve
निम्न स्क्रीनशॉट ऊपर दिए गए आदेशों का उत्पादन दिखाता है -
लेखन कमांड
आर्टिसन में सूचीबद्ध कमांड के अलावा, एक उपयोगकर्ता एक कस्टम कमांड भी बना सकता है जिसे वेब एप्लिकेशन में उपयोग किया जा सकता है। कृपया ध्यान दें कि आदेशों को संग्रहीत किया जाता हैapp/console/commands directory।
उपयोगकर्ता परिभाषित कमांड बनाने के लिए डिफ़ॉल्ट कमांड नीचे दिखाया गया है -
php artisan make:console <name-of-command>
एक बार जब आप ऊपर दी गई कमांड टाइप करते हैं, तो आप नीचे दिए गए स्क्रीनशॉट में दिखाए अनुसार आउटपुट देख सकते हैं -
के लिए बनाई गई फ़ाइल DefaultCommand नाम दिया गया है DefaultCommand.php और नीचे दिखाया गया है -
<?php
namespace App\Console\Commands;
use Illuminate\Console\Command;
class DefaultCommand extends Command{
/**
* The name and signature of the console command.
*
* @var string
*/
protected $signature = 'command:name';
/**
* The console command description.
*
* @var string
*/
protected $description = 'Command description';
/**
* Create a new command instance.
*
* @return void
*/
public function __construct() {
parent::__construct();
}
/**
* Execute the console command.
*
* @return mixed
*/
public function handle() {
//
}
}
इस फ़ाइल में उपयोगकर्ता द्वारा परिभाषित कमांड के लिए हस्ताक्षर और विवरण शामिल हैं। सार्वजनिक समारोह का नामhandleकमांड निष्पादित होने पर कार्यक्षमताओं को निष्पादित करता है। ये कमांड फ़ाइल में पंजीकृत हैंKernel.php उसी निर्देशिका में।
आप उपयोगकर्ता परिभाषित कमांड के लिए कार्यों का शेड्यूल भी बना सकते हैं जैसा कि निम्नलिखित कोड में दिखाया गया है -
<?php
namespace App\Console;
use Illuminate\Console\Scheduling\Schedule;
use Illuminate\Foundation\Console\Kernel as ConsoleKernel;
class Kernel extends ConsoleKernel {
/**
* The Artisan commands provided by your application.
*
* @var array
*/
protected $commands = [
// Commands\Inspire::class,
Commands\DefaultCommand::class
];
/**
* Define the application's command schedule.
*
* @param \Illuminate\Console\Scheduling\Schedule $schedule * @return void */ protected function schedule(Schedule $schedule) {
// $schedule->command('inspire')
// ->hourly();
}
}
ध्यान दें कि दिए गए कमांड के लिए कार्यों की अनुसूची नामांकित फ़ंक्शन में परिभाषित की गई है schedule, जिसमें शामिल होने वाले कार्यों को निर्धारित करने के लिए एक पैरामीटर शामिल है hourly पैरामीटर।
आदेशों को कमांड के सरणी में पंजीकृत किया जाता है, जिसमें कमांड का पथ और नाम शामिल होता है।
एक बार कमांड पंजीकृत होने के बाद, इसे कारीगर कमांड में सूचीबद्ध किया जाता है। जब आप निर्दिष्ट कमांड की सहायता विशेषता के लिए कहते हैं, तो हस्ताक्षर और विवरण अनुभाग में शामिल मूल्य प्रदर्शित किए जाएंगे।
आइए देखें कि हमारे कमांड की विशेषताओं को कैसे देखा जाए DefaultCommand। आपको नीचे दिखाए अनुसार कमांड का उपयोग करना चाहिए -
php artisan help DefaultCommand
एन्क्रिप्शन एक सादा पाठ को कुछ एल्गोरिदम का उपयोग करके संदेश में परिवर्तित करने की एक प्रक्रिया है, जिससे कोई तीसरा उपयोगकर्ता जानकारी नहीं पढ़ सकता है। यह संवेदनशील सूचनाओं को प्रसारित करने के लिए सहायक है क्योंकि हस्तांतरित सूचना को लक्षित करने के लिए घुसपैठिया के लिए कम संभावनाएं हैं।
एन्क्रिप्शन नामक एक प्रक्रिया का उपयोग करके किया जाता है Cryptography। जिस पाठ को एन्क्रिप्ट किया जाना है उसे ही कहा जाता हैPlain Text और एन्क्रिप्शन के बाद पाठ या संदेश प्राप्त होता है Cipher Text। सिफर टेक्स्ट को प्लेन टेक्स्ट में बदलने की प्रक्रिया को कहा जाता हैDecryption।
लारवेल का उपयोग करता है AES-256 तथा AES-128एन्क्रिप्शन, जो एन्क्रिप्शन के लिए ओपन एसएसएल का उपयोग करता है। लारवेल में शामिल सभी मूल्यों पर प्रोटोकॉल का उपयोग करके हस्ताक्षर किए गए हैंMessage Authentication Code एक बार एन्क्रिप्ट किए जाने के बाद अंतर्निहित मूल्य से छेड़छाड़ नहीं की जा सकती है।
विन्यास
कमांड जनरेट करता था key लारवेल में नीचे दिखाया गया है -
php artisan key:generate
कृपया ध्यान दें कि यह कमांड PHP सुरक्षित रैंडम बाइट्स जनरेटर का उपयोग करता है और आप नीचे दिए गए स्क्रीनशॉट में दिखाए अनुसार आउटपुट देख सकते हैं -
ऊपर दी गई कमांड कुंजी को उत्पन्न करने में मदद करती है जिसका उपयोग वेब एप्लिकेशन में किया जा सकता है। नीचे दिखाए गए स्क्रीनशॉट को ध्यान से देखें -
ध्यान दें
एन्क्रिप्शन के लिए मान ठीक से संरेखित हैं config/app.php फ़ाइल, जिसमें एन्क्रिप्शन के लिए दो पैरामीटर शामिल हैं key तथा cipher। यदि इस कुंजी का उपयोग करने वाला मान ठीक से संरेखित नहीं किया गया है, तो लारवेल में एन्क्रिप्ट किए गए सभी मान असुरक्षित होंगे।
एन्क्रिप्शन प्रक्रिया
का उपयोग करके किसी मान का एन्क्रिप्शन किया जा सकता है encrypt helperलारवेल वर्ग के नियंत्रकों में। इन मूल्यों को OpenSSL और AES-256 सिफर का उपयोग करके एन्क्रिप्ट किया गया है। एन्क्रिप्टेड स्ट्रिंग के किसी भी संशोधन के लिए जाँच करने के लिए संदेश प्रमाणीकरण कोड (मैक) के साथ सभी एन्क्रिप्टेड मूल्यों पर हस्ताक्षर किए जाते हैं।
नीचे दिखाया गया कोड एक नियंत्रक में उल्लिखित है और इसका उपयोग गुप्त या संवेदनशील संदेश को संग्रहीत करने के लिए किया जाता है।
<?php
namespace App\Http\Controllers;
use Illuminate\Http\Request;
use App\Http\Controllers\Controller;
class DemoController extends Controller{
**
* Store a secret message for the user.
*
* @param Request $request
* @param int $id * @return Response */ public function storeSecret(Request $request, $id) { $user = User::findOrFail($id); $user->fill([
'secret' => encrypt($request->secret)
])->save();
}
}
डिक्रिप्शन प्रक्रिया
मानों का डिक्रिप्शन किसके साथ किया जाता है decrypt helper। कोड की निम्नलिखित पंक्तियों को ध्यान से देखें -
use Illuminate\Contracts\Encryption\DecryptException;
// Exception for decryption thrown in facade
try {
$decrypted = decrypt($encryptedValue); } catch (DecryptException $e) {
//
}
कृपया ध्यान दें कि यदि अमान्य मैक का उपयोग किए जाने के कारण डिक्रिप्शन की प्रक्रिया सफल नहीं होती है, तो एक उपयुक्त अपवाद फेंक दिया जाता है।
हाशिंग वर्णों के स्ट्रिंग को छोटे निश्चित मान या मूल स्ट्रिंग का प्रतिनिधित्व करने वाली कुंजी में बदलने की प्रक्रिया है। लारवेल का उपयोग करता हैHash मुखौटा जो हैशेड तरीके से पासवर्ड संग्रहीत करने के लिए एक सुरक्षित तरीका प्रदान करता है।
मूल उपयोग
निम्न स्क्रीनशॉट दिखाता है कि नाम नियंत्रक कैसे बनाया जाए passwordController जिसका उपयोग पासवर्ड को संग्रहीत करने और अद्यतन करने के लिए किया जाता है -
कोड की निम्नलिखित लाइनें कार्यक्षमता और उपयोग के बारे में बताती हैं passwordController -
<?php
namespace App\Http\Controllers;
use Illuminate\Http\Request;
use Illuminate\Support\Facades\Hash;
use App\Http\Controllers\Controller
class passwordController extends Controller{
/**
* Updating the password for the user.
*
* @param Request $request * @return Response */ public function update(Request $request) {
// Validate the new password length...
$request->user()->fill([ 'password' => Hash::make($request->newPassword) // Hashing passwords
])->save();
}
}
हैशेड पासवर्ड का उपयोग करके संग्रहीत किया जाता है makeतरीका। यह विधि कार्य कारक के प्रबंधन की अनुमति देती हैbcrypt हैशिंग एल्गोरिथ्म, जिसका लोकप्रिय लारवेल में उपयोग किया जाता है।
हैश के खिलाफ पासवर्ड का सत्यापन
आपको उस स्ट्रिंग की जांच करने के लिए हैश का पासवर्ड सत्यापित करना चाहिए जो रूपांतरण के लिए उपयोग की गई थी। इसके लिए आप उपयोग कर सकते हैंcheckतरीका। यह नीचे दिए गए कोड में दिखाया गया है -
if (Hash::check('plain-text', $hashedPassword)) {
// The passwords match...
}
ध्यान दें कि check विधि सादे पाठ के साथ तुलना करता है hashedPassword परिवर्तनशील और यदि परिणाम सत्य है, तो यह एक सही मूल्य देता है।
हर वेब एप्लिकेशन फ्रेमवर्क का अपना संस्करण इतिहास होता है और इसे हमेशा अपडेट और रखरखाव किया जाता है। प्रत्येक नवीनतम संस्करण नई कार्यक्षमता और कार्य लाता है जो या तो बदल दिए जाते हैं या हटाए जाते हैं, इसलिए यह महत्वपूर्ण है कि आप जानते हैं कि कौन सा संस्करण आपकी परियोजनाओं के लिए उपयुक्त होगा।
जब लारवेल की बात आती है, तो नीचे दिए गए अनुसार दो सक्रिय संस्करण हैं -
- लारवेल 4- मई 2013 में रिलीज़ हुई
- लारवेल 5.1- फरवरी 2015 में रिलीज़ हुई
Laravel 5.1 में Laravel 5.1.5 के नवीनतम संस्करण के साथ विभिन्न रिलीज़ भी शामिल हैं जिसमें वेब विकास के लिए सभी मजबूत विशेषताएं शामिल हैं। लारवेल का रोडमैप या संस्करण रिलीज़ नीचे दी गई छवि में दिखाया गया है -
लारवेल की रिहाई की प्रक्रिया को समझने के संदर्भ में निम्नलिखित बिंदु उल्लेखनीय हैं -
की पुरानी निर्देशिका है app/models लारवेल 5.1 में हटा दिया गया है।
सभी नियंत्रकों, मिडलवेयर और अनुरोधों को एप्लिकेशन / Http फ़ोल्डर के अंतर्गत एक निर्देशिका में समूहीकृत किया जाता है।
एक नया फ़ोल्डर अर्थात् Providers निर्देशिका के साथ बदल दिया है app/start लारवेल के पिछले संस्करणों में फ़ाइलें 4.x.
सभी भाषा फ़ाइलों और विचारों को स्थानांतरित कर दिया जाता है resources निर्देशिका।
नया कारीगर कमान route:cache का उपयोग नए मार्गों के पंजीकरण के लिए किया जाता है और इसमें लारवेल 5.1 और आगे के संस्करण जारी किए जाते हैं।
लारवेल सपोर्ट करता है HTTP middleware और भी शामिल है CSRF tokens और प्रमाणीकरण मॉडल।
सभी प्रमाणीकरण मॉडल एक निर्देशिका के अंतर्गत स्थित हैं resources/views/auth। इसमें उपयोगकर्ता पंजीकरण, प्रमाणीकरण और पासवर्ड नियंत्रक शामिल हैं।
लारवेल जारी
संस्करण | रिहाई | बग फिक्स तक | सिक्योरिटी फिक्स तक |
---|---|---|---|
V1 | जून 2011 | - | - |
वी 2 | सितंबर 2011 | - | - |
वी 3 | फरवरी 2012 | - | - |
v4 | मई 2013 | - | - |
5.0 | फ़रवरी 4, 2015 | अगस्त 4, 2015 | फ़रवरी 4, 2016 |
5.1 (LTS) | जून ९, २०१५ | जून 9, 2017 | जून ९, २०१8 |
5.2 | दिसंबर 21, 2015 | जून 21, 2016 | दिसंबर 21, 2016 |
5.3 | अगस्त २३, २०१६ | फरवरी 23, 2017 | अगस्त २३, २०१ 2017 |
5.4 | २४ जनवरी २०१ 2017 | जुलाई 24, 2017 | जनवरी 24, 2018 |
5.5 (LTS) | अगस्त ३०, २०१ 2017 | अगस्त ३०, २०१ ९ | अगस्त 30, 2020 |
5.6 | फरवरी 7, 2018 | अगस्त 7, 2018 | फरवरी 7, 2019 |
5.7 | 4 सितंबर, 2018 | फरवरी 4, 2019 | 4 सितंबर, 2019 |
ध्यान दें कि हाइलाइट किया गया संस्करण नवीनतम रिलीज़ को चिह्नित करता है।
अतिथि उपयोगकर्ता गेट्स सुविधा सितंबर 2018 में जारी नवीनतम 5.7 संस्करण के लिए एक ऐड-ऑन है। इस सुविधा का उपयोग विशिष्ट उपयोगकर्ताओं के लिए प्राधिकरण प्रक्रिया शुरू करने के लिए किया जाता है।
लारवेल 5.6 में, एक प्रक्रिया थी जहां यह वापस लौटता था falseअनधिकृत उपयोगकर्ताओं के लिए। Laravel 5.7 में, हम विशिष्ट का उपयोग करके मेहमानों को प्राधिकरण की जांच करने की अनुमति दे सकते हैंnullable नीचे दिए गए अनुसार निर्दिष्ट नियंत्रक के भीतर लिखें संकेत -
<?php
Gate::define('view-post', function (?User $user) {
// Guests
});
संहिता की व्याख्या
ए का उपयोग करके nullableजब कोई अतिथि उपयोगकर्ता गेट पर जाता है, तो $ उपयोगकर्ता चर इंगित करता है। फिर आप कार्रवाई को अधिकृत करने के बारे में निर्णय ले सकते हैं। यदि आप अशक्त प्रकारों को अनुमति देते हैं और सही हैं, तो अतिथि के पास प्राधिकरण होगा। यदि आप एक अशक्त प्रकार के संकेत का उपयोग नहीं करते हैं, तो मेहमानों को स्वचालित रूप से लारवेल 5.7 के लिए 403 प्रतिक्रिया मिलेगी, जो नीचे प्रदर्शित की गई है -
403 और 404 त्रुटि के बीच का अंतर यह है कि 404 तब प्रदर्शित किया जाता है जब उपयोगकर्ता अज्ञात संसाधन या URL तक पहुंचने का प्रयास करता है और 403 त्रुटि जैसा कि ऊपर स्नैपशॉट में दिखाया गया है यदि अनधिकृत उपयोगकर्ता वेबसाइट तक पहुंचता है।
लारवेल 5.7 नए आदेशों के इलाज और परीक्षण के नए तरीके के साथ आता है। इसमें कारीगर कमांडों के परीक्षण की एक नई विशेषता शामिल है और प्रदर्शन नीचे उल्लिखित है -
class ArtisanCommandTest extends TestCase{
public function testBasicTest() {
$this->artisan('nova:create', [
'name' => 'My New Admin panel'
])
->expectsQuestion('Please enter your API key', 'apiKeySecret')
->expectsOutput('Authenticating...')
->expectsQuestion('Please select a version', 'v1.0')
->expectsOutput('Installing...')
->expectsQuestion('Do you want to compile the assets?', 'yes')
->expectsOutput('Compiling assets...')
->assertExitCode(0);
}
}
संहिता की व्याख्या
यहां "आर्टिसनकोमांडटेस्ट" नामक एक नया वर्ग परीक्षण मामलों के मॉड्यूल के तहत बनाया गया है। इसमें एक मूल कार्य शामिल हैtestBasicTest जिसमें मुखरता के विभिन्न कार्य शामिल हैं।
कारीगर की आज्ञा expectsQuestionदो विशेषताएँ शामिल हैं। एक प्रश्न के साथ और दूसरा एक के साथapiKeySecret। यहां, कारीगर एपिसेक्रेेट को मान्य करता है और उपयोगकर्ता द्वारा भेजे गए इनपुट की पुष्टि करता है।
एक ही परिदृश्य प्रश्न के लिए लागू होता है "कृपया एक संस्करण का चयन करें" जहां एक उपयोगकर्ता को एक विशिष्ट संस्करण का उल्लेख करने की उम्मीद है।
Laravel में पेजिंग की एक सुविधा शामिल है जो एक उपयोगकर्ता या डेवलपर को पेजिंग सुविधा को शामिल करने में मदद करती है। लारावेल पेजिनेटर क्वेरी बिल्डर और एलोक्वेंट ओआरएम के साथ एकीकृत है। पेजेट विधि स्वचालित रूप से आवश्यक सीमा और परिभाषित ऑफसेट की स्थापना का ख्याल रखती है। यह केवल एक पैरामीटर को पेजेट करने के लिए स्वीकार करता है अर्थात एक पृष्ठ में प्रदर्शित होने वाली वस्तुओं की संख्या।
Laravel 5.7 पेजिनेटर के प्रत्येक पक्ष पर पृष्ठों की संख्या को अनुकूलित करने के लिए एक नया पृष्ठांकन विधि शामिल करता है। नई विधि को अब कस्टम पेजेशन दृश्य की आवश्यकता नहीं है।
कस्टम पृष्ठांकन दृश्य कोड प्रदर्शन नीचे उल्लिखित है -
<?php
namespace App\Http\Controllers;
use Illuminate\Support\Facades\DB;
use App\Http\Controllers\Controller;
class UserController extends Controller{
/**
* Show all of the users for the application.
*
* @return Response
*/
public function index() {
$users = DB::table('users')->paginate(15); return view('user.index', ['users' => $users]);
}
}
लारावेल मानकों के अनुसार नया पृष्ठांकन अनुकूलन नीचे उल्लिखित है -
<?php
User::paginate(10)->onEachSide(5);
ध्यान दें कि onEachSide 10 के साथ प्रत्येक अंकन रिकॉर्ड के उपखंड और 5 के उपखंड को संदर्भित करता है।
Laravel डंप सर्वर Laravel 5.7 के संस्करण के साथ आता है। पिछले संस्करणों में कोई डंप सर्वर शामिल नहीं है। डंप सर्वर लारवल / लार्वा कंपोजर फाइल में एक विकास निर्भरता होगी।
संस्करण 5.7 जारी करने के साथ, आपको यह आदेश मिलेगा जिसमें एक अवधारणा आउट-ऑफ-बॉक्स शामिल है जो उपयोगकर्ता को ब्राउज़र के बजाय कंसोल या HTML फ़ाइल में डेटा डंप करने की अनुमति देता है। कमांड निष्पादन नीचे उल्लिखित है -
php artisan dump-server
# Or send the output to an HTML file
php artisan dump-server --format=html > dump.html
व्याख्या
कमांड पृष्ठभूमि में एक सर्वर चलाता है जो एप्लिकेशन से भेजे गए डेटा के संग्रह में मदद करता है, जो कंसोल के माध्यम से आउटपुट भेजता है। जब कमांड अग्रभूमि में नहीं चल रहा है, तो डंप () फ़ंक्शन डिफ़ॉल्ट रूप से काम करने की उम्मीद है।
Laravel 5.7 एक नया फीचर पेश करता है जिसे "कॉल करने योग्य एक्शन URL" कहा जाता है। यह सुविधा लारवेल 5.6 में एक के समान है जो एक्शन विधि में स्ट्रिंग को स्वीकार करती है। लारवेल 5.7 पेश किए गए नए सिंटैक्स का मुख्य उद्देश्य सीधे नियंत्रक को एक्सेस करने में सक्षम करना है।
लारवेल 5.6 संस्करण में प्रयुक्त सिंटैक्स निम्नानुसार है -
<?php
$url = action('UserController@profile', ['id' => 1]);
लारवेल 5.7 में इसी तरह की कार्रवाई का उल्लेख नीचे किया गया है -
<?php
$url = action([PostsController::class, 'index']);
नए कॉल करने योग्य सरणी सिंटैक्स प्रारूप के साथ एक लाभ नियंत्रक को सीधे नेविगेट करने की क्षमता है यदि कोई डेवलपर किसी टेक्स्ट एडिटर या आईडीई का उपयोग करता है जो कोड नेविगेशन का समर्थन करता है।