लारवेल - नियंत्रक
एमवीसी ढांचे में, 'सी' अक्षर नियंत्रक के लिए खड़ा है। यह दृश्य और मॉडल के बीच निर्देशन यातायात के रूप में कार्य करता है। इस अध्याय में, आप लारवेल में नियंत्रकों के बारे में जानेंगे।
एक नियंत्रक बनाना
आपके द्वारा उपयोग किए जा रहे ऑपरेटिंग सिस्टम के आधार पर कमांड प्रॉम्प्ट या टर्मिनल खोलें और कारीगर 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>’);
उस क्लास के नाम के साथ <class-name-of-the-नियंत्रक> को बदलें जो आपने अपने नियंत्रक को दिया है।
कंट्रोलर की विधि का नाम 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
यह निम्नलिखित उत्पादन का उत्पादन करेगा -