CodeIgniter - मूल अवधारणाओं
नियंत्रकों
एक नियंत्रक एक साधारण वर्ग फ़ाइल है। जैसा कि नाम से पता चलता है, यह यूआरआई द्वारा पूरे एप्लिकेशन को नियंत्रित करता है।
एक नियंत्रक बनाना
सबसे पहले, पर जाएं application/controllersफ़ोल्डर। आपको वहां दो फाइलें मिलेंगी,index.html तथा Welcome.php। ये फाइलें CodeIgniter के साथ आती हैं।
इन फाइलों को वैसे ही रखें जैसे वे हैं। उसी पथ के तहत एक नई फ़ाइल बनाएं जिसका नाम “Test.php"। उस फ़ाइल में निम्नलिखित कोड लिखें -
<?php
class Test extends CI_Controller {
public function index() {
echo "Hello World!";
}
}
?>
Test कक्षा में निर्मित एक कक्षा का विस्तार होता है CI_Controller। जब भी आप अपना खुद का नियंत्रक वर्ग बनाना चाहते हैं, तो इस वर्ग को बढ़ाया जाना चाहिए।
एक नियंत्रक को फोन करना
उपर्युक्त नियंत्रक को URI द्वारा निम्नानुसार बुलाया जा सकता है -
http://www.your-domain.com/index.php/test
शब्द पर ध्यान दें ”test“Index.php के बाद उपरोक्त URI में। यह नियंत्रक के वर्ग नाम को इंगित करता है। जैसा कि हमने नियंत्रक का नाम दिया है “Test", हम लिख रहे हैं "testसूचकांक के बाद। वर्ग नाम के साथ शुरू होना चाहिएuppercase letter लेकिन हमें लिखने की जरूरत है lowercase letterजब हम URI द्वारा उस कंट्रोलर को कॉल करते हैं। कंट्रोलर को कॉल करने का सामान्य सिंटैक्स इस प्रकार है -
http://www.your-domain.com/index.php/controller/method-name
कंस्ट्रक्टर विधि बनाना और कॉल करना
आइए हम उपरोक्त वर्ग को संशोधित करें और एक अन्य विधि बनाएं जिसका नाम है "हैलो"।
<?php
class Test extends CI_Controller {
public function index() {
echo "This is default function.";
}
public function hello() {
echo "This is hello function.";
}
}
?>
हम उपरोक्त नियंत्रक को निम्नलिखित तीन तरीकों से निष्पादित कर सकते हैं -
- http://www.your-domain.com/index.php/test
- http://www.your-domain.com/index.php/test/index
- http://www.your-domain.com/index.php/test/hello
ब्राउज़र में पहले यूआरआई पर जाने के बाद, हमें आउटपुट मिलता है जैसा कि नीचे दी गई तस्वीर में दिखाया गया है। जैसा कि आप देख सकते हैं, हमें विधि का आउटपुट मिला "indexहालांकि, भले ही हमने यूआरआई के तरीके का नाम नहीं दिया है। हमने यूआरआई में केवल नियंत्रक नाम का उपयोग किया है। ऐसी स्थितियों में, CodeIgniter डिफ़ॉल्ट विधि को कॉल करता है ”index"।
ब्राउज़र में दूसरा यूआरआई देखने पर, हमें वही आउटपुट मिलता है जैसा कि ऊपर चित्र में दिखाया गया है। यहां, हमने URI में नियंत्रक के नाम के बाद विधि का नाम पारित किया है। जैसा कि विधि का नाम है "index“, हम एक ही आउटपुट प्राप्त कर रहे हैं।
ब्राउज़र में तीसरे यूआरआई को देखते हुए, हम आउटपुट प्राप्त करते हैं जैसा कि नीचे दी गई तस्वीर में दिखाया गया है। जैसा कि आप देख सकते हैं, हमें विधि का आउटपुट मिल रहा है ”hello"क्योंकि हम बीत चुके हैं"hello"विधि के नाम के रूप में, नियंत्रक के नाम के बाद"test“URI में।
याद दिलाने के संकेत
नियंत्रक वर्ग का नाम अपरकेस अक्षर से शुरू होना चाहिए।
नियंत्रक को लोअरकेस अक्षर के साथ बुलाया जाना चाहिए।
अपने मूल वर्ग के रूप में विधि के उसी नाम का उपयोग न करें, क्योंकि यह मूल वर्ग की कार्यक्षमता को ओवरराइड करेगा।
दृश्य
यह एक सरल या जटिल वेबपेज हो सकता है, जिसे नियंत्रक द्वारा बुलाया जा सकता है। वेबपेज में हेडर, फुटर, साइडबार आदि हो सकते हैं। दृश्य को सीधे नहीं बुलाया जा सकता है। आइए हम एक सरल दृश्य बनाते हैं। के तहत एक नई फ़ाइल बनाएँapplication/views नाम के साथ "test.php"और उस फ़ाइल में नीचे दिए गए कोड को कॉपी करें।
<!DOCTYPE html>
<html lang = "en">
<head>
<meta charset = "utf-8">
<title>CodeIgniter View Example</title>
</head>
<body>
CodeIgniter View Example
</body>
</html>
का कोड बदलें application/controllers/test.php फ़ाइल के रूप में नीचे दिखाया गया है।
दृश्य लोड हो रहा है
दृश्य को निम्नलिखित सिंटैक्स द्वारा लोड किया जा सकता है -
$this->load->view('name');
जहां नाम दृश्य फ़ाइल है, जिसका प्रतिपादन किया जा रहा है। यदि आपने कुछ निर्देशिका में दृश्य फ़ाइल संग्रहीत करने की योजना बनाई है, तो आप निम्न सिंटैक्स का उपयोग कर सकते हैं -
$this->load->view('directory-name/name');
एक्सटेंशन को php के रूप में निर्दिष्ट करना आवश्यक नहीं है, जब तक कि .php के अलावा किसी अन्य चीज का उपयोग नहीं किया जाता है।
अनुक्रमणिका () विधि दृश्य विधि को बुला रही है और "परीक्षण" को तर्क के रूप में देखने के लिए पारित कर रही है () विधि क्योंकि हमने html कोडिंग को "" में संग्रहीत किया हैtest.phpके तहत फाइल करें application/views/test.php।
<?php
class Test extends CI_Controller {
public function index() {
$this->load->view('test');
}
}
?>
यहाँ उपरोक्त कोड का उत्पादन है -
निम्न फ़्लोचार्ट दिखाता है कि सब कुछ कैसे काम करता है -
मॉडल
मॉडल कक्षाओं को डेटाबेस में जानकारी के साथ काम करने के लिए डिज़ाइन किया गया है। एक उदाहरण के रूप में, यदि आप अपने एप्लिकेशन में उपयोगकर्ताओं को प्रबंधित करने के लिए CodeIgniter का उपयोग कर रहे हैं, तो आपके पास मॉडल वर्ग होना चाहिए, जिसमें आपके उपयोगकर्ताओं के डेटा को सम्मिलित करने, हटाने, अद्यतन करने और पुनर्प्राप्त करने के कार्य शामिल हैं।
मॉडल क्लास बनाना
मॉडल कक्षाओं में संग्रहीत हैं application/modelsनिर्देशिका। निम्नलिखित कोड दिखाता है कि CodeIgniter में मॉडल वर्ग कैसे बनाया जाए।
<?php
Class Model_name extends CI_Model {
Public function __construct() {
parent::__construct();
}
}
?>
जहां Model_name उस मॉडल वर्ग का नाम है जिसे आप देना चाहते हैं। प्रत्येक मॉडल वर्ग को CodeIgniter की CI_Model श्रेणी विरासत में मिलनी चाहिए। मॉडल क्लास का पहला अक्षर कैपिटल लेटर में होना चाहिए। उपयोगकर्ताओं के मॉडल वर्ग के लिए कोड निम्नलिखित है।
<?php
Class User_model extends CI_Model {
Public function __construct() {
parent::__construct();
}
}
?>
उपर्युक्त मॉडल वर्ग को User_model.php के रूप में सहेजा जाना चाहिए। कक्षा का नाम और फ़ाइल नाम समान होना चाहिए।
लोड हो रहा है मॉडल
मॉडल को नियंत्रक में कहा जा सकता है। किसी भी मॉडल को लोड करने के लिए निम्नलिखित कोड का उपयोग किया जा सकता है।
$this->load->model('model_name');
जहां model_name लोड होने वाले मॉडल का नाम है। मॉडल को लोड करने के बाद आप बस इसकी विधि को नीचे दिखाए अनुसार कह सकते हैं।
$this->model_name->method();
ऑटो-लोडिंग मॉडल
ऐसी स्थितियाँ हो सकती हैं जहाँ आप अपने पूरे आवेदन में कुछ मॉडल वर्ग चाहते हैं। ऐसी स्थितियों में, हम इसे ऑटोलॉग कर लें तो बेहतर है।
/*
| ---------------------------------------------------------------
| Auto-Load Models
| ---------------------------------------------------------------
| Prototype:
|
| $autoload['model'] = array('first_model', 'second_model');
|
| You can also supply an alternative model name to be assigned
| in the controller:
|
| $autoload['model'] = array('first_model' => 'first');
*/
$autoload['model'] = array();
जैसा कि ऊपर की आकृति में दिखाया गया है, उस मॉडल का नाम उस ऐरे में पास करें, जिसे आप ऑटोलैड करना चाहते हैं और यह ऑटोलॉइड होगा, जबकि सिस्टम इनिशियलाइज़ेशन स्थिति में है और पूरे एप्लिकेशन में पहुंच योग्य है।
सहायकों
जैसा कि नाम से पता चलता है, यह आपके सिस्टम को बनाने में मदद करेगा। विभिन्न कार्यक्षमता की सेवा के लिए इसे छोटे कार्यों में विभाजित किया गया है। CodeIgniter में कई हेल्पर्स उपलब्ध हैं, जो नीचे दी गई तालिका में सूचीबद्ध हैं। हम अपने स्वयं के सहायकों का भी निर्माण कर सकते हैं।
सहायकों को आम तौर पर आपके स्टोर में रखा जाता है system/helpers, या application/helpers directory। कस्टम हेल्पर्स को स्टोर किया जाता हैapplication/helpers निर्देशिका और सिस्टम के हेल्पर्स को स्टोर किया जाता है system/helpersनिर्देशिका। CodeIgniter आपके अंदर सबसे पहले दिखेगाapplication/helpers directory। यदि निर्देशिका मौजूद नहीं है या निर्दिष्ट सहायक स्थित नहीं है, तो CodeIgniter बजाय अपने वैश्विक में दिखेगाsystem/helpers/ directory। प्रत्येक सहायक, चाहे वह कस्टम या सिस्टम सहायक हो, उसे उपयोग करने से पहले लोड किया जाना चाहिए।
एस.एन. | हेल्पर का नाम और विवरण |
---|---|
1 | Array Helper ऐरे हेल्पर फ़ाइल में फ़ंक्शन होते हैं जो सरणियों के साथ काम करने में सहायता करते हैं। |
2 | CAPTCHA Helper कैप्चा हेल्पर फ़ाइल में फ़ंक्शंस होते हैं जो कैप्चा इमेज बनाने में सहायता करते हैं। |
3 | Cookie Helper कुकी हेल्पर फ़ाइल में ऐसे कार्य होते हैं जो कुकीज़ के साथ काम करने में सहायता करते हैं। |
4 | Date Helper दिनांक सहायक फ़ाइल में ऐसे कार्य होते हैं जो आपको दिनांक के साथ काम करने में सहायता करते हैं। |
5 | Directory Helper निर्देशिका हेल्पर फ़ाइल में ऐसे कार्य होते हैं जो निर्देशिकाओं के साथ काम करने में सहायता करते हैं। |
6 | Download Helper डाउनलोड हेल्पर आपको अपने डेस्कटॉप पर डेटा डाउनलोड करने देता है। |
7 | Email Helper ईमेल हेल्पर ईमेल के साथ काम करने के लिए कुछ सहायक कार्य प्रदान करता है। अधिक मजबूत ईमेल समाधान के लिए, CodeIgniter की ईमेल क्लास देखें। |
8 | File Helper फ़ाइल हेल्पर फ़ाइल में फ़ंक्शंस होते हैं जो फ़ाइलों के साथ काम करने में सहायता करते हैं। |
9 | Form Helper प्रपत्र हेल्पर फ़ाइल में फ़ंक्शंस होते हैं जो फ़ॉर्म के साथ काम करने में सहायता करते हैं। |
10 | HTML Helper HTML हेल्पर फ़ाइल में ऐसे कार्य होते हैं जो HTML के साथ काम करने में सहायता करते हैं। |
1 1 | Inflector Helper Inflector हेल्पर फ़ाइल में ऐसे फ़ंक्शंस होते हैं, जो आपको शब्दों को बहुवचन, एकवचन, ऊंट मामले आदि में बदलने की अनुमति देते हैं। |
12 | Language Helper लैंग्वेज हेल्पर फ़ाइल में ऐसे कार्य होते हैं जो भाषा फ़ाइलों के साथ काम करने में सहायता करते हैं। |
13 | Number Helper नंबर हेल्पर फ़ाइल में फ़ंक्शन होते हैं जो आपको संख्यात्मक डेटा के साथ काम करने में मदद करते हैं। |
14 | Path Helper पाथ हेल्पर फ़ाइल में फ़ंक्शंस होते हैं जो आपको सर्वर पर फ़ाइल पथों के साथ काम करने की अनुमति देता है। |
15 | Security Helper सुरक्षा हेल्पर फ़ाइल में सुरक्षा संबंधी कार्य होते हैं। |
16 | Smiley Helper स्माइली हेल्पर फ़ाइल में फ़ंक्शंस होते हैं जो आपको स्माइलीज़ (इमोटिकॉन्स) प्रबंधित करते हैं। |
17 | String Helper स्ट्रिंग हेल्पर फ़ाइल में ऐसे फ़ंक्शन होते हैं जो स्ट्रिंग्स के साथ काम करने में सहायता करते हैं। |
18 | Text Helper टेक्स्ट हेल्पर फ़ाइल में फ़ंक्शंस होते हैं जो टेक्स्ट के साथ काम करने में सहायता करते हैं। |
19 | Typography Helper टाइपोग्राफी हेल्पर फ़ाइल में ऐसे कार्य होते हैं जो आपके प्रारूप पाठ को शब्दार्थ रूप से प्रासंगिक तरीकों से मदद करते हैं। |
20 | URL Helper URL हेल्पर फ़ाइल में ऐसे फ़ंक्शंस होते हैं जो URL के साथ काम करने में सहायता करते हैं। |
21 | XML Helper XML हेल्पर फ़ाइल में ऐसे फ़ंक्शन होते हैं जो XML डेटा के साथ काम करने में सहायता करते हैं। |
एक हेल्पर लोड हो रहा है
एक सहायक को नीचे दिखाए अनुसार लोड किया जा सकता है -
$this->load->helper('name');
जहां नाम सहायक का नाम है। उदाहरण के लिए, यदि आप URL हेल्पर को लोड करना चाहते हैं, तो इसे इस प्रकार लोड किया जा सकता है -
$this->load->helper('url');
मार्ग
CodeIgniter में उपयोगकर्ता के अनुकूल URI रूटिंग सिस्टम है, जिससे आप आसानी से URL को फिर से रूट कर सकते हैं। आमतौर पर, URL स्ट्रिंग और इसके संबंधित नियंत्रक वर्ग / विधि के बीच एक-से-एक संबंध होता है। URI के सेगमेंट आमतौर पर इस पैटर्न का अनुसरण करते हैं -
your-domain.com/class/method/id/
first segment नियंत्रक वर्ग का प्रतिनिधित्व करता है जिसे लागू किया जाना चाहिए।
second segment वर्ग फ़ंक्शन या विधि का प्रतिनिधित्व करता है, जिसे बुलाया जाना चाहिए।
third, और कोई भी अतिरिक्त खंड, आईडी और किसी भी चर का प्रतिनिधित्व करता है जो नियंत्रक को दिया जाएगा।
कुछ स्थितियों में, आप इस डिफ़ॉल्ट रूटिंग तंत्र को बदलना चाह सकते हैं। CodeIgniter सुविधा प्रदान करता है जिसके द्वारा आप अपने रूटिंग नियम निर्धारित कर सकते हैं।
रूटिंग नियमों को अनुकूलित करें
एक विशेष फ़ाइल है जहाँ आप इन सभी को संभाल सकते हैं। फ़ाइल एप्लिकेशन / कॉन्फ़िग / मार्गों पर स्थित है। आपको $ रूट नामक एक सरणी मिलेगी जिसमें आप अपने रूटिंग नियमों को अनुकूलित कर सकते हैं। $ रूट एरे में कुंजी तय करेगी कि रूट को क्या करना है और वैल्यू तय करेगी कि रूट कहां करना है। CodeIgniter में तीन आरक्षित मार्ग हैं।
एस.एन. | आरक्षित मार्ग और विवरण |
---|---|
1 | $route['default_controller'] यह मार्ग इंगित करता है कि किस नियंत्रक वर्ग को लोड किया जाना चाहिए, यदि यूआरआई में कोई डेटा नहीं है, जो तब होगा जब लोग आपके रूट URL को लोड करेंगे। आपको डिफ़ॉल्ट मार्ग के लिए प्रोत्साहित किया जाता है अन्यथा एक 404 पृष्ठ डिफ़ॉल्ट रूप से दिखाई देगा। हम यहां वेबसाइट का होम पेज सेट कर सकते हैं, इसलिए इसे डिफ़ॉल्ट रूप से लोड किया जाएगा। |
2 | $route['404_override'] यह मार्ग इंगित करता है कि कौन सा नियंत्रक वर्ग लोड किया जाना चाहिए यदि अनुरोधित नियंत्रक नहीं मिला है। यह डिफ़ॉल्ट 404 त्रुटि पृष्ठ को ओवरराइड करेगा। इसका कोई असर नहीं होगाshow_404() फ़ंक्शन, जो डिफ़ॉल्ट लोड करना जारी रखेगा error_404.php में फाइल application/views/errors/error_404.php। |
3 | $route['translate_uri_dashes'] जैसा कि बूलियन मूल्य से स्पष्ट है, यह बिल्कुल एक मार्ग नहीं है। यह विकल्प आपको नियंत्रक और विधि URI खंडों में अंडरस्कोर के साथ स्वचालित रूप से डैश ('-') को बदलने में सक्षम बनाता है, इस प्रकार आपको अतिरिक्त रूट प्रविष्टियों को सहेजना पड़ता है यदि आपको ऐसा करने की आवश्यकता है। यह आवश्यक है क्योंकि डैश एक मान्य वर्ग या विधि-नाम वर्ण नहीं है और यदि आप इसका उपयोग करने का प्रयास करते हैं, तो एक घातक त्रुटि होगी। |
मार्गों द्वारा अनुकूलित किया जा सकता है wildcards या उपयोग करके regular expressions लेकिन ध्यान रखें कि रूटिंग के लिए ये अनुकूलित नियम आरक्षित नियमों के बाद आने चाहिए।
वाइल्डकार्ड
हम नीचे बताए अनुसार दो वाइल्डकार्ड वर्णों का उपयोग कर सकते हैं -
(:num) - यह एक सेगमेंट से मेल खाएगा जिसमें केवल नंबर होंगे।
(:any) - यह किसी भी पात्र वाले सेगमेंट से मेल खाएगा।
Example
$route['product/:num']='catalog/product_lookup';
उपरोक्त उदाहरण में, यदि URL के पहले खंड में शाब्दिक शब्द "उत्पाद" पाया जाता है, और दूसरे खंड में एक संख्या पाई जाती है, तो "कैटलॉग" वर्ग और "उत्पाद_दृश्य" विधि का उपयोग किया जाता है।
नियमित अभिव्यक्ति
वाइल्डकार्ड की तरह, हम नियमित अभिव्यक्तियों का भी उपयोग कर सकते हैं $route array keyअंश। यदि कोई भी यूआरआई नियमित अभिव्यक्ति के साथ मेल खाता है, तो इसे $ मार्ग सरणी में सेट किए गए मान भाग पर भेजा जाएगा।
Example
$route['products/([a-z]+)/(\d+)']='$1/id_$2';
उपरोक्त उदाहरण में, उत्पादों / जूतों / 123 के समान एक यूआरआई इसके बजाय "कॉल" करेगाshoes"नियंत्रक वर्ग और"id_123" तरीका।