FuelPHP - नियंत्रकों

Controllersप्रत्येक अनुरोध है कि FuelPHP आवेदन में आता है से निपटने के लिए जिम्मेदार हैं। FuelPHP के अनुसार, नियंत्रकों में स्थित हैंfuel/app/classes/controller/। आइए सबसे पहले एक एम्प्लॉई कंट्रोलर बनाएं।

employee.php

<?php  
   class Controller_Employee extends Controller { 
      public function action_home() { 
         echo "FuelPHP-Employee application!"; 
      }  
      
      public function action_index() { 
         echo "This is the index method of employee controller"; 
      } 
   }

नियंत्रक के तरीके

नियंत्रणकर्ता इसके किसी एक का उपयोग करके एक वेब अनुरोध संसाधित करते हैं action_ विधियाँ। हम एप्लिकेशन की आवश्यकता के आधार पर कई एक्शन_ तरीके बना सकते हैं । डिफ़ॉल्ट क्रिया_ विधि Action_index हैएक्शन_इंडेक्स विधि को निम्नलिखित में से किसी एक URL से बुलाया जा सकता है।

http://localhost:8080/employee/index
http://localhost:8080/employee/

परिणाम

हमें एक नया बनाएँ actionमेथड, एक्शन_शो हमारे मेंemployee आवेदन।

<?php  
   class Controller_Employee extends Controller { 
      public function action_home() { 
         echo "FuelPHP-Employee application!"; 
      }  
      public function action_index() { 
         echo "This is the index method of employee controller"; 
      }  
      public function action_show() { 
         echo "This is the show method of employee controller"; 
      } 
   }

action_show विधि को निम्न URL का उपयोग करके बुलाया जा सकता है।

http://localhost:8080/home/show

परिणाम

पहले () विधि

हम एक विधि बना सकते हैं, beforeहमारे नियंत्रक में। प्रत्येक एक्शन_ मेथड इनवोकेशन से पहले इस विधि को निष्पादित किया जाएगा । यह नहीं कहा जाएगा यदि वह विधि मौजूद नहीं है। यह विधि हमें सामान्य क्रियाओं जैसे लॉगिन जाँच, डिफ़ॉल्ट डेटा प्राप्त करना, आदि लिखने में मदद करती है।

हमें एक विधि बनाने से पहले और एक साधारण पाठ संदेश प्रिंट करना चाहिए।

public function before() { 
   echo "This message comes from <em>before()</em> method</br>"; 
}

सूचकांक पृष्ठ कार्रवाई से पहले

कार्रवाई से पहले पृष्ठ दिखाएं

बाद () विधि

after() विधि के समान है before()पद्धति लेकिन एक्शन_ पद्धति के बाद निष्पादित की जाती है। के बाद () विधि इनपुट के रूप में प्रतिक्रिया लेती है और प्रतिक्रिया वस्तु को वापस करती है।

public function after($response) { 
   if ( ! $response instanceof Response) { 
      $response = \Response::forge($response, $this->response_status); 
   } 
   return $response; 
}

यदि इनपुट NULL है या रिस्पॉन्स ऑब्जेक्ट नहीं है, तो रिस्पॉन्स की फोर्ज विधि का उपयोग करके एक नया रिस्पॉन्स ऑब्जेक्ट बनाएं और उसे वापस लौटाएं। हम रिस्पांस क्लास को बाद के अध्यायों में विस्तार से जानेंगे।

विस्तार करने वाले नियंत्रक

हम एक कंट्रोलर को दूसरे कंट्रोलर से बढ़ा सकते हैं। निम्नलिखित मूल सिंटैक्स है।

class Controller_Employee extends Controller_Welcome { 
   // controller methods 
}

यह तरीकों को साझा करने में मदद करेगा।

नियंत्रक उत्पन्न करें

ईंधन में ऑयल कमांड का उपयोग करके नियंत्रक उत्पन्न करने का विकल्प होता है। निम्नलिखित वाक्य रचना है।

वाक्य - विन्यास

oil g controller <controller-name>

उदाहरण

oil g controller sample

उपरोक्त कमांड निष्पादित करने के बाद, आप निम्नलिखित प्रतिक्रिया देखेंगे।

परिणाम

Creating view: /path/to/project/fuel/app/views/template.php 
Creating view: /path/to/project/fuel/app/views/sample/index.php 
Creating controller: /path/to/project/fuel/app/classes/controller/sample.php

नियंत्रकों का प्रकार

FuelPHP विभिन्न उद्देश्य के लिए विभिन्न प्रकार के नियंत्रक प्रदान करता है। वे इस प्रकार हैं -

  • आधार नियंत्रक
  • टेम्पलेट नियंत्रक
  • बाकी नियंत्रक
  • हाइब्रिड नियंत्रक

आधार नियंत्रक

फ्यूलफेप में उपलब्ध सभी विभिन्न प्रकार के नियंत्रकों के लिए नियंत्रक आधार नियंत्रक है। यह वेब अनुरोध को संसाधित करने के लिए आवश्यक सभी बुनियादी कार्यात्मकता प्रदान करता है। यह अनुरोध, प्रतिक्रिया, सत्र, आदि का समर्थन करता है। हम इसका उपयोग सभी उदाहरणों में करेंगे जब तक कि अन्यथा निर्दिष्ट न हो।

टेम्पलेट नियंत्रक

एक टेम्पलेट नियंत्रक आधार नियंत्रक का एक विस्तार है। यह टेम्पलेट समर्थन है, पहले () और बाद में () तरीकों से पूर्वनिर्धारित। मूल रूप से, इसका उपयोग हेडर, फुटर, साइडबार आदि के साथ लेआउट में आपके दृश्य को लपेटने के लिए किया जा सकता है। टेम्प्लेट कंट्रोलर बनाने के लिए, हमें कंट्रोलरटेम्पलेट वर्ग का विस्तार करना होगा । डिफ़ॉल्ट रूप से, नियंत्रक_ Template को विस्तारित करने वाले वर्ग के सभी तरीकों को टेम्पलेट का उपयोग करने की आवश्यकता होती है।

इसे निम्नानुसार परिभाषित किया गया है।

class Controller_Employee extends Controller_Template { 
   public function action_index() { 
      // add methods 
   } 
}

हम दृश्य अध्याय में टेम्पलेट नियंत्रक के बारे में अधिक चर्चा करेंगे।

बाकी नियंत्रक

रेस्ट कंट्रोलर बेस कंट्रोलर का एक एक्सटेंशन है। इसमें REST API प्रोग्रामिंग के लिए पूर्व-निर्धारित समर्थन है। यह आपको आसानी से एपीआई बनाने की अनुमति देगा।

रेस्ट कंट्रोलर बनाने के लिए, आपको कंट्रोलर_रेस्ट क्लास का विस्तार करना होगा । इसे निम्नानुसार परिभाषित किया गया है।

class Controller_Employee extends Controller_Rest { 
   public function action_index() { 
      // add methods 
   } 
}

हम अजाक्स अध्याय में बाकी नियंत्रक के बारे में अधिक चर्चा करेंगे।

हाइब्रिड कंट्रोलर

हाइब्रिड कंट्रोलर एक बेस कंट्रोलर में REST कंट्रोलर और टेम्प्लेट कंट्रोलर दोनों की कार्यक्षमता को प्रदर्शित करता है।