CakePHP - त्वरित गाइड

CakePHP एक खुला स्रोत MVC फ्रेमवर्क है। यह अनुप्रयोगों के विकास, तैनाती और रखरखाव को बहुत आसान बनाता है। CakePHP में अधिकांश सामान्य कार्यों के अधिभार को कम करने के लिए कई पुस्तकालय हैं।

CakePHP के लाभ

CakePHP का उपयोग करने के फायदे नीचे सूचीबद्ध हैं -

  • खुला स्त्रोत

  • MVC फ्रेमवर्क

  • अस्थायी इंजन

  • कैशिंग संचालन

  • खोज इंजन के अनुकूल URL

  • आसान CRUD (बनाएँ, पढ़ें, अपडेट, हटाएं) डेटाबेस इंटरैक्शन।

  • पुस्तकालय और सहायक

  • अंतर्निहित मान्यता

  • Localisation

  • ईमेल, कुकी, सुरक्षा, सत्र और अनुरोध हैंडलिंग घटक

  • AJAX, जावास्क्रिप्ट, HTML फ़ॉर्म और अधिक के लिए सहायक देखें

CakePHP अनुरोध चक्र

निम्नलिखित दृष्टांत बताता है कि CakePHP में एक अनुरोध जीवनचक्र कैसे काम करता है -

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

  • वेबसर्वर नियम फिर से निर्देशित करने के लिए अनुरोध webroot / index.php।

  • आपके एप्लिकेशन के ऑटोलैडर और बूटस्ट्रैप फ़ाइलों को निष्पादित किया जाता है।

  • कोई भी dispatch filters जो कॉन्फ़िगर किए गए हैं वे अनुरोध को संभाल सकते हैं, और वैकल्पिक रूप से एक प्रतिक्रिया उत्पन्न कर सकते हैं।

  • डिस्पैचर रूटिंग नियमों के आधार पर उपयुक्त नियंत्रक और कार्रवाई का चयन करता है।

  • नियंत्रक की कार्रवाई को कहा जाता है और नियंत्रक आवश्यक मॉडल और घटकों के साथ बातचीत करता है।

  • नियंत्रक प्रतिक्रिया निर्माण को दर्शाता है View मॉडल डेटा से उत्पन्न आउटपुट उत्पन्न करने के लिए।

  • दृश्य का उपयोग करता है Helpers तथा Cells प्रतिक्रिया शरीर और हेडर उत्पन्न करने के लिए।

  • प्रतिक्रिया क्लाइंट को वापस भेज दी जाती है।

इस अध्याय में, हम CakePHP 4.0.3 की स्थापना दिखाएंगे। न्यूनतम PHP संस्करण जिसे हमें स्थापित करने की आवश्यकता हैPHP 7.3

CakePHP की स्थापना शुरू करने से पहले आपके पास PHP 7.3 और संगीतकार होना आवश्यक है।

के लिये Windows उपयोगकर्ता, PHP संस्करण> 7.3 के साथ WAMP सर्वर को स्थापित या अपडेट करते हैं।

Www.wampserver.com/en/download-wampserver-64bits/ पर जाएं और इसे इंस्टॉल करें।

लिनक्स उपयोगकर्ताओं के लिए, कृपया PHPs की स्थापना के लिए www.tutorialspoint.com/php7/php7_installation_linux.htm पर उपलब्ध ट्यूटोरियल प्वाइंट वेबसाइट देखें ।

कम्पोजर स्थापित करना

संगीतकार पर जाएं https://getcomposer.org/download/और अपने कंप्यूटर के ऑपरेटिंग सिस्टम (OS) के अनुसार डाउनलोड पर क्लिक करें और अपने सिस्टम पर कंपोज़र इंस्टॉल करें। Windows उपयोगकर्ताओं के लिए PATH चर में स्थान जोड़ें, ताकि आप किसी भी निर्देशिका से संगीतकार का उपयोग कर सकें।

एक बार जब आप कंपोज़र इंस्टॉल कर रहे हों, तो अब केकपीएचपी इंस्टॉल करना शुरू करते हैं।

CakePHP स्थापित करना

उस फ़ोल्डर पर जाएं जहां wamp विंडोज़ उपयोगकर्ताओं के लिए और www / फ़ोल्डर में स्थित है, एक फ़ोल्डर बनाएं cakephp4/.

लिनक्स उपयोगकर्ताओं के लिए, फ़ोल्डर बनाएँ var/www/html/ और फिर फ़ोल्डर बनाएँ cakephp4/

  • cakephp4 / वह फ़ोल्डर है जहां हम CakePHP स्थापित करने जा रहे हैं।

निम्नलिखित कमांड निष्पादित करने के लिए संगीतकार का उपयोग करें -

composer create-project --prefer-dist cakephp/app:4.0.3 cakephp4

यह वही है जो आपको देखना चाहिए, जब कमांड निष्पादित होता है -

एक बार इंस्टॉलेशन पूरा हो जाने के बाद, ब्राउज़र में अपना प्रोजेक्ट खोलने के लिए लोकलहोस्ट का उपयोग करें।

उसी के लिए पथ http: // localhost / cakephp है।

यहां, हम CakePHP में फ़ोल्डर संरचना और नामकरण कन्वेंशन के बारे में जानेंगे। फ़ोल्डर संरचना को समझने के द्वारा शुरू करते हैं।

फ़ोल्डर संरचना

निम्नलिखित स्क्रीनशॉट पर एक नज़र डालें। यह CakePHP की फ़ोल्डर संरचना को दर्शाता है।

निम्न तालिका CakePHP में प्रत्येक फ़ोल्डर की भूमिका का वर्णन करती है -

अनु क्रमांक फ़ोल्डर का नाम और विवरण
1

bin

bin फ़ोल्डर केक कंसोल निष्पादन योग्य रखता है।

2

config

configफ़ोल्डर (कुछ) विन्यास फाइल CakePHP का उपयोग करता है। डेटाबेस कनेक्शन विवरण, बूटस्ट्रैपिंग, कोर कॉन्फ़िगरेशन फाइलें और बहुत कुछ यहां संग्रहीत किया जाना चाहिए।

3

logs

logs फ़ोल्डर में सामान्य रूप से आपकी लॉग फ़ाइलें होती हैं, जो आपके लॉग कॉन्फ़िगरेशन के आधार पर होती है।

4

plugins

प्लगइन्स फ़ोल्डर वह जगह है जहां आपके एप्लिकेशन उपयोग के प्लगइन्स संग्रहीत हैं।

5

resources

संबंधित स्थानीय फ़ोल्डर में अंतर्राष्ट्रीयकरण के लिए फ़ाइलें यहां संग्रहीत की जाएंगी। जैसे स्थान / en_US।

6

src

srcफ़ोल्डर वह जगह होगी जहाँ आप अपना जादू चलाते हैं। यह वह जगह है जहां आपके एप्लिकेशन की फाइलें रखी जाएंगी और आप अपने अधिकांश एप्लिकेशन डेवलपमेंट करेंगे। आइए src के अंदर फ़ोल्डरों पर थोड़ा करीब से देखें।

  • कंसोल - आपके एप्लिकेशन के लिए कंसोल कमांड और कंसोल कार्यों को समाहित करता है।

  • नियंत्रक - आपके एप्लिकेशन के नियंत्रकों और उनके घटकों को शामिल करता है।

  • मॉडल - आपके आवेदन की तालिकाओं, संस्थाओं और व्यवहारों को समाहित करता है।

  • प्रेजेंटेशनल कक्षाएं यहां रखी गई हैं: सेल, हेल्पर्स और टेम्प्लेट फाइलें।

7

templates

टेम्प्लेट प्रस्तुति फ़ाइलें यहाँ रखी गई हैं: तत्व, त्रुटि पृष्ठ, लेआउट, और टेम्पलेट फ़ाइलें।

8

tests

tests फ़ोल्डर वह होगा जहां आप अपने आवेदन के लिए परीक्षण के मामले डालते हैं।

9

tmp

tmpफ़ोल्डर है जहाँ CakePHP अस्थायी डेटा संग्रहीत करता है। आपके द्वारा संग्रहीत किए गए वास्तविक डेटा पर निर्भर करता है कि आपने CakePHP को कैसे कॉन्फ़िगर किया है, लेकिन यह फ़ोल्डर आमतौर पर मॉडल विवरण और कभी-कभी सत्र जानकारी संग्रहीत करने के लिए उपयोग किया जाता है।

10

vendor

vendorफ़ोल्डर जहां CakePHP और अन्य अनुप्रयोग निर्भरताएं स्थापित की जाएंगी। इस फ़ोल्डर में फ़ाइलों को संपादित नहीं करने के लिए एक व्यक्तिगत प्रतिबद्धता बनाएं। यदि आपने कोर को संशोधित किया है तो हम आपकी मदद नहीं कर सकते।

1 1

webroot

webrootनिर्देशिका आपके आवेदन का सार्वजनिक दस्तावेज़ रूट है। इसमें वे सभी फाइलें शामिल हैं, जिन्हें आप पारंपरिक रूप से उपलब्ध होना चाहते हैं।

नामकरण परंपरा

नामकरण सम्मेलन का पालन किया जाना अनिवार्य नहीं है, लेकिन एक अच्छा कोडिंग अभ्यास है और यह बहुत उपयोगी होगा क्योंकि आपकी परियोजना बड़ी हो जाएगी।

नियंत्रक सम्मेलन

नियंत्रक वर्ग का नाम बहुवचन, PascalCased होना चाहिए और नाम को नियंत्रक के साथ समाप्त करना होगा। उदाहरण के लिए, छात्र वर्ग के लिए नियंत्रक का नाम हो सकता हैStudentsController। नियंत्रकों पर सार्वजनिक तरीकों को अक्सर वेब ब्राउज़र के माध्यम से सुलभ 'कार्यों' के रूप में उजागर किया जाता है।

उदाहरण के लिए, / उपयोगकर्ताओं / नक्शे को देखने के लिए view()बॉक्स से बाहर UsersController की विधि। राउटिंग के साथ संरक्षित या निजी तरीकों को एक्सेस नहीं किया जा सकता है।

फ़ाइल और कक्षा नाम कन्वेंशन

अधिकतर, हमने देखा है कि हमारी कक्षा का नाम फ़ाइल का नाम लगभग समान है। यह केकफप में समान है।

उदाहरण के लिए, क्लास स्टूडेंट्सकंट्रोलर में स्टूडेंट्सकंट्रोलर.फपी नाम की फाइल होगी। फ़ाइलों को मॉड्यूल नाम और ऐप फ़ोल्डर में संबंधित फ़ोल्डर में सहेजा जाना है।

डेटाबेस कन्वेंशन

CakePHP मॉडल के लिए उपयोग की जाने वाली तालिकाओं में ज्यादातर अंडरस्कोर के साथ बहुवचन नाम होते हैं।

उदाहरण के लिए, student_details, student_mark। फ़ील्ड नाम में एक अंडरस्कोर है, अगर यह दो शब्दों से बना है, उदाहरण के लिए, first_name, last_name।

मॉडल कन्वेंशन

मॉडल के लिए, कक्षाओं को डेटाबेस तालिका के अनुसार नाम दिया गया है, नाम बहुवचन, पास्कल्डेड और टेबल के साथ प्रत्यय हैं।

उदाहरण के लिए, StudentDetailsTable, StudentMarksTable

सम्मेलनों को देखें

व्यू टेम्प्लेट के लिए, फाइलें नियंत्रक कार्यों पर आधारित होती हैं।

उदाहरण के लिए, यदि क्लास स्टूडेंटडेलेट्सकंट्रोलर के पास शो शोऑल () है, तो व्यू टेम्प्लेट को शो_ऑल.फैप के रूप में नामित किया जाएगा और टेम्प्लेट / यारमोडुले / शो_ऑल.फैप के अंदर बचाया जाएगा।

इस अध्याय में, हम समझेंगे Environment Variables, General Configuration, Database Configuration तथा Email Configuration केकपीएचपी में।

ConfigurationCakePHP डिफ़ॉल्ट रूप से एक कॉन्फ़िगरेशन फ़ाइल के साथ आता है, और हम इसे अपनी आवश्यकताओं के अनुसार संशोधित कर सकते हैं। एक समर्पित फ़ोल्डर है“config”इस काम के लिए। CakePHP विभिन्न विन्यास विकल्पों के साथ आता है।

चलिए CakePHP में पर्यावरण चर को समझने के द्वारा शुरू करते हैं।

पर्यावरण चर

पर्यावरण चर विभिन्न वातावरणों पर आपके एप्लिकेशन के काम को आसान बनाते हैं। उदाहरण के लिए, देव सर्वर, परीक्षण सर्वर, मंचन सर्वर और उत्पादन सर्वर वातावरण पर। इन सभी वातावरणों के लिए, आप इसका उपयोग कर सकते हैंenv() function आपके द्वारा आवश्यक पर्यावरण के लिए कॉन्फ़िगरेशन को पढ़ने और अपने एप्लिकेशन का निर्माण करने के लिए।

आपके कॉन्फ़िगरेशन फ़ोल्डर में, आप config / .env.example भर में आएंगे। इस फ़ाइल में सभी चर हैं जो आपके वातावरण के आधार पर बदले जाएंगे। इसके साथ शुरू करने के लिए, आप विन्यास फ़ोल्डर में फाइल बना सकते हैं। config / .env और उन चरों को परिभाषित करके उनका उपयोग कर सकते हैं। यदि आपको किसी अतिरिक्त चर की आवश्यकता होती है, तो यह उस फ़ाइल में जा सकता है।

आप अपने पर्यावरण चर को एन्वा () फ़ंक्शन के रूप में नीचे दिखाए अनुसार पढ़ सकते हैं -

उदाहरण

$debug = env('APP_DEBUG', false);

पहला एक पर्यावरण चर का नाम है जिसे आप चाहते हैं और दूसरा मान डिफ़ॉल्ट मान है। डिफ़ॉल्ट मान का उपयोग किया जाता है, अगर पर्यावरण चर के लिए कोई मूल्य नहीं मिला है।

सामान्य विन्यास

निम्न तालिका विभिन्न चर की भूमिका का वर्णन करती है और वे आपके CakePHP अनुप्रयोग को कैसे प्रभावित करती हैं।

अनु क्रमांक परिवर्तनीय नाम और विवरण
1

debug

केकपीएचपी डिबगिंग आउटपुट में परिवर्तन।

false= उत्पादन मोड। कोई त्रुटि संदेश, त्रुटियां, या चेतावनी नहीं दिखाई गई हैं।

true = त्रुटियों और चेतावनियों को दिखाया।

2

App.namespace

के तहत एप्लिकेशन कक्षाओं को खोजने के लिए नामस्थान।

3

App.baseUrl

यदि आप Apache की mod_rewrite CakePHP के साथ उपयोग करने की योजना नहीं बनाते हैं, तो इस परिभाषा को अन-कमेंट करें। अपनी .htaccess फ़ाइलों को भी निकालना न भूलें।

4

App.base

आधार निर्देशिका ऐप में रहता है। यदि गलत है, तो यह ऑटो का पता लगाया जाएगा।

5

App.encoding

परिभाषित करें कि आपके एप्लिकेशन का उपयोग करने वाले एन्कोडिंग क्या हैं। इस एन्कोडिंग का उपयोग लेआउट में चारसेट बनाने के लिए किया जाता है, और संस्थाओं को एनकोड किया जाता है। यह आपके डेटाबेस के लिए निर्दिष्ट एन्कोडिंग मूल्यों से मेल खाना चाहिए।

6

App.webroot

Webroot निर्देशिका।

7

App.wwwRoot

Webroot के लिए फ़ाइल पथ।

8

App.fullBaseUrl

आपके आवेदन की जड़ में पूरी तरह से योग्य डोमेन नाम (प्रोटोकॉल सहित)।

9

App.imageBaseUrl

वेबरूट के तहत सार्वजनिक छवियों निर्देशिका के लिए वेब पथ।

10

App.cssBaseUrl

Webroot के तहत सार्वजनिक css निर्देशिका में वेब पथ।

1 1

App.jsBaseUrl

Webroot के तहत जनता के लिए js डायरेक्टरी का वेब पथ।

12

App.paths

गैर-वर्ग आधारित संसाधनों के लिए पथ कॉन्फ़िगर करें। का समर्थन करता हैplugins, templates, locales, subkeys, जो क्रमशः प्लगइन्स, व्यू टेम्प्लेट और लोकेल फ़ाइलों के लिए पथ की परिभाषा की अनुमति देते हैं।

13

Security.salt

हैशिंग में प्रयुक्त एक यादृच्छिक स्ट्रिंग। सममित एन्क्रिप्शन करते समय इस मान का उपयोग HMAC नमक के रूप में भी किया जाता है।

14

Asset.timestamp

एक टाइमस्टैम्प को लागू करता है, जो उचित सहायकों का उपयोग करते समय संपत्ति फाइलों के URL (CSS, जावास्क्रिप्ट, छवि) के अंत में विशेष रूप से संशोधित समय होता है। मान्य मूल्य हैं -

  • (बूल) झूठा - कुछ भी नहीं करना (डिफ़ॉल्ट)।

  • (बूल) सही - टाइमस्टैम्प को लागू करता है, जब डिबग सच होता है।

  • (स्ट्रिंग) 'बल' - हमेशा टाइमस्टैम्प को जोड़ता है।

डेटाबेस कॉन्फ़िगरेशन

डेटाबेस में कॉन्फ़िगर किया जा सकता है config/app.php and config/app_local.phpफ़ाइल। इस फ़ाइल में प्रदान किए गए मापदंडों के साथ एक डिफ़ॉल्ट कनेक्शन है, जिसे हमारी पसंद के अनुसार संशोधित किया जा सकता है।

नीचे दिए गए स्निपेट डिफ़ॉल्ट मापदंडों और मूल्यों को दर्शाते हैं, जिन्हें आवश्यकता के अनुसार संशोधित किया जाना चाहिए।

Config / app_local.php

*/
   'Datasources' => [
      'default' => [
         'host' => 'localhost',
         'username' => 'my_app',
         'password' => 'secret',
         'database' => 'my_app',
         'url' => env('DATABASE_URL', null),
      ],
      /*
         * The test connection is used during the test suite.
      */
      'test' => [
         'host' => 'localhost',
         //'port' => 'non_standard_port_number',
         'username' => 'my_app',
         'password' => 'secret',
         'database' => 'test_myapp',
         //'schema' => 'myapp',
      ],
   ],

आइए हम प्रत्येक पैरामीटर को विस्तार से समझते हैं config/app_local.php

मेज़बान

डेटाबेस सर्वर के होस्टनाम (या आईपी पते)।

उपयोगकर्ता नाम

डेटाबेस उपयोगकर्ता नाम

कुंजिका

डेटाबेस पासवर्ड।

डेटाबेस

डेटाबेस का नाम।

बंदरगाह

टीसीपी पोर्ट या यूनिक्स सॉकेट सर्वर से कनेक्ट करने के लिए उपयोग किया जाता है।

config / app.php

'Datasources' => [
   'default' => [
      'className' => Connection::class,
      'driver' => Mysql::class,
      'persistent' => false,
      'timezone' => 'UTC',
      //'encoding' => 'utf8mb4',
      'flags' => [],
      'cacheMetadata' => true,
      'log' => false,
      'quoteIdentifiers' => false,
      //'init' => ['SET GLOBAL innodb_stats_on_metadata = 0'],
   ],
]

आइए हम प्रत्येक पैरामीटर को विस्तार से समझते हैं config/app.php

लॉग
अनु क्रमांक कुंजी और विवरण
1

className

वर्ग का पूरी तरह से नामांकित वर्ग नाम जो एक डेटाबेस सर्वर से कनेक्शन का प्रतिनिधित्व करता है। यह वर्ग डेटाबेस ड्राइवर को लोड करने, SQL लेनदेन तंत्र प्रदान करने और अन्य बातों के बीच SQL कथन तैयार करने के लिए जिम्मेदार है।

2

driver

चालक का वर्ग नाम डेटाबेस इंजन के लिए सभी विशिष्टताओं को लागू करने के लिए उपयोग किया जाता है। यह प्लगइन सिंटैक्स, पूरी तरह से नामांकित नाम, या एक निर्मित ड्राइवर उदाहरण का उपयोग करके या तो एक छोटा वर्गनाम हो सकता है। लघु वर्गनाम के उदाहरण हैं मैसकल, स्क्लाइट, पोस्टग्रेज और स्क्लसेवर।

3

persistent

डेटाबेस के लिए एक स्थायी कनेक्शन का उपयोग करें या नहीं।

4

encoding

SQL कथन को 'utf8' आदि जैसे सर्वर पर भेजते समय उपयोग किए गए वर्ण को इंगित करता है।

5

timezone

सर्वर timezone सेट करने के लिए।

6

init

उन क्वेरीज़ की एक सूची, जिन्हें कनेक्शन बनाते समय डेटाबेस सर्वर को भेजा जाना चाहिए।

7

log

क्वेरी लॉगिंग को सक्षम करने के लिए सही पर सेट करें। जब सक्षम क्वेरीज़ को क्वेरी स्तर के साथ डीबग स्तर पर लॉग किया जाएगा।

8

quoteIdentifiers

सही पर सेट करें, यदि आप अपनी तालिका या स्तंभ नामों में आरक्षित शब्दों या विशेष वर्णों का उपयोग कर रहे हैं। इस सेटिंग को सक्षम करने से क्वेरी बिल्डर के उपयोग से निर्मित क्वेरीज़ का पता चलेगा, जिसमें SQL बनाते समय पहचानकर्ता को उद्धृत किया जाता है। यह प्रदर्शन को कम करता है।

9

flags

पीडीओ स्थिरांक का एक सहयोगी सरणी जिसे अंतर्निहित पीडीओ उदाहरण के लिए पारित किया जाना चाहिए।

10

cacheMetadata

मेटा डेटा को संग्रहीत करने के लिए या तो बूलियन सच, या कैश कॉन्फ़िगरेशन युक्त स्ट्रिंग में मेटाडेटा कैशिंग अक्षम होने की सलाह नहीं दी जाती है और इसके परिणामस्वरूप बहुत खराब प्रदर्शन हो सकता है।

ईमेल कॉन्फ़िगरेशन

ईमेल को फ़ाइल में कॉन्फ़िगर किया जा सकता है config/app.php। यह विन्यास / app.php में ईमेल विन्यास को परिभाषित करने के लिए आवश्यक नहीं है। इसके बिना ईमेल का उपयोग किया जा सकता है। सभी कॉन्फ़िगरेशन को अलग-अलग सेट करने के लिए संबंधित विधियों का उपयोग करें या कॉन्फ़िगरेशन की एक सरणी लोड करें। ईमेल डिफॉल्ट के लिए कॉन्फ़िगरेशन का उपयोग करके बनाया गया हैconfig() तथा configTransport()

ईमेल कॉन्फ़िगरेशन परिवहन

डिलीवरी प्रोफाइल से अलग ट्रांसपोर्ट को परिभाषित करके, आप आसानी से कई प्रोफाइल में ट्रांसपोर्ट कॉन्फ़िगरेशन को फिर से उपयोग कर सकते हैं। आप उत्पादन, विकास और परीक्षण के लिए कई कॉन्फ़िगरेशन निर्दिष्ट कर सकते हैं। प्रत्येक परिवहन को एक क्लासनाम की आवश्यकता होती है। मान्य विकल्प इस प्रकार हैं -

  • Mail - PHP मेल फ़ंक्शन का उपयोग करके भेजें

  • Smtp - SMTP का उपयोग करके भेजें

  • Debug - ईमेल न भेजें, बस परिणाम वापस करें

आप उपयुक्त फ़ाइल जोड़कर कस्टम ट्रांसपोर्ट (या मौजूदा ट्रांसपोर्ट को ओवरराइड कर सकते हैं) जोड़ सकते हैं src/Mailer/Transport। ट्रांसपोर्टेशन के नाम होने चाहिएYourTransport.php, कहाँ पे 'Your' परिवहन का नाम है।

ईमेल विन्यास परिवहन का उदाहरण निम्नलिखित है।

'EmailTransport' => [
   'default' => [
      'className' => 'Mail',
      // The following keys are used in SMTP transports
      'host' => 'localhost',
      'port' => 25,
      'timeout' => 30,
      'username' => 'user',
      'password' => 'secret',
      'client' => null,
      'tls' => null,
      'url' => env('EMAIL_TRANSPORT_DEFAULT_URL', null),
   ],
],

ईमेल डिलीवरी प्रोफाइल

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

निम्नलिखित ईमेल डिलीवरी प्रोफाइल का एक उदाहरण है।

'Email' => [
   'default' => [
   
      'transport' => 'default',
      'from' => 'you@localhost',
   ],
],

इस अध्याय में, हम रूटिंग से संबंधित निम्नलिखित विषयों को जानने जा रहे हैं -

  • रूटिंग का परिचय
  • कनेक्टिंग रूट
  • मार्गों के लिए तर्क पारित करना
  • पेशाब पैदा करना
  • पुन: निर्देशित करता है

रूटिंग का परिचय

इस अनुभाग में, हम देखेंगे कि आप मार्गों को कैसे कार्यान्वित कर सकते हैं, आप URL से नियंत्रक की कार्रवाई तक तर्क कैसे पारित कर सकते हैं, आप URL कैसे बना सकते हैं, और आप किसी विशिष्ट URL पर पुनर्निर्देशित कैसे कर सकते हैं। आम तौर पर, मार्गों को फ़ाइल में लागू किया जाता हैconfig/routes.php। रूटिंग को दो तरीकों से लागू किया जा सकता है -

  • स्थैतिक विधि
  • scoped मार्ग बिल्डर

यहाँ, दोनों प्रकारों को प्रस्तुत करने वाला एक उदाहरण है।

// Using the scoped route builder.
Router::scope('/', function ($routes) {
   $routes->connect('/', ['controller' => 'Articles', 'action' => 'index']);
});
// Using the static method.
Router::connect('/', ['controller' => 'Articles', 'action' => 'index']);

दोनों विधियों के सूचकांक विधि को निष्पादित करेगा ArticlesController। दो विधियों में से,scoped route builder बेहतर प्रदर्शन देता है।

कनेक्टिंग रूट

Router::connect()मार्गों को जोड़ने के लिए विधि का उपयोग किया जाता है। निम्नलिखित विधि का वाक्य विन्यास है -

static Cake\Routing\Router::connect($route, $defaults =[], $options =[])

के लिए तीन तर्क हैं Router::connect() विधि -

  • पहला तर्क उस URL टेम्पलेट के लिए है जिसे आप मिलान करना चाहते हैं।

  • दूसरे तर्क में आपके मार्ग तत्वों के लिए डिफ़ॉल्ट मान हैं।

  • तीसरे तर्क में मार्ग के लिए विकल्प हैं, जिसमें आम तौर पर नियमित अभिव्यक्ति नियम शामिल हैं।

यहाँ, एक मार्ग का मूल प्रारूप है -

$routes->connect(
   'URL template',
   ['default' => 'defaultValue'],
   ['option' => 'matchingRegex']
);

उदाहरण

में बदलाव करें config/routes.php फ़ाइल के रूप में नीचे दिखाया गया है।

config/routes.php

<?php
use Cake\Http\Middleware\CsrfProtectionMiddleware;
use Cake\Routing\Route\DashedRoute;
use Cake\Routing\RouteBuilder;
$routes->setRouteClass(DashedRoute::class);
$routes->scope('/', function (RouteBuilder $builder) {
   // Register scoped middleware for in scopes.
      $builder->registerMiddleware('csrf', new CsrfProtectionMiddleware([ 'httpOnly' => true, ])); $builder->applyMiddleware('csrf');
   $builder->connect('/', ['controller' => 'Tests', 'action' => 'show']); $builder->connect('/pages/*', ['controller' => 'Pages', 'action' => 'display']);
   $builder->fallbacks();
});

बनाओ TestsController.php पर फ़ाइल करें src/Controller/TestsController.php. नियंत्रक फ़ाइल में निम्न कोड की प्रतिलिपि बनाएँ।

src/Controller/TestsController.php

<?php
declare(strict_types=1);
namespace App\Controller;
use Cake\Core\Configure;
use Cake\Http\Exception\ForbiddenException;
use Cake\Http\Exception\NotFoundException;
use Cake\Http\Response;
use Cake\View\Exception\MissingTemplateException;
class TestsController extends AppController {
   public function show()
   {
   }
}

एक फ़ोल्डर बनाएँ Tests के अंतर्गत src/Template और उस फ़ोल्डर के तहत, एक बनाएँ View fileshow.php कहा जाता है। उस फ़ाइल में निम्न कोड कॉपी करें।

src/Template/Tests/show.php

<h1>This is CakePHP tutorial and this is an example of connecting routes.</h1>

निम्नलिखित उदाहरण पर जाएँ निम्नलिखित URL पर जाएँ जो http: // localhost / cakephp4 / पर उपलब्ध है

उत्पादन

उपरोक्त URL निम्न आउटपुट देगा।

तर्क पारित किया

पारित तर्क वे तर्क हैं जो URL में पारित किए जाते हैं। इन तर्कों को नियंत्रक की कार्रवाई के लिए पारित किया जा सकता है। ये पारित तर्क आपके नियंत्रक को तीन तरीकों से दिए गए हैं।

कार्रवाई विधि के तर्क के रूप में

निम्नलिखित उदाहरण से पता चलता है कि हम नियंत्रक की कार्रवाई के लिए तर्क कैसे पारित कर सकते हैं। निम्नलिखित URL पर जाएँ http: // localhost / cakephp4 / परीक्षण / value1 / value2

यह निम्नलिखित मार्ग रेखा से मेल खाएगा।

$builder->connect('tests/:arg1/:arg2', ['controller' => 'Tests', 'action' => 'show'],['pass' => ['arg1', 'arg2']]);

यहां, URL से मान 1 को आर्ग 1 को सौंपा जाएगा और मान 2 को आर्ग 2 को सौंपा जाएगा।

संख्यात्मक रूप से सरणी के रूप में

एक बार नियंत्रक की कार्रवाई पर तर्क पारित होने के बाद, आप निम्न कथन के साथ तर्क प्राप्त कर सकते हैं।

$args = $this->request->params[‘pass’]

नियंत्रक की कार्रवाई के लिए पारित तर्क $ args चर में संग्रहीत किया जाएगा।

रूटिंग सरणी का उपयोग करना

तर्क को निम्नलिखित कथन द्वारा कार्रवाई के लिए भी पारित किया जा सकता है -

$routes->connect('/', ['controller' => 'Tests', 'action' => 'show',5,6]);

उपरोक्त कथन टेस्टकंट्रोलर के शो () विधि में दो तर्क 5, और 6 पारित करेगा।

उदाहरण

में परिवर्तन करें config/routes.php निम्नलिखित कार्यक्रम में दिखाया गया है।

config/routes.php

<?php
use Cake\Http\Middleware\CsrfProtectionMiddleware;
use Cake\Routing\Route\DashedRoute;
use Cake\Routing\RouteBuilder;
$routes->setRouteClass(DashedRoute::class); $routes->scope('/', function (RouteBuilder $builder) { // Register scoped middleware for in scopes. $builder->registerMiddleware('csrf', new CsrfProtectionMiddleware([
      'httpOnly' => true,
   ]));
   $builder->applyMiddleware('csrf'); $builder->connect('tests/:arg1/:arg2', ['controller' => 'Tests', 'action' => 'show'],['pass' => ['arg1', 'arg2']]);
   $builder->connect('/pages/*', ['controller' => 'Pages', 'action' => 'display']); $builder->fallbacks();
});

बनाओ TestsController.php पर फ़ाइल करें src/Controller/TestsController.php. नियंत्रक फ़ाइल में निम्न कोड की प्रतिलिपि बनाएँ।

src/Controller/TestsController.php

<?php
declare(strict_types=1);
namespace App\Controller;
use Cake\Core\Configure;
use Cake\Http\Exception\ForbiddenException;
use Cake\Http\Exception\NotFoundException;
use Cake\Http\Response;
use Cake\View\Exception\MissingTemplateException;
class TestsController extends AppController {
public function show($arg1, $arg2) {
      $this->set('argument1',$arg1);
      $this->set('argument2',$arg2);
   }
}

एक फ़ोल्डर बनाएँ Tests पर src/Template और उस फ़ोल्डर के तहत एक बनाएँ Viewshow.php नामक फ़ाइल। उस फ़ाइल में निम्न कोड कॉपी करें।

src/Template/Tests/show.php.

<h1>This is CakePHP tutorial and this is an example of Passed arguments.</h1>
<?php
   echo "Argument-1:".$argument1."<br/>"; echo "Argument-2:".$argument2."<br/>";
?>

निम्नलिखित URL http: // localhost / cakephp4 / परीक्षण / विराट / कुणाल पर जाकर उपरोक्त उदाहरण देखें

उत्पादन

निष्पादन के बाद, उपरोक्त URL निम्न आउटपुट का उत्पादन करेगा।

जनरेटिंग यूआरएल

यह CakePHP की एक शांत विशेषता है। जनरेट किए गए URL का उपयोग करके, हम आसानी से पूरे कोड को संशोधित किए बिना एप्लिकेशन में URL की संरचना को बदल सकते हैं।

url( string|array|null $url null , boolean $full false )

उपरोक्त समारोह में दो तर्क होंगे -

  • पहला तर्क निम्नलिखित में से किसी को निर्दिष्ट करने वाला एक सरणी है - 'controller', 'action', 'plugin'। इसके अतिरिक्त, आप रूट किए गए तत्व या क्वेरी स्ट्रिंग पैरामीटर प्रदान कर सकते हैं। यदि स्ट्रिंग है, तो इसे किसी भी मान्य url स्ट्रिंग का नाम दिया जा सकता है।

  • यदि सही है, तो परिणाम के लिए पूर्ण आधार URL तैयार किया जाएगा। डिफ़ॉल्ट गलत है।

उदाहरण

में परिवर्तन करें config/routes.php निम्नलिखित कार्यक्रम में दिखाया गया है।

config/routes.php

<?php
use Cake\Http\Middleware\CsrfProtectionMiddleware;
use Cake\Routing\Route\DashedRoute;
use Cake\Routing\RouteBuilder;
$routes->setRouteClass(DashedRoute::class); $routes->scope('/', function (RouteBuilder $builder) { // Register scoped middleware for in scopes. $builder->registerMiddleware('csrf', new CsrfProtectionMiddleware([
      'httpOnly' => true,
   ]));
   $builder->applyMiddleware('csrf'); $builder->connect('/generate',['controller'=>'Generates','action'=>'show']);
   $builder->fallbacks();
});

बनाओ GeneratesController.php पर फ़ाइल करें src/Controller/GeneratesController.php. नियंत्रक फ़ाइल में निम्न कोड की प्रतिलिपि बनाएँ।

src/Controller/GeneratesController.php

<?php
declare(strict_types=1);
namespace App\Controller;
21
use Cake\Core\Configure;
use Cake\Http\Exception\ForbiddenException;
use Cake\Http\Exception\NotFoundException;
use Cake\Http\Response;
use Cake\View\Exception\MissingTemplateException;
class GeneratesController extends AppController {
   public function show()
   {
   }
}

एक फ़ोल्डर बनाएँ Generates at src/Template और उस फ़ोल्डर के तहत, एक बनाएँ Viewshow.php नामक फ़ाइल। उस फ़ाइल में निम्न कोड कॉपी करें।

src/Template/Generates/show.php

<h1>This is CakePHP tutorial and this is an example of Generating URLs<h1>

निम्न URL पर जाकर उपरोक्त उदाहरण देखें -

http: // localhost / cakephp4 / उत्पन्न

उत्पादन

उपरोक्त URL निम्न आउटपुट का उत्पादन करेगा -

अनुप्रेषित रूटिंग

रीडायरेक्ट रूटिंग उपयोगी है, जब हम क्लाइंट एप्लिकेशन को सूचित करना चाहते हैं कि, यह URL ले जाया गया है। निम्नलिखित फ़ंक्शन का उपयोग करके URL को पुनर्निर्देशित किया जा सकता है -

static Cake\Routing\Router::redirect($route, $url, $options =[])

उपरोक्त समारोह के तीन तर्क इस प्रकार हैं -

  • मार्ग का खाका बताने वाला एक तार।

  • URL को पुनर्निर्देशित करने के लिए।

  • मार्ग में नामित तत्वों को नियमित अभिव्यक्तियों से मिलान करने वाला एक सरणी जो उस तत्व से मेल खाना चाहिए।

उदाहरण

में परिवर्तन करें config/routes.phpफ़ाइल के रूप में नीचे दिखाया गया है। यहां, हमने उन नियंत्रकों का उपयोग किया है जो पहले बनाए गए थे।

config/routes.php

<?php
use Cake\Http\Middleware\CsrfProtectionMiddleware;
use Cake\Routing\Route\DashedRoute;
use Cake\Routing\RouteBuilder;
$routes->setRouteClass(DashedRoute::class); $routes->scope('/', function (RouteBuilder $builder) { // Register scoped middleware for in scopes. $builder->registerMiddleware('csrf', new CsrfProtectionMiddleware([
      'httpOnly' => true,
   ]));
   $builder->applyMiddleware('csrf'); $builder->connect('/generate',['controller'=>'Generates','action'=>'show']);
   $builder->redirect('/redirect','https://tutorialspoint.com/'); $builder->fallbacks();
});

निम्नलिखित URL पर जाकर उपरोक्त उदाहरण देखें।

URL 1 - http: // localhost / cakephp4 / generate

URL 1 के लिए आउटपुट

URL 2 - http: // localhost / cakephp4 / redirect

URL 2 के लिए आउटपुट

आपको https://tutorialspoint.com पर भेज दिया जाएगा

नाम के रूप में कंट्रोलर एप्लिकेशन को नियंत्रित करता है। यह मॉडल और विचारों के बीच एक पुल की तरह काम करता है। नियंत्रक अनुरोध डेटा को संभालते हैं, यह सुनिश्चित करते हैं कि सही मॉडल कहा जाता है और सही प्रतिक्रिया या दृश्य प्रदान किया जाता है।

नियंत्रकों के वर्ग में विधियों को कहा जाता है actions। प्रत्येक नियंत्रक नामकरण सम्मेलनों का अनुसरण करता है। नियंत्रक वर्ग के नाम बहुवचन रूप में हैं, कैमल कैसड, और नियंत्रक में अंत -PostsController

AppController

AppConttrollerवर्ग सभी अनुप्रयोगों के नियंत्रकों का मूल वर्ग है। यह वर्ग विस्तार करता हैControllerCakePHP की कक्षा। AppController पर परिभाषित किया गया हैsrc/Controller/AppController.php. फ़ाइल में निम्न कोड है।

<?php
declare(strict_types=1);
namespace App\Controller;
use Cake\Controller\Controller;
class AppController extends Controller {
   public function initialize(): void {
      parent::initialize();
      $this->loadComponent('RequestHandler'); $this->loadComponent('Flash');
   }
}

AppControllerउन घटकों को लोड करने के लिए उपयोग किया जा सकता है जो आपके एप्लिकेशन के प्रत्येक नियंत्रक में उपयोग किए जाएंगे। AppController में बनाई गई विशेषताएँ और विधियाँ इसे बढ़ाने वाले सभी नियंत्रकों में उपलब्ध होंगी। initialize() घटकों को लोड करने के लिए नियंत्रक के निर्माता के अंत में विधि लागू की जाएगी।

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

नियंत्रक वर्ग में विधियों को क्रिया कहा जाता है। ये क्रियाएं ब्राउज़र / उपयोगकर्ता से अनुरोध करने के लिए उचित प्रतिक्रिया भेजने के लिए जिम्मेदार हैं। दृश्य को कार्रवाई के नाम से प्रस्तुत किया जाता है, अर्थात, नियंत्रक में विधि का नाम।

उदाहरण

class RecipesController extends AppController {
   public function view($id) { // Action logic goes here. } public function share($customerId, $recipeId) { // Action logic goes here. } public function search($query) {
      // Action logic goes here.
   }
}

जैसा कि आप ऊपर के उदाहरण में देख सकते हैं, RecipesController 3 क्रियाएँ हैं - View, शेयर, और Search

पुन: निर्देशित

एक उपयोगकर्ता को उसी नियंत्रक की दूसरी कार्रवाई पर पुनर्निर्देशित करने के लिए, हम सेटएक्शन () विधि का उपयोग कर सकते हैं। सेटएशन () विधि के लिए निम्नलिखित सिंटैक्स है।

Cake\Controller\Controller::setAction($action, $args...)

निम्न कोड उपयोगकर्ता को उसी नियंत्रक की क्रिया को पुनः निर्देशित करेगा।

$this->setAction('index');

निम्न उदाहरण उपरोक्त विधि के उपयोग को दर्शाता है।

उदाहरण

में बदलाव करें config/routes.php निम्नलिखित कार्यक्रम में दिखाया गया है।

config/routes.php

<?php
use Cake\Http\Middleware\CsrfProtectionMiddleware;
use Cake\Routing\Route\DashedRoute;
use Cake\Routing\RouteBuilder;
$routes->setRouteClass(DashedRoute::class);
$routes->scope('/', function (RouteBuilder $builder) {
   // Register scoped middleware for in scopes.
   $builder->registerMiddleware('csrf', new CsrfProtectionMiddleware([ 'httpOnly' => true, ])); $builder->applyMiddleware('csrf'); 
   $builder->connect('/redirect-controller',['controller'=>'Redirects','action'=>'action1']); $builder->connect('/redirect-controller2',['controller'=>'Redirects','action'=>'action2']);
   $builder->fallbacks();
});

बनाओ RedirectsController.phpsrc / Controller / RedirectsController.php पर फ़ाइल। नियंत्रक फ़ाइल में निम्न कोड की प्रतिलिपि बनाएँ।

src/Controller/RedirectsController.php

<?php
declare(strict_types=1);
namespace App\Controller;
use Cake\Core\Configure;
use Cake\Http\Exception\ForbiddenException;
use Cake\Http\Exception\NotFoundException;
use Cake\Http\Response;
use Cake\View\Exception\MissingTemplateException;
class RedirectsController extends AppController {
   public function action1() {
   }
   public function action2(){
      echo "redirecting from action2";
      $this->setAction('action1');
   }
}

एक निर्देशिका बनाएँ Redirects पर src/Template और उस निर्देशिका के तहत एक बनाएँ Viewएक्शन 1.php नामक फाइल। उस फ़ाइल में निम्न कोड कॉपी करें।

src/Template/Redirects/action1.php

<h1>This is an example of how to redirect within controller.</h1>

निम्न URL पर जाकर उपरोक्त उदाहरण देखें।

http: // localhost / cakephp4 / पुनर्निर्देशित नियंत्रक

उत्पादन

निष्पादन के बाद, आप निम्न आउटपुट प्राप्त करेंगे।

अब, निम्नलिखित URL पर जाएँ: http: // localhost / cakephp4 / redirect-नियंत्रक2

उपरोक्त URL आपको निम्न आउटपुट देगा।

लोड हो रहा है मॉडल

CakePHP में, मॉडल का उपयोग करके एक मॉडल को लोड किया जा सकता है loadModel()तरीका। निम्नलिखित के लिए वाक्य रचना हैloadModel() विधि -

Cake\Controller\Controller::loadModel(string $modelClass, string $type)

उपरोक्त फ़ंक्शन के दो तर्क निम्न हैं -

  • पहला तर्क मॉडल वर्ग का नाम है।

  • दूसरा तर्क लोड करने के लिए भंडार का प्रकार है।

उदाहरण

यदि आप एक नियंत्रक में लेख मॉडल लोड करना चाहते हैं, तो इसे नियंत्रक की कार्रवाई में निम्नलिखित पंक्ति लिखकर लोड किया जा सकता है।

$this->loadModel('Articles');

MVC में "V" अक्षर व्यू के लिए है। अनुरोध के आधार पर उपयोगकर्ता को आउटपुट भेजने के लिए दृश्य जिम्मेदार हैं।View Classes विकास की प्रक्रिया को तेज करने का एक शक्तिशाली तरीका है।

टेम्प्लेट देखें

CakePHP की व्यू टेम्प्लेट फ़ाइल कंट्रोलर से डेटा प्राप्त करती है और फिर आउटपुट रेंडर करती है ताकि इसे उपयोगकर्ता के लिए ठीक से प्रदर्शित किया जा सके। हम टेम्प्लेट में चर, विभिन्न नियंत्रण संरचनाओं का उपयोग कर सकते हैं।

टेम्प्लेट फ़ाइलें संग्रहीत की जाती हैं src/Template/, नियंत्रक के नाम वाली एक निर्देशिका में, जो फ़ाइलों का उपयोग करता है, और कार्रवाई से मेल खाती है, के नाम पर। उदाहरण के लिए,Viewउत्पाद नियंत्रक के लिए फ़ाइल “view()” कार्रवाई, सामान्य रूप से src / Template / Products / view.php में मिलेगी।

संक्षेप में, नियंत्रक (ProductController) का नाम फ़ोल्डर (उत्पाद) के नाम के समान है, लेकिन नियंत्रक शब्द के बिना और नियंत्रक / क्रिया (विधि ()) का नाम नियंत्रक (ProductController) के नाम के समान है फ़ाइल देखें (view.php)।

चर देखें

देखें चर वे चर हैं जो नियंत्रक से मान प्राप्त करते हैं। हम जितने चाहें उतने टेंपरेचर में उपयोग कर सकते हैं। हम उपयोग कर सकते हैंset()विचारों में चर के मानों को पारित करने की विधि। ये सेट चर आपके एक्शन रेंडर को देखने और लेआउट दोनों में उपलब्ध होंगे। निम्नलिखित का सिंटैक्स हैset() तरीका।

Cake\View\View::set(string $var, mixed $value)

इस विधि में दो तर्क दिए गए हैं - the name of the variable तथा its value

उदाहरण

में परिवर्तन करें config/routes.php निम्नलिखित कार्यक्रम में दिखाया गया है।

config/routes.php

<?php
use Cake\Http\Middleware\CsrfProtectionMiddleware;
use Cake\Routing\Route\DashedRoute;
use Cake\Routing\RouteBuilder;
$routes->setRouteClass(DashedRoute::class);
$routes->scope('/', function (RouteBuilder $builder) {
   // Register scoped middleware for in scopes.
   $builder->registerMiddleware('csrf', new CsrfProtectionMiddleware([ 'httpOnly' => true, ])); $builder->applyMiddleware('csrf');
   $builder->connect('template',['controller'=>'Products','action'=>'view']); $builder->fallbacks();
});

बनाओ ProductsController.php पर फ़ाइल करें src/Controller/ProductsController.php. नियंत्रक फ़ाइल में निम्न कोड की प्रतिलिपि बनाएँ।

src/Controller/ProductsController.php

<?php
declare(strict_types=1);
namespace App\Controller;
use Cake\Core\Configure;
use Cake\Http\Exception\ForbiddenException;
use Cake\Http\Exception\NotFoundException;
use Cake\Http\Response;
use Cake\View\Exception\MissingTemplateException;
class ProductsController extends AppController {
public function view(){
      $this->set('Product_Name','XYZ');
   }
}

पर एक निर्देशिका उत्पाद बनाएँ src/Template और उस फ़ोल्डर के तहत एक बनाएँ Viewफ़ाइल जिसे view.php कहा जाता है। उस फ़ाइल में निम्न कोड कॉपी करें।

Value of variable is: <?php echo $Product_Name; ? >

निम्न URL पर जाकर उपरोक्त उदाहरण देखें।

http: // localhost / cakephp4 / टेम्पलेट

उत्पादन

उपरोक्त URL निम्न आउटपुट का उत्पादन करेगा।

कई बार, वेब पेज बनाते समय, हम पृष्ठों के कुछ भाग को अन्य पृष्ठों में दोहराना चाहते हैं। CakePHP में ऐसी सुविधा है जिसके द्वारा कोई अन्य दृश्य में दृश्य का विस्तार कर सकता है और इसके लिए हमें दोबारा कोड दोहराने की आवश्यकता नहीं है।

extend() में विचारों का विस्तार करने के लिए विधि का उपयोग किया जाता है Viewफ़ाइल। यह विधि एक तर्क लेती है, अर्थात, पथ के साथ दृश्य फ़ाइल का नाम। दृश्य फ़ाइल का नाम प्रदान करते समय एक्सटेंशन .ctp का उपयोग न करें।

उदाहरण

निम्न प्रोग्राम में दिखाए गए अनुसार config / path.php फ़ाइल में परिवर्तन करें।

config / routes.php

<?php
use Cake\Http\Middleware\CsrfProtectionMiddleware;
use Cake\Routing\Route\DashedRoute;
use Cake\Routing\RouteBuilder;
$routes->setRouteClass(DashedRoute::class); $routes->scope('/', function (RouteBuilder $builder) { $builder->registerMiddleware('csrf', new CsrfProtectionMiddleware([
      'httpOnly' => true,
   ]));
   $builder->applyMiddleware('csrf'); $builder->connect('extend',['controller'=>'Extends','action'=>'index']);
   $builder->fallbacks();
});

बनाओ ExtendsController.php पर फ़ाइल करें src/Controller/ExtendsController.php. नियंत्रक फ़ाइल में निम्न कोड की प्रतिलिपि बनाएँ।

src / नियंत्रक / ExtendsController.php

<?php
   namespace App\Controller;
   use App\Controller\AppController;
   class ExtendsController extends AppController{
      public function index(){
      }
   }
?>

एक निर्देशिका बनाएँ Extends पर src/Template और उस फ़ोल्डर के तहत एक बनाएँ Viewहैडर नामक फ़ाइल। php। उस फ़ाइल में निम्न कोड कॉपी करें।

src / खाका / का विस्तार / header.php

<div align="center">
   <h1>Common Header</h1>
</div>
<?= $this->fetch('content') ?>

दूसरा बनाओ View के अंतर्गत Extends निर्देशिका कहा जाता है index.php.उस फ़ाइल में निम्न कोड कॉपी करें। यहां, हम उपरोक्त दृश्य का विस्तार कर रहे हैंheader.php.

src / खाका / का विस्तार / index.php

<?php $this->extend('header'); ?>
This is an example of extending view.

निम्नलिखित URL http: // localhost / cakephp4 / विस्तारित पर जाकर उपरोक्त उदाहरण देखें

उत्पादन

निष्पादन के बाद, आप निम्न आउटपुट प्राप्त करेंगे।

वेब पेजों के कुछ हिस्सों को कई वेब पेजों पर दोहराया जाता है, लेकिन विभिन्न स्थानों पर। CakePHP इन दोहराया भागों का पुन: उपयोग करने में हमारी मदद कर सकता है। इन पुन: प्रयोज्य भागों को कहा जाता हैElements - help box, extra menu, आदि एक तत्व मूल रूप से एक है mini-view। हम तत्वों में चर भी पारित कर सकते हैं।

Cake\View\View::element(string $elementPath, array $data, array $options =[]

उपरोक्त समारोह के तीन तर्क इस प्रकार हैं -

  • पहला तर्क टेम्पलेट फ़ाइल का नाम है /src/Template/element/ फ़ोल्डर।

  • दूसरा तर्क प्रदान किए गए दृश्य को उपलब्ध कराने के लिए डेटा का सरणी है।

  • तीसरा तर्क विकल्पों की सरणी के लिए है। उदाहरण के लिए कैश।

3 तर्कों में से पहला अनिवार्य है, जबकि बाकी वैकल्पिक हैं।

उदाहरण

पर एक तत्व फ़ाइल बनाएँ src/Template/element निर्देशिका कहा जाता है helloworld.php. उस फ़ाइल में निम्न कोड कॉपी करें।

src / खाका / तत्व / helloworld.php

<p>Hello World</p>

एक फ़ोल्डर बनाएँ Elems पर src/Template और उस निर्देशिका के तहत एक बनाएँ Viewindex.php नामक फाइल। उस फ़ाइल में निम्न कोड कॉपी करें।

src / खाका / elems / index.php

Element Example: <?php echo $this->element('helloworld'); ?>

में परिवर्तन करें config/routes.php निम्नलिखित कार्यक्रम में दिखाया गया है।

config / routes.php

<?php
use Cake\Http\Middleware\CsrfProtectionMiddleware;
use Cake\Routing\Route\DashedRoute;
use Cake\Routing\RouteBuilder;
$routes->setRouteClass(DashedRoute::class);
$routes->scope('/', function (RouteBuilder $builder) {
   $builder->registerMiddleware('csrf', new CsrfProtectionMiddleware([ 'httpOnly' => true, ])); $builder->applyMiddleware('csrf');
   $builder->connect('/element-example',['controller'=>'Elems','action'=>'index']); $builder->fallbacks();
});

बनाओ ElemsController.php पर फ़ाइल करें src/Controller/ElemsController.php. नियंत्रक फ़ाइल में निम्न कोड की प्रतिलिपि बनाएँ।

src / नियंत्रक / ElemsController.php

<?php
   namespace App\Controller;
   use App\Controller\AppController;
   class ElemsController extends AppController{
      public function index(){
      }
   }
?>

निम्नलिखित URL http: // localhost / cakephp4 / element-example पर जाकर उपरोक्त उदाहरण देखें

उत्पादन

निष्पादन के बाद, उपरोक्त URL आपको निम्न आउटपुट देगा।

कई कॉलबैक / इवेंट्स हैं जिनका उपयोग हम व्यू इवेंट्स के साथ कर सकते हैं। कुछ होने से पहले या कुछ होने के बाद ये कार्यक्रम कई कार्यों को करने में सहायक होते हैं। निम्नलिखित कॉलबैक की एक सूची है जिसका उपयोग CakePHP के साथ किया जा सकता है -

अनु क्रमांक इवेंट फंक्शन और विवरण
1

Helper::beforeRender(Event $event,$viewFile)

beforeRender कंट्रोलर के पहले के रेंडर मेथड के बाद मेथड कहा जाता है लेकिन कंट्रोलर रेंडर से पहले view तथा layout। यह फ़ाइल को एक तर्क के रूप में प्रदान की जा रही है।

2

Helper::beforeRenderFile(Event $event, $viewFile)

प्रत्येक दृश्य फ़ाइल रेंडर करने से पहले इस विधि को कहा जाता है। यह भी शामिल हैelements, views, parent views तथा layouts

3

Helper::afterRenderFile(Event $event, $viewFile, $content)

प्रत्येक दृश्य फ़ाइल के रेंडर होने के बाद इस विधि को कहा जाता है। यह भी शामिल हैelements, views, parent views तथा layouts। एक कॉलबैक संशोधित और वापस आ सकता है$content यह बताने के लिए कि ब्राउज़र में प्रदान की गई सामग्री कैसे प्रदर्शित की जाएगी।

4

Helper::afterRender(Event $event, $viewFile)

इस पद्धति को दृश्य रेंडर होने के बाद कहा जाता है, लेकिन लेआउट रेंडरिंग शुरू होने से पहले।

5

Helper::beforeLayout(Event $event, $layoutFile)

लेआउट रेंडरिंग शुरू होने से पहले इस विधि को कहा जाता है। यह एक तर्क के रूप में लेआउट फ़ाइल नाम प्राप्त करता है।

6

Helper::afterLayout(Event $event, $layoutFile)

लेआउट रेंडरिंग पूर्ण होने के बाद इस विधि को कहा जाता है। यह एक तर्क के रूप में लेआउट फ़ाइल नाम प्राप्त करता है।

CakePHP में डेटाबेस के साथ काम करना बहुत आसान है। हम इस अध्याय में CRUD (क्रिएट, रीड, अपडेट, डिलीट) ऑपरेशंस को समझेंगे।

इसके अलावा, हमें अपने डेटाबेस को भी कॉन्फ़िगर करना होगा config/app_local.php file.

'Datasources' => [
   'default' => [
      'host' => 'localhost',
      'username' => 'my_app',
      'password' => 'secret',
      'database' => 'my_app',
      'url' => env('DATABASE_URL', null),
   ],
   /*
      * The test connection is used during the test suite.
   */
   'test' => [
      'host' => 'localhost',
      //'port' => 'non_standard_port_number',
      'username' => 'my_app',
      'password' => 'secret',
      'database' => 'test_myapp',
      //'schema' => 'myapp',
   ],
],

डिफ़ॉल्ट कनेक्शन में निम्नलिखित विवरण हैं -

'host' => 'localhost',
   'username' => 'my_app',
   'password' => 'secret',
   'database' => 'my_app',

आप अपनी पसंद के अनुसार विवरण, यानी होस्ट, उपयोगकर्ता नाम, पासवर्ड और डेटाबेस बदल सकते हैं।

एक बार हो जाने के बाद, यह सुनिश्चित करें कि यह डाटासॉर्स ऑब्जेक्ट में config / app_local.php में अपडेट किया गया है।

अब, हम उपरोक्त विवरण के साथ जारी रखेंगे, अपने phpmyadmin या mysql डेटाबेस पर जाएं और उपयोगकर्ता my_app बनाएं जो नीचे दिखाया गया है -

आवश्यक विशेषाधिकार दें और इसे बचाएं। अब, हमारे पास app_local.php में उल्लिखित विन्यास के अनुसार डेटाबेस का विवरण है। जब आप केकपीएचपी होम पेज की जांच करते हैं, तो आपको यही मिलना चाहिए -

अब, हम डेटाबेस में निम्नलिखित उपयोगकर्ताओं की तालिका बनाएंगे।

CREATE TABLE `users` ( 
   `id` int(11) NOT NULL AUTO_INCREMENT,
   `username` varchar(50) NOT NULL, 
   `password` varchar(255) NOT NULL, PRIMARY KEY (`id`) 
) ENGINE=InnoDB AUTO_INCREMENT=7 DEFAULT CHARSET=latin1

एक रिकॉर्ड डालें

डेटाबेस में रिकॉर्ड डालने के लिए, हमें सबसे पहले उपयोग करके एक टेबल पकड़नी होगी TableRegistryकक्षा। हम रजिस्ट्री का उपयोग करके उदाहरण प्राप्त कर सकते हैंget()तरीका। get() विधि डेटाबेस तालिका का नाम तर्क के रूप में लेगा।

इस नई आवृत्ति का उपयोग नई इकाई बनाने के लिए किया जाता है। नई इकाई के उदाहरण के साथ आवश्यक मान सेट करें। हमें अब कॉल करना होगाsave() के साथ विधि TableRegistry कक्षा का उदाहरण डेटाबेस में नया रिकॉर्ड डालेगा।

उदाहरण

में बदलाव करें config/routes.php निम्नलिखित कार्यक्रम में दिखाया गया है।

config/routes.php

<?php
use Cake\Http\Middleware\CsrfProtectionMiddleware;
use Cake\Routing\Route\DashedRoute;
use Cake\Routing\RouteBuilder;
$routes->setRouteClass(DashedRoute::class); $routes->scope('/', function (RouteBuilder $builder) { $builder->registerMiddleware('csrf', new CsrfProtectionMiddleware([
      'httpOnly' => true,
   ]));
   $builder->applyMiddleware('csrf'); //$builder->connect('/pages',['controller'=>'Pages','action'=>'display', 'home']);
   $builder->connect('/users/add', ['controller' => 'Users', 'action' => 'add']); $builder->fallbacks();
});

बनाओ UsersController.php पर फ़ाइल करें src/Controller/UsersController.php. नियंत्रक फ़ाइल में निम्न कोड की प्रतिलिपि बनाएँ।

src/controller/UsersController.php

<?php
namespace App\Controller;
use App\Controller\AppController;
use Cake\ORM\TableRegistry;
use Cake\Datasource\ConnectionManager;
use Cake\Auth\DefaultPasswordHasher;
class UsersController extends AppController{
   public function add(){
      if($this->request->is('post')){ $username = $this->request->getData('username'); $hashPswdObj = new DefaultPasswordHasher;
         $password = $hashPswdObj->hash($this->request->getData('password')); $users_table = TableRegistry::get('users');
         $users = $users_table->newEntity($this->request->getData()); $users->username = $username; $users->password = $password; $this->set('users', $users); if($users_table->save($users))
         echo "User is added.";
      }
   }
}
?>

एक निर्देशिका बनाएँ Users पर src/Template और उस निर्देशिका के तहत एक बनाएँ Viewadd.php नामक फाइल। उस फ़ाइल में निम्न कोड कॉपी करें।

src/Template/Users/add.php

<?php
   echo $this->Form->create(NULL,array('url'=>'/users/add'));
   echo $this->Form->control('username'); echo $this->Form->control('password');
   echo $this->Form->button('Submit'); echo $this->Form->end();
?>

निम्न URL पर जाकर उपरोक्त उदाहरण देखें। http: // localhost / cakephp4 / उपयोगकर्ताओं / ऐड

उत्पादन

निष्पादन के बाद, आप निम्न आउटपुट प्राप्त करेंगे।

जैसा कि नीचे दिखाया गया है, डेटा को उपयोगकर्ता तालिका में सहेजा जाएगा -

डेटाबेस के रिकॉर्ड को देखने के लिए, हमें सबसे पहले एक टेबल को पकड़ना होगा TableRegistryकक्षा। हम रजिस्ट्री का उपयोग करके उदाहरण प्राप्त कर सकते हैंget()तरीका। get() विधि तर्क के रूप में डेटाबेस तालिका का नाम लेगी।

अब, इस नए उदाहरण का उपयोग डेटाबेस से रिकॉर्ड खोजने के लिए किया जाता है () विधि का उपयोग कर। यह विधि अनुरोधित तालिका से सभी रिकॉर्ड लौटा देगी।

उदाहरण

में बदलाव करें config/routes.php फ़ाइल को निम्न कोड में दिखाया गया है।

config / routes.php

<?php
use Cake\Http\Middleware\CsrfProtectionMiddleware;
use Cake\Routing\Route\DashedRoute;
use Cake\Routing\RouteBuilder;
$routes->setRouteClass(DashedRoute::class); $routes->scope('/', function (RouteBuilder $builder) { $builder->registerMiddleware('csrf', new CsrfProtectionMiddleware([
      'httpOnly' => true,
   ]));
   $builder->applyMiddleware('csrf'); //$builder->connect('/pages',['controller'=>'Pages','action'=>'display', 'home']);
   $builder->connect('/users', ['controller' => 'Users', 'action' => 'index']); $builder->fallbacks();
});

बनाओ UsersController.php पर फ़ाइल करें src/Controller/UsersController.php. नियंत्रक फ़ाइल में निम्न कोड की प्रतिलिपि बनाएँ।

src / नियंत्रक / UsersController.php

<?php
   namespace App\Controller;
   use App\Controller\AppController;
   use Cake\ORM\TableRegistry;
   use Cake\Datasource\ConnectionManager;
   class UsersController extends AppController{
      public function index(){
         $users = TableRegistry::get('users'); $query = $users->find(); $this->set('results',$query);
      }
   }
?>

एक निर्देशिका बनाएँ Users पर src/Template, यदि पहले से निर्मित है, तो अनदेखा करें और उस निर्देशिका के अंतर्गत a बनाएँ View फ़ाइल कहा जाता है index.php. उस फ़ाइल में निम्न कोड कॉपी करें।

src / खाका / उपयोगकर्ताओं / index.ctp

<a href="add">Add User</a>
<table>
   <tr>
      <td>ID</td>
      <td>Username</td>
      <td>Password</td>
      <td>Edit</td>
      <td>Delete</td>
   </tr>
   <?php
      foreach ($results as $row): echo "<tr><td>".$row->id."</td>";
      echo "<td<".$row-<username."</td>"; echo "<td>".$row->password."</td>";
      echo "<td><a href='".$this-<Url->build(["controller" => "Users","action" => "edit",$row->id])."'>Edit</a></td>";
      echo "<td><a href='".$this->Url->build(["controller" => "Users","action" => "delete",$row->id])."'>Delete</a></td></tr>";
      endforeach;
   ?>
</table>

निम्नलिखित URL http: // localhost / cakephp4 / उपयोगकर्ताओं पर जाकर उपरोक्त उदाहरण देखें

उत्पादन

निष्पादन के बाद, उपरोक्त URL आपको निम्न आउटपुट देगा।

डेटाबेस में रिकॉर्ड अपडेट करने के लिए, हमें सबसे पहले एक टेबल को पकड़कर उपयोग करना होगा TableRegistryकक्षा। हम रजिस्ट्री का उपयोग करके उदाहरण प्राप्त कर सकते हैंget()तरीका। get()विधि डेटाबेस तालिका का नाम तर्क के रूप में लेगा। अब, इस नए उदाहरण का उपयोग उस विशेष रिकॉर्ड को प्राप्त करने के लिए किया जाता है जिसे हम अपडेट करना चाहते हैं।

बुलाएं get()इस नए उदाहरण के साथ विधि, और एक रिकॉर्ड खोजने के लिए प्राथमिक कुंजी को पास करें, जिसे किसी अन्य उदाहरण में सहेजा जाएगा। इस उदाहरण का उपयोग करें, नए मान सेट करने के लिए जिन्हें आप अपडेट करना चाहते हैं और फिर, अंत में कॉल करेंsave() के साथ विधि TableRegistry रिकॉर्ड को अद्यतन करने के लिए कक्षा का उदाहरण।

उदाहरण

निम्न कोड में दिखाए गए अनुसार config / path.php फ़ाइल में परिवर्तन करें।

config / routes.php

<?php
use Cake\Http\Middleware\CsrfProtectionMiddleware;
use Cake\Routing\Route\DashedRoute;
use Cake\Routing\RouteBuilder;
$routes->setRouteClass(DashedRoute::class); $routes->scope('/', function (RouteBuilder $builder) { $builder->registerMiddleware('csrf', new CsrfProtectionMiddleware([
      'httpOnly' => true,
   ]));
   $builder->applyMiddleware('csrf'); //$builder->connect('/pages',['controller'=>'Pages','action'=>'display', 'home']);
   $builder->connect('/users/edit', ['controller' => 'Users', 'action' => 'edit']); $builder->fallbacks();
});

बनाओ UsersController.php पर फ़ाइल करें src/Controller/UsersController.php. नियंत्रक फ़ाइल में निम्न कोड की प्रतिलिपि बनाएँ।

src / नियंत्रक / UsersController.php

<?php
   namespace App\Controller;
   use App\Controller\AppController;
   use Cake\ORM\TableRegistry;
   use Cake\Datasource\ConnectionManager;
   class UsersController extends AppController{
      public function index(){
         $users = TableRegistry::get('users'); $query = $users->find(); $this->set('results',$query); } public function edit($id){
         if($this->request->is('post')){ $username = $this->request->getData('username'); $password = $this->request->getData('password'); $users_table = TableRegistry::get('users');
            $users = $users_table->get($id); $users->username = $username; $users->password = $password; if($users_table->save($users)) echo "User is udpated"; $this->setAction('index');
         } else {
            $users_table = TableRegistry::get('users')->find(); $users = $users_table->where(['id'=>$id])->first();
            $this->set('username',$users->username);
            $this->set('password',$users->password);
            $this->set('id',$id);
         }
      }
   }
?>

एक निर्देशिका बनाएँ Users at src/Template, यदि पहले से निर्मित है, तो अनदेखा करें और उस निर्देशिका के तहत एक दृश्य बनाएं जिसे कहा जाता है index.php. उस फ़ाइल में निम्न कोड कॉपी करें।

src / खाका / उपयोगकर्ताओं / index.php

<a href="add">Add User</a>
<table>
   <tr>
   <td>ID</td>
   <td>Username</td>
   <td>Password</td>
   <td>Edit</td>
   <td>Delete</td>
   </tr>
   <?php
      foreach ($results as $row):
      echo "<tr><td>".$row->id."</td>"; echo "<td>".$row->username."</td>";
      echo "<td>".$row->password."</td>"; echo "<td><a href='".$this->Url->build(["controller" => "Users","action" => "edit",$row->id])."'>Edit</a></td>"; echo "<td><a href='".$this->Url->build(["controller" => "Users","action" => "delete",$row->id])."'>Delete</a></td></tr>";
      endforeach;
   ?>
</table>

दूसरा बनाओ View उपयोगकर्ता निर्देशिका के तहत फ़ाइल कहा जाता है edit.php और इसमें निम्न कोड को कॉपी करें।

src / खाका / उपयोगकर्ताओं / edit.php

<?php
   echo $this->Form->create(NULL,array('url'=>'/users/edit/'.$id)); echo $this->Form->control('username',['value'=>$username]); echo $this->Form->control('password',['value'=>$password]); echo $this->Form->button('Submit');
   echo $this->Form->end();
?>

निम्न URL पर जाकर उपरोक्त उदाहरण देखें और क्लिक करें Edit link रिकॉर्ड संपादित करने के लिए।

http: // localhost / cakephp4 / उपयोगकर्ताओं

उत्पादन

उपरोक्त URL पर जाने के बाद, यह नीचे दिखाए गए अनुसार उपयोगकर्ताओं की तालिका में रिकॉर्ड प्रदर्शित करेगा -

संपादित करें बटन पर क्लिक करें और यह आपको निम्नलिखित स्क्रीन प्रदर्शित करेगा -

अब, हम विराट नाम को विराट १२३ में अद्यतन करेंगे और विवरण प्रस्तुत करेंगे। प्रदर्शित अगली स्क्रीन इस प्रकार होगी -

डेटाबेस में एक रिकॉर्ड को हटाने के लिए, हमें सबसे पहले एक तालिका का उपयोग करना होगा TableRegistryकक्षा। हम रजिस्ट्री का उपयोग करके उदाहरण प्राप्त कर सकते हैंget()तरीका। प्राप्त () विधि डेटाबेस तालिका का नाम तर्क के रूप में लेगी। अब, यह नया उदाहरण विशेष रिकॉर्ड प्राप्त करने के लिए उपयोग किया जाता है जिसे हम हटाना चाहते हैं।

बुलाएं get()इस नए उदाहरण के साथ विधि और एक रिकॉर्ड खोजने के लिए प्राथमिक कुंजी को पास करें जो किसी अन्य उदाहरण में सहेजी जाएगी। कॉल करने के लिए TableRegistry वर्ग के उदाहरण का उपयोग करेंdelete डेटाबेस से रिकॉर्ड को हटाने के लिए विधि।

उदाहरण

निम्न कोड में दिखाए गए अनुसार config / path.php फ़ाइल में परिवर्तन करें।

config / routes.php

<?php
use Cake\Http\Middleware\CsrfProtectionMiddleware;
use Cake\Routing\Route\DashedRoute;
use Cake\Routing\RouteBuilder;
$routes->setRouteClass(DashedRoute::class);
$routes->scope('/', function (RouteBuilder $builder) {
   $builder->registerMiddleware('csrf', new CsrfProtectionMiddleware([ 'httpOnly' => true, ])); $builder->applyMiddleware('csrf');
   //$builder->connect('/pages',['controller'=>'Pages','action'=>'display', 'home']); $builder->connect('/users/delete', ['controller' => 'Users', 'action' => 'delete']);
   $builder->fallbacks();
});

बनाओ UsersController.php पर फ़ाइल करें src/Controller/UsersController.php. नियंत्रक फ़ाइल में निम्न कोड की प्रतिलिपि बनाएँ।

src / नियंत्रक / UsersController.php

<?php
   namespace App\Controller;
   use App\Controller\AppController;
   use Cake\ORM\TableRegistry;
   use Cake\Datasource\ConnectionManager;
   class UsersController extends AppController{
      public function index(){
         $users = TableRegistry::get('users');
         $query = $users->find();
         $this->set('results',$query);
      }
      public function delete($id){ $users_table = TableRegistry::get('users');
         $users = $users_table->get($id); $users_table->delete($users); echo "User deleted successfully."; $this->setAction('index');
      }
   }
?>

बस एक रिक्त बनाएँ View के तहत दर्ज करें Users निर्देशिका कहा जाता है delete.ctp.

src / खाका / उपयोगकर्ताओं / delete.ctp

एक निर्देशिका बनाएँ Users पर src/Template, यदि पहले से निर्मित है, तो अनदेखा करें और उस निर्देशिका के अंतर्गत a बनाएँ Viewफ़ाइल कहा जाता है index.ctp. उस फ़ाइल में निम्न कोड कॉपी करें।

src / खाका / उपयोगकर्ताओं / index.ctp

<a href="add">Add User</a>
<table>
   <tr>
   <td>ID</td>
   <td>Username</td>
   <td>Password</td>
   <td>Edit</td>
   <td>Delete</td>
   </tr>
   <?php
      foreach ($results as $row):
      echo "<tr><td>".$row->id."</td>"; echo "<td>".$row->username."</td>";
      echo "<td>".$row->password."</td>"; echo "<td><a href='".$this->Url->build(["controller" => "Users","action" => "edit",$row->id])."'>Edit</a></td>"; echo "<td><a href='".$this->Url->build(["controller" => "Users","action" => "delete",$row->id])."'>Delete</a></td></tr>";
      endforeach;
   ?>
</table>

निम्न URL पर जाकर उपरोक्त उदाहरण देखें और क्लिक करें Delete link रिकॉर्ड हटाने के लिए।

http: // localhost: 85 / CakePHP / उपयोगकर्ताओं

उत्पादन

उपरोक्त URL पर जाने और डिलीट लिंक पर क्लिक करने के बाद, आपको निम्न आउटपुट प्राप्त होंगे जहाँ आप रिकॉर्ड हटा सकते हैं।

रिकॉर्ड हटाने के लिए डिलीट लिंक पर क्लिक करें।

यह अध्याय CakePHP में उपलब्ध प्रमाणीकरण प्रक्रिया के बारे में जानकारी प्रदान करता है।

प्रमाणीकरण

प्रमाणीकरण सही उपयोगकर्ता की पहचान करने की प्रक्रिया है। CakePHP प्रमाणीकरण के तीन प्रकारों का समर्थन करता है।

  • FormAuthenticate- यह आपको प्रपत्र POST डेटा के आधार पर उपयोगकर्ताओं को प्रमाणित करने की अनुमति देता है। आमतौर पर, यह एक लॉगिन फ़ॉर्म है जिसमें उपयोगकर्ता जानकारी दर्ज करते हैं। यह डिफ़ॉल्ट प्रमाणीकरण विधि है।

  • BasicAuthenticate - यह आपको मूल HTTP प्रमाणीकरण का उपयोग करके उपयोगकर्ताओं को प्रमाणित करने की अनुमति देता है

  • DigestAuthenticate - यह आपको डाइजेस्ट HTTP प्रमाणीकरण का उपयोग करके उपयोगकर्ताओं को प्रमाणित करने की अनुमति देता है।

FormAuthentication के लिए उदाहरण

निम्न कोड में दिखाए गए अनुसार config / path.php फ़ाइल में परिवर्तन करें।

config/routes.php

<?php
use Cake\Core\Plugin;
use Cake\Routing\RouteBuilder;
use Cake\Routing\Router;
Router::defaultRouteClass('DashedRoute');
Router::scope('/', function (RouteBuilder $routes) {
   $routes->connect('/auth',['controller'=>'Authexs','action'=>'index']); $routes->connect('/login',['controller'=>'Authexs','action'=>'login']);
   $routes->connect('/logout',['controller'=>'Authexs','action'=>'logout']); $routes->fallbacks('DashedRoute');
});
Plugin::routes();

निम्न कार्यक्रम में दिखाए गए अनुसार AppController.php फ़ाइल का कोड बदलें।

src/Controller/AppController.php

<?php
namespace App\Controller;
use Cake\Controller\Controller;
use Cake\Event\Event;
use Cake\Controller\Component\AuthComponent;
class AppController extends Controller {
   public function initialize() {
      parent::initialize();
      $this->loadComponent('RequestHandler'); $this->loadComponent('Flash');
         $this->loadComponent('Auth', [ 'authenticate' => [ 'Form' => [ 'fields' => [ 'username' => 'username', 'password' => 'password' ] ] ], 'loginAction' => [ 'controller' => 'Authexs', 'action' => 'login' ], 'loginRedirect' => [ 'controller' => 'Authexs', 'action' => 'index' ], 'logoutRedirect' => [ 'controller' => 'Authexs', 'action' => 'login' ] ]); } public function beforeFilter(Event $event) {
      $this->Auth->allow(['index','view']); $this->set('loggedIn', $this->Auth->user());
   }
}

सृजन करना AuthexsController.php पर फ़ाइल करें src/Controller/AuthexsController.php. नियंत्रक फ़ाइल में निम्न कोड की प्रतिलिपि बनाएँ।

src/Controller/AuthexsController.php

<?php
namespace App\Controller;
use App\Controller\AppController;
use Cake\ORM\TableRegistry;
use Cake\Datasource\ConnectionManager;
use Cake\Event\Event;
use Cake\Auth\DefaultPasswordHasher;
class AuthexsController extends AppController {
   var $components = array('Auth');
   public function index(){
   }
   public function login(){
      if($this->request->is('post')) { $user = $this->Auth->identify(); if($user){
            $this->Auth->setUser($user);
            return $this->redirect($this->Auth->redirectUrl());
         } else
         $this->Flash->error('Your username or password is incorrect.'); } } public function logout(){ return $this->redirect($this->Auth->logout());
   } 
}
?>

एक निर्देशिका बनाएँ Authexs पर src/Template और उस निर्देशिका के तहत एक बनाएँ View फ़ाइल कहा जाता है login.php। उस फ़ाइल में निम्न कोड कॉपी करें।

src/Template/Authexs/login.php

<?php
   echo $this->Form->create();
   echo $this->Form->control('username'); echo $this->Form->control('password');
   echo $this->Form->button('Submit'); echo $this->Form->end();
?>

दूसरा बनाओ View फ़ाइल कहा जाता है logout.php. उस फ़ाइल में निम्न कोड कॉपी करें।

src/Template/Authexs/logout.php

You are successfully logged out.

दूसरा बनाओ View फ़ाइल कहा जाता है index.php. उस फ़ाइल में निम्न कोड कॉपी करें।

src/Template/Authexs/index.php

You are successfully logged in. 
<?php 
   echo $this->Html->link('logout',[
      "controller" => "Authexs","action" => "logout"
   ]); 
?>

निम्न URL पर जाकर उपरोक्त उदाहरण देखें।

http: // localhost / cakephp4 / प्रमाणन

उत्पादन

जैसा कि प्रमाणीकरण लागू किया गया है, और एक बार जब आप उपरोक्त URL पर जाने का प्रयास करते हैं, तो आपको नीचे दिखाए गए लॉगिन पृष्ठ पर भेज दिया जाएगा।

सही क्रेडेंशियल्स प्रदान करने के बाद, आपको लॉग इन किया जाएगा और स्क्रीन पर रीडायरेक्ट किया जाएगा जैसा कि नीचे दिखाया गया है।

पर क्लिक करने के बाद logout लिंक, आपको फिर से लॉगिन स्क्रीन पर भेज दिया जाएगा।

प्रणाली को सुचारू रूप से चलाने के लिए प्रणाली की विफलता को प्रभावी ढंग से संभालने की आवश्यकता है। CakePHP डिफ़ॉल्ट त्रुटि फंसाने के साथ आता है, जो प्रिंट और लॉग त्रुटि के रूप में होता है। इसी त्रुटि हैंडलर को पकड़ने के लिए उपयोग किया जाता हैExceptions

डिबग सही होने पर त्रुटि हैंडलर त्रुटियों को प्रदर्शित करता है, और डीबग झूठा होने पर त्रुटि लॉग करता है। CakePHP में अपवाद कक्षाओं की संख्या होती है और बिल्ट इन अपवाद हैंडलिंग किसी भी अनकैप्ड अपवाद को कैप्चर करेगा और एक उपयोगी पृष्ठ को प्रस्तुत करेगा।

त्रुटियां और अपवाद कॉन्फ़िगरेशन

त्रुटियों और अपवाद को फ़ाइल में कॉन्फ़िगर किया जा सकता है config\app.php। त्रुटि से निपटने के कुछ विकल्प स्वीकार करते हैं जो आपको अपने आवेदन के लिए दर्जी त्रुटि से निपटने की अनुमति देते हैं -

विकल्प डाटा प्रकार विवरण
eRRORLEVEL पूर्णांक

त्रुटियों का स्तर जिसे आप पकड़ने में रुचि रखते हैं। आपके द्वारा रुचि के स्तर का चयन करने के लिए अंतर्निहित php त्रुटि स्थिरांक, और बिटमास्क का उपयोग करें।

निशान bool

लॉग फ़ाइलों में त्रुटियों के लिए स्टैक निशान शामिल करें। प्रत्येक त्रुटि के बाद लॉग में स्टैक के निशान शामिल किए जाएंगे। यह पता लगाने में मददगार है कि त्रुटियां कहां / कब उठाई जा रही हैं।

exceptionRenderer तार

बिना किसी अपवाद के रेंडरिंग के लिए जिम्मेदार वर्ग। यदि आप चुनते हैंcustom क्लास, आपको उस क्लास के लिए फाइल को अंदर रखना चाहिए src/Error। इस वर्ग को लागू करने की जरूरत हैrender() तरीका।

लॉग bool

सही होने पर, अपवाद + उनके स्टैक के निशान लॉग इन हो जाएंगे Cake\Log\Log

skipLog सरणी

अपवाद श्रेणी नामों की एक सरणी जिसे लॉग नहीं किया जाना चाहिए। यह हटाने के लिए उपयोगी हैNotFoundExceptions या अन्य सामान्य, लेकिन निर्बाध लॉग संदेश।

extraFatalErrorMemory पूर्णांक

जब कोई घातक त्रुटि सामने आती है, तो मेमोरी सीमा बढ़ाने के लिए मेगाबाइट की संख्या पर सेट करें। यह श्वास कक्ष को लॉगिंग या त्रुटि हैंडलिंग को पूरा करने की अनुमति देता है।

उदाहरण

में बदलाव करें config/routes.php फ़ाइल को निम्न कोड में दिखाया गया है।

config/routes.php

<?php
use Cake\Http\Middleware\CsrfProtectionMiddleware;
use Cake\Routing\Route\DashedRoute;
use Cake\Routing\RouteBuilder;
$routes->setRouteClass(DashedRoute::class);
$routes->scope('/', function (RouteBuilder $builder) {
   $builder->registerMiddleware('csrf', new CsrfProtectionMiddleware([ 'httpOnly' => true, ])); $builder->applyMiddleware('csrf');
   //$builder->connect('/pages',['controller'=>'Pages','action'=>'display', 'home']); $builder->connect('/exception/:arg1/:arg2',
      ['controller'=>'Exps','action'=>'index'],
      ['pass' => ['arg1', 'arg2']]);
   $builder->fallbacks();
});

सृजन करना ExpsController.php पर फ़ाइल करें src/Controller/ExpsController.php. नियंत्रक फ़ाइल में निम्न कोड की प्रतिलिपि बनाएँ।

src/Controller/ExpsController.php

<?php
   namespace App\Controller;
   use App\Controller\AppController;
   use Cake\Core\Exception\Exception;
   class ExpsController extends AppController {
      public function index($arg1,$arg2) { try{ $this->set('argument1',$arg1); $this->set('argument2',$arg2); if(($arg1 > 1 || $arg1 > 10) || ($arg2 < 1 || $arg2 > 10)) throw new Exception("One of the number is out of range [1-10]."); } catch(\Exception $ex){
            echo $ex->getMessage();
         }
      }
   }
?>

एक निर्देशिका बनाएँ Exps पर src/Template और उस निर्देशिका के तहत एक बनाएँ Viewindex.php नामक फाइल। उस फ़ाइल में निम्न कोड कॉपी करें।

src/Template/Exps/index.php

This is CakePHP tutorial and this is an example of Passed arguments.
Argument-1: <?=$argument1?><br/> Argument-2: <?=$argument2?><br/>

निम्न URL पर जाकर उपरोक्त उदाहरण देखें।

http: // localhost / cakephp4 / अपवाद / 5/0

उत्पादन

निष्पादन के बाद, आप निम्न आउटपुट प्राप्त करेंगे।

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

लॉगिंग कॉन्फ़िगरेशन

हम लॉग इन फ़ाइल को कॉन्फ़िगर कर सकते हैं config/app.php. फ़ाइल में एक लॉग अनुभाग है, जहां आप लॉगिंग विकल्पों को कॉन्फ़िगर कर सकते हैं जैसा कि निम्नलिखित स्क्रीनशॉट में दिखाया गया है।

डिफ़ॉल्ट रूप से, आपको दो लॉग स्तर दिखाई देंगे - error तथा debugआपके लिए पहले से ही कॉन्फ़िगर है। प्रत्येक संदेश के विभिन्न स्तर को संभालेंगे।

CakePHP विभिन्न लॉगिंग स्तरों का समर्थन करता है जैसा कि नीचे दिखाया गया है -

  • Emergency - सिस्टम अनुपयोगी है

  • Alert - तुरंत कार्रवाई की जानी चाहिए

  • Critical - गंभीर स्थिति

  • Error - त्रुटि की स्थिति

  • Warning - चेतावनी की स्थिति

  • Notice - सामान्य लेकिन महत्वपूर्ण स्थिति

  • Info - सूचनात्मक संदेश

  • Debug - डिबग-स्तरीय संदेश

लॉग फ़ाइल में लेखन

दो तरीके हैं जिनके द्वारा, हम एक लॉग फ़ाइल में लिख सकते हैं।

पहला स्थिर का उपयोग करना है write()तरीका। निम्नलिखित स्थैतिक का वाक्य विन्यास हैwrite() तरीका।

वाक्य - विन्यास लिखना (पूर्णांक | स्ट्रिंग $ स्तर , मिश्रित $ संदेश , स्ट्रिंग | सरणी $ संदर्भ [])
मापदंडों

लिखे जा रहे संदेश की गंभीरता का स्तर। मान एक पूर्णांक या स्ट्रिंग होना चाहिए जो एक ज्ञात स्तर से मेल खाता हो।

लॉग करने के लिए संदेश सामग्री।

संदेश लॉग करने के लिए उपयोग किया जाने वाला अतिरिक्त डेटा। लॉग करने के लिए उपयोग किए जाने वाले लॉग इंजनों को आगे फ़िल्टर करने के लिए विशेष स्कोप कुंजी का उपयोग किया जा सकता है। यदि एक स्ट्रिंग या एक संख्यात्मक सूचकांक सरणी पास की जाती है, तो इसे स्कोप कुंजी के रूप में माना जाएगा। देखCake\Log\Log::config() लॉगिंग स्कोप के बारे में अधिक जानकारी के लिए।

रिटर्न

बूलियन

विवरण

दिए गए संदेश को लिखते हैं और कॉन्फ़िगर किए गए लॉग एडेप्टर में से सभी को टाइप करते हैं। कॉन्फ़िगर किए गए एडेप्टर दोनों पास हैं$level and $संदेश चर। $ स्तर निम्नलिखित तार / मूल्यों में से एक है।

दूसरा उपयोग करना है log() shortcut किसी का उपयोग करके उपलब्ध फ़ंक्शन LogTrait कॉलिंग लॉग () आंतरिक रूप से कॉल करेगा Log::write() -

उदाहरण

में बदलाव करें config/routes.php निम्नलिखित कार्यक्रम में दिखाया गया है।

config/routes.php

<?php
use Cake\Http\Middleware\CsrfProtectionMiddleware;
use Cake\Routing\Route\DashedRoute;
use Cake\Routing\RouteBuilder;
$routes->setRouteClass(DashedRoute::class);
$routes->scope('/', function (RouteBuilder $builder) {
   $builder->registerMiddleware('csrf', new CsrfProtectionMiddleware([ 'httpOnly' => true, ])); $builder->applyMiddleware('csrf');
   //$builder->connect('/pages', ['controller'=>'Pages','action'=>'display', 'home']); $builder->connect('logex',['controller'=>'Logexs','action'=>'index']);
   $builder->fallbacks();
});

बनाओ LogexsController.php पर फ़ाइल करें src/Controller/LogexsController.php. नियंत्रक फ़ाइल में निम्न कोड की प्रतिलिपि बनाएँ।

src/Controller/LogexsController.php

<?php
   namespace App\Controller;
   use App\Controller\AppController;
   use Cake\Log\Log;
   class LogexsController extends AppController{
      public function index(){
         /*The first way to write to log file.*/
         Log::write('debug',"Something didn't work.");
         /*The second way to write to log file.*/
         $this->log("Something didn't work.",'debug');
      }
   }
?>

एक निर्देशिका बनाएँ Logexs पर src/Template और उस निर्देशिका के तहत एक बनाएँ Viewindex.php नामक फाइल। उस फ़ाइल में निम्न कोड कॉपी करें।

src/Template/Logexs/index.php

Something is written in log file. Check log file logs\debug.log

निम्न URL पर जाकर उपरोक्त उदाहरण देखें।

http: // localhost / cakephp4 / logex

उत्पादन

निष्पादन के बाद, आप निम्न आउटपुट प्राप्त करेंगे।

लॉग / debug.log फ़ाइल में लॉग जोड़े जाएंगे -

CakePHP HTML रूपों को आसानी से और सुरक्षित रूप से संभालने के लिए विभिन्न निर्मित टैग प्रदान करता है। कई अन्य PHP रूपरेखाओं की तरह, HTML के प्रमुख तत्व भी CakePHP का उपयोग करके उत्पन्न होते हैं। HTML तत्वों को उत्पन्न करने के लिए उपयोग किए जाने वाले विभिन्न कार्य निम्नलिखित हैं।

निम्नलिखित कार्यों के लिए उपयोग किया जाता है generate select options -

वाक्य - विन्यास _selectOptions (सरणी $ एलिमेंट्रे) () , एरे $ पेरर्सरे () , बूलियन $ शोपर्सेंटनुल , एरे $ एट्रिब्यूटर्स () )
मापदंडों
  • प्रारूप करने के लिए तत्व

  • OPTGROUP के लिए माता-पिता

  • माता-पिता को दिखाना है या नहीं

  • HTML विशेषताएँ

रिटर्न सरणी
विवरण स्वरूपित विकल्प / OPTGROUP तत्वों की एक सरणी देता है

निम्नलिखित कार्यों का उपयोग किया जाता है to generate HTML select element

वाक्य - विन्यास चयन करें (स्ट्रिंग $fieldName, array $विकल्प सरणी (), सरणी $ विशेषताएँ सरणी ())
मापदंडों

चयन का नाम विशेषता

विकल्प तत्वों का सरणी ('मान' => 'पाठ' जोड़े) के रूप में चयनित तत्व में उपयोग किया जाना है।

रिटर्न गठित चयन तत्व।
विवरण एक स्वरूपित चयनित तत्व देता है।

निम्नलिखित कार्यों का उपयोग किया जाता है to generate button HTML पेज पर।

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

बटन (स्ट्रिंग $ शीर्षक, सरणी $ Optionsarray ())

मापदंडों
  • बटन का कैप्शन। स्वचालित रूप से HTML एन्कोडेड नहीं है।

  • विकल्पों और HTML विशेषताओं का सरणी

रिटर्न HTML बटन टैग।
विवरण

बनाता है a <button>टैग। प्रकार विशेषता को डिफॉल्ट करता हैtype="submit"। आप इसे उपयोग करके किसी भिन्न मान में बदल सकते हैं$options['type']

निम्नलिखित कार्यों का उपयोग किया जाता है to generate checkbox HTML पेज पर।

वाक्य - विन्यास चेकबॉक्स (स्ट्रिंग $fieldName, array $विकल्प-पत्र ())
मापदंडों
  • किसी फ़ील्ड का नाम, जैसे "Modelname.fieldname"

  • HTML विशेषताओं का सरणी। संभावित विकल्प मान, चेक किए गए, हिडनफिल्ड, अक्षम, डिफ़ॉल्ट हैं।

रिटर्न एक HTML पाठ इनपुट तत्व।
विवरण एक चेकबॉक्स इनपुट विजेट बनाता है।

निम्नलिखित कार्यों का उपयोग किया जाता है to create form HTML पेज पर।

वाक्य - विन्यास बनाएँ (मिश्रित $ मॉडलनुल , सरणी $ ऑप्शंस्रे () )
मापदंडों
  • वह मॉडल नाम जिसके लिए फ़ॉर्म परिभाषित किया जा रहा है। प्लगइन मॉडल के लिए प्लगइन का नाम शामिल होना चाहिए। उदाहरण के लिए ContactManager.Contact। यदि कोई सरणी पास है और $ विकल्प तर्क रिक्त है, तो सरणी को विकल्प के रूप में उपयोग किया जाएगा। यदि गलत है, तो कोई मॉडल उपयोग नहीं किया जाता है।

  • HTML विशेषताओं और विकल्पों की एक सरणी। संभावित विकल्प टाइप, एक्शन, यूआरएल, डिफॉल्ट, ऑनसुबमिट, इनपुटडिफॉल्ट्स, एन्कोडिंग हैं।

रिटर्न

एक प्रारूपित प्रारूप FORM टैग।

विवरण एक HTML FORM तत्व देता है।

निम्नलिखित कार्यों के लिए उपयोग किया जाता है provide file uploading functionality HTML पेज पर।

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

फ़ाइल (स्ट्रिंग $ फ़ील्डनाम, सरणी $ ऑप्शंसअरे ())

मापदंडों
  • फ़ील्ड का नाम, "Modelname.fieldname" फ़ॉर्म में

  • HTML विशेषताओं का सरणी।

रिटर्न

एक उत्पन्न फ़ाइल इनपुट।

विवरण

फ़ाइल इनपुट विजेट बनाता है।

निम्नलिखित कार्यों का उपयोग बनाने के लिए किया जाता है hidden element HTML पेज पर।

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

छिपा हुआ (स्ट्रिंग $ फ़ील्डनाम , सरणी $ ऑप्शंसअरे () )

मापदंडों
  • एक फ़ील्ड का नाम, "Modelname.fieldname" के रूप में

  • HTML विशेषताओं का सरणी।

रिटर्न

एक उत्पन्न छिपा हुआ इनपुट

विवरण

एक छिपा इनपुट क्षेत्र बनाता है

निम्नलिखित कार्यों का उपयोग उत्पन्न करने के लिए किया जाता है input element HTML पेज पर।

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

इनपुट (स्ट्रिंग $ फ़ील्डनाम, सरणी $ विकल्प सरणी ())

मापदंडों
  • यह "Modelname.fieldname" होना चाहिए

  • प्रत्येक प्रकार का इनपुट अलग-अलग विकल्प लेता है

रिटर्न

पूर्ण रूप विजेट

विवरण

लेबल और आवरण div के साथ पूरा एक फार्म इनपुट तत्व बनाता है

निम्नलिखित कार्यों का उपयोग उत्पन्न करने के लिए किया जाता है radio button HTML पेज पर।

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

Radio (string $ fieldName , array $ optionsarray) ( , सरणी $ विशेषताएँ सार () )

मापदंडों
  • किसी फ़ील्ड का नाम, जैसे "Modelname.fieldname"

  • रेडियो बटन विकल्प सरणी।

  • HTML विशेषताओं का ऐरे, और ऊपर विशेष विशेषताएँ।

रिटर्न पूरा रेडियो विजेट सेट
विवरण रेडियो विगेट्स का एक सेट बनाता है। डिफ़ॉल्ट रूप से एक लेजेंड और फील्डसेट बनाएंगे। इसे नियंत्रित करने के लिए $ विकल्पों का उपयोग करें।

निम्नलिखित कार्यों का उपयोग उत्पन्न करने के लिए किया जाता है submit HTML पेज पर बटन।

वाक्य - विन्यास सबमिट करें (स्ट्रिंग $ कैप्शन नल, सरणी $ विकल्प सरणी ())
मापदंडों
  • बटन पर दिखाई देने वाला लेबल या यदि स्ट्रिंग में शामिल हैं: // या एक्सटेंशन .jpg, .jpe, .jpeg, .gif, .png यदि एक्सटेंशन मौजूद है, तो एक छवि का उपयोग करें, और पहला वर्ण / है, छवि वेबरूट के सापेक्ष है, या यदि पहला वर्ण / नहीं है, तो छवि वेबरोट / img के सापेक्ष है।

  • विकल्पों की सरणी। संभावित विकल्प div हैं, पहले, बाद, प्रकार आदि।

रिटर्न

एक HTML सबमिट बटन

विवरण एक सबमिट बटन तत्व बनाता है। यह विधि $ विकल्पों का उपयोग करके फ़ॉर्म सबमिट करने और रीसेट करने के लिए उपयोग किए जा सकने वाले <इनपुट /> तत्वों को उत्पन्न करेगी। $ कैप्शन के लिए छवि पथ की आपूर्ति करके छवि प्रस्तुतियाँ बनाई जा सकती हैं।

निम्नलिखित कार्यों का उपयोग किया जाता है to generate textarea element HTML पेज पर।

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

Textarea (स्ट्रिंग $ फ़ील्डनाम, सरणी $ विकल्प सरणी ())

मापदंडों
  • फ़ील्ड का नाम, "Modelname.fieldname" फ़ॉर्म में

  • HTML विशेषताओं का ऐरे, भागने का विशेष विकल्प

रिटर्न एक उत्पन्न HTML पाठ इनपुट तत्व
विवरण एक textarea विजेट बनाता है

उदाहरण

में बदलाव करें config/routes.php फ़ाइल को निम्न कोड में दिखाया गया है।

config/routes.php

<?php
use Cake\Http\Middleware\CsrfProtectionMiddleware;
use Cake\Routing\Route\DashedRoute;
use Cake\Routing\RouteBuilder;
$routes->setRouteClass(DashedRoute::class);
$routes->scope('/', function (RouteBuilder $builder) {
   $builder->registerMiddleware('csrf', new CsrfProtectionMiddleware([ 'httpOnly' => true, ])); $builder->applyMiddleware('csrf');
   //$builder->connect('/pages',['controller'=>'Pages','action'=>'display', 'home']); $builder->connect('register',['controller'=>'Registrations','action'=>'index']);
   $builder->fallbacks();
});

बनाओ RegistrationsController.php पर फ़ाइल करें

src/Controller/RegistrationsController.php. नियंत्रक फ़ाइल में निम्न कोड की प्रतिलिपि बनाएँ।

src/Controller/RegistrationsController.php

<?php
   namespace App\Controller;
   use App\Controller\AppController;
   class RegistrationsController extends AppController{
      public function index(){
         $country = array('India','United State of America','United Kingdom');
         $this->set('country',$country);
         $gender = array('Male','Female'); $this->set('gender',$gender);
      }
   }
?>

एक निर्देशिका बनाएँ Registrations पर src/Template और उस निर्देशिका के तहत, एक बनाएँ View फ़ाइल कहा जाता है index.php. उस फ़ाइल में निम्न कोड कॉपी करें।

src/Template/Registrations/index.php

<?php
   echo $this->Form->create(NULL,array('url'=>'/register'));
   echo '<label for="country">Country</label>';
   echo $this->Form->select('country',$country);
   echo '<label for="gender">Gender</label>';
   echo $this->Form->radio('gender ',$gender);
   echo '<label for="address">Address</label>';
   echo $this->Form->textarea('address'); echo $this->Form->file('profilepic');
   echo '<div>'.$this->Form->checkbox('terms'). '<label for="country">Terms ∓ Conditions</label></div>'; echo $this->Form->button('Submit');
   echo $this->Form->end();
?>

निम्न URL पर जाकर उपरोक्त उदाहरण देखें -

http: // localhost / cakephp4 / रजिस्टर

उत्पादन

निष्पादन के बाद, आप निम्न आउटपुट प्राप्त करेंगे।

कई अन्य रूपरेखाओं की तरह, CakePHP भी अंतर्राष्ट्रीयकरण का समर्थन करता है। हमें एकल भाषा से एकाधिक भाषा में जाने के लिए इन चरणों का पालन करने की आवश्यकता है।

चरण 1

एक अलग स्थान बनाएं निर्देशिका संसाधन \locales

चरण 2

निर्देशिका src \ Locale के तहत प्रत्येक भाषा के लिए उपनिर्देशिका बनाएं। उपनिर्देशिका का नाम भाषा का दो अक्षर का आईएसओ कोड या पूर्ण स्थानीय नाम हो सकता है जैसे en_US, fr_FR आदि।

चरण 3

अलग बनाएं default.poप्रत्येक भाषा उपनिर्देशिका के तहत फ़ाइल। इस फ़ाइल में के रूप में प्रविष्टि हैmsgid तथा msgstr, जैसा कि निम्नलिखित कार्यक्रम में दिखाया गया है।

msgid "msg"
msgstr "CakePHP Internationalization example."

यहां ही msgid वह कुंजी है जिसका उपयोग व्यू टेम्प्लेट फ़ाइल में और किया जाएगा msgstr वह मूल्य है जो अनुवाद को संग्रहीत करता है।

चरण 4

देखें टेम्पलेट फ़ाइल में, हम ऊपर का उपयोग कर सकते हैं msgid, जैसा कि नीचे दिखाया गया है, जो स्थानीय के निर्धारित मूल्य के आधार पर अनुवादित किया जाएगा।

<?php echo __('msg'); ?>

डिफ़ॉल्ट लोकेल में सेट किया जा सकता है config/app.php निम्नलिखित लाइन द्वारा फ़ाइल।

'defaultLocale' => env('APP_DEFAULT_LOCALE', 'en_US')

रनटाइम पर स्थानीय को बदलने के लिए, हम निम्नलिखित लाइनों का उपयोग कर सकते हैं।

use Cake\I18n\I18n;
I18n::locale('de_DE');

उदाहरण

निम्न प्रोग्राम में दिखाए गए अनुसार config / path.php फ़ाइल में परिवर्तन करें।

config/routes.php

<?php
use Cake\Http\Middleware\CsrfProtectionMiddleware;
use Cake\Routing\Route\DashedRoute;
use Cake\Routing\RouteBuilder;
$routes->setRouteClass(DashedRoute::class);
$routes->scope('/', function (RouteBuilder $builder) {
   $builder->registerMiddleware('csrf', new CsrfProtectionMiddleware([ 'httpOnly' => true, ])); $builder->applyMiddleware('csrf');
   //$builder->connect('/pages', ['controller'=>'Pages','action'=>'display', 'home']); $builder->connect('locale',
      ['controller'=>'Localizations','action'=>'index']);
   $builder->fallbacks();
});

बनाओ LocalizationsController.php पर फ़ाइल करें src/Controller/LocalizationsController.php. नियंत्रक फ़ाइल में निम्न कोड की प्रतिलिपि बनाएँ।

src/Controller/LocalizationsController.php

<?php
   namespace App\Controller;
   use App\Controller\AppController;
   use Cake\I18n\I18n;
   class LocalizationsController extends AppController {
      public function index() {
         if($this->request->is('post')) {
            $locale = $this->request->getData('locale');
            I18n::setLocale($locale);
         }
      }
   }
?>

बनाओ locales संसाधनों पर निर्देशिका \locales। नामक 3 निर्देशिका बनाएँen_US, fr_FR, de_DEस्थान निर्देशिका के तहत। नामक प्रत्येक निर्देशिका के तहत एक फ़ाइल बनाएँdefault.po. निम्नलिखित कोड को संबंधित फाइल में कॉपी करें।

resources/locales/en_US/default.po

msgid "msg"
msgstr "CakePHP Internationalization example."

resources/locales/fr_FR/default.po

msgid "msg"
msgstr "Exemple CakePHP internationalisation."

resources/locales/de_DE/default.po

msgid "msg"
msgstr "CakePHP Internationalisierung Beispiel."

एक निर्देशिका बनाएँ Localizations पर src/Template और उस निर्देशिका के तहत, एक बनाएँ View फ़ाइल कहा जाता है index.php. उस फ़ाइल में निम्न कोड कॉपी करें।

src/Template/Localizations/index.php

<?php
   echo $this->Form->create(NULL,array('url'=>'/locale'));
   echo $this->Form->radio("locale", [ ['value'=>'en_US','text'=>'English'], ['value'=>'de_DE','text'=>'German'], ['value'=>'fr_FR','text'=>'French'], ] ); echo $this->Form->button('Change Language');
   echo $this->Form->end();
?>
<?php echo __('msg'); ?>

निम्न URL पर जाकर उपरोक्त उदाहरण देखें। http: // localhost / cakephp4 / स्थानीय

उत्पादन

निष्पादन के बाद, आप निम्न आउटपुट प्राप्त करेंगे।

ईमेल

CakePHP ईमेल से संबंधित कार्यात्मकताओं का प्रबंधन करने के लिए ईमेल वर्ग प्रदान करता है। किसी भी कंट्रोलर में ईमेल फंक्शनलिटी का उपयोग करने के लिए, हमें सबसे पहले निम्न लाइन लिखकर ईमेल क्लास को लोड करना होगा।

use Cake\Mailer\Email;

ईमेल वर्ग विभिन्न उपयोगी तरीके प्रदान करता है जो नीचे वर्णित हैं।

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

From (string | array | null $ email null, string | null $ name null)

मापदंडों
  • ईमेल के साथ स्ट्रिंग

  • Name

रिटर्न

सरणी | इस $

विवरण

यह निर्दिष्ट करता है कि किस ईमेल पते से; ईमेल भेजा जाएगा

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

To (string | array | null $ email null, string | null $ name null)

मापदंडों
  • ईमेल के साथ स्ट्रिंग

  • Name

रिटर्न

सरणी | इस $

विवरण

यह निर्दिष्ट करता है कि ईमेल किसे भेजा जाएगा

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

भेजें (स्ट्रिंग | सरणी | शून्य $ सामग्री शून्य)

मापदंडों
  • संदेश के साथ स्ट्रिंग या संदेश के साथ सरणी।

रिटर्न सरणी
विवरण

निर्दिष्ट सामग्री, टेम्पलेट और लेआउट का उपयोग करके एक ईमेल भेजें

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

विषय (स्ट्रिंग | अशक्त $ विषय शून्य)

मापदंडों
  • विषय स्ट्रिंग

रिटर्न

सरणी | इस $

विवरण

विषय प्राप्त / सेट करें

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

अनुलग्नक (स्ट्रिंग | सरणी | शून्य $ अनुलग्नक स्नल)

मापदंडों
  • फ़ाइल नाम या फ़ाइल नाम के साथ सरणी के साथ स्ट्रिंग

रिटर्न

सरणी | इस $

विवरण

ईमेल संदेश में अनुलग्नक जोड़ें

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

Bcc (string | array | null $ email null, string | null $ name null)

मापदंडों
  • ईमेल के साथ स्ट्रिंग

  • Name

रिटर्न

सरणी | इस $

विवरण

गुप्त प्रतिलिपि

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

cc (string | array | null $ email null, string | null $ name null)

मापदंडों
  • ईमेल के साथ स्ट्रिंग

  • Name

रिटर्न

सरणी | इस $

विवरण

प्रतिलिपि

उदाहरण

निम्न प्रोग्राम में दिखाए गए अनुसार config / path.php फ़ाइल में परिवर्तन करें।

config/routes.php

<?php
use Cake\Http\Middleware\CsrfProtectionMiddleware;
use Cake\Routing\Route\DashedRoute;
use Cake\Routing\RouteBuilder;
$routes->setRouteClass(DashedRoute::class); $routes->scope('/', function (RouteBuilder $builder) { $builder->registerMiddleware('csrf', new CsrfProtectionMiddleware([
      'httpOnly' => true,
   ]));
   $builder->applyMiddleware('csrf'); //$builder->connect('/pages',['controller'=>'Pages','action'=>'display', 'home']);
   $builder->connect('/email',['controller'=>'Emails','action'=>'index']); $builder->fallbacks();
});

बनाओ EmailsController.php पर फ़ाइल करें src/Controller/EmailsController.php. नियंत्रक फ़ाइल में निम्न कोड की प्रतिलिपि बनाएँ।

src/Controller/EmailsController.php

<?php
   namespace App\Controller;
   use App\Controller\AppController;
   use Cake\Mailer\Email;
   class EmailsController extends AppController{
      public function index(){
         $email = new Email('default'); $email->to('[email protected]')
            ->subject('About')
            ->send('My message');
      }
   }
?>

एक निर्देशिका बनाएँ Emails पर src/Template और उस निर्देशिका के तहत, देखें नामक एक फ़ाइल बनाएँ index.php. उस फ़ाइल में निम्न कोड कॉपी करें।

src/Template/Emails/index.php

Email Sent.

कोई भी ईमेल भेजने से पहले हमें उसे कॉन्फ़िगर करना होगा। नीचे दिए गए स्क्रीनशॉट में, आप देख सकते हैं कि दो ट्रांसपोर्ट, डिफ़ॉल्ट और जीमेल हैं। हमने जीमेल ट्रांसपोर्ट का इस्तेमाल किया है।

आपको अपने एप्लिकेशन पासवर्ड से "GMAIL USERNAME" को अपने Gmail उपयोगकर्ता नाम और "APP PASSWORD" से बदलना होगा। आपको जीमेल में 2-चरणीय सत्यापन चालू करना होगा और ईमेल भेजने के लिए एक नया एपीपी पासवर्ड बनाना होगा।

config/app.php

निम्नलिखित URL - http: // localhost / cakephp / email पर जाकर उपरोक्त उदाहरण देखें

उत्पादन

निष्पादन के बाद, आप निम्न आउटपुट प्राप्त करेंगे।

सत्र हमें विशिष्ट उपयोगकर्ताओं के लिए विशिष्ट उपयोगकर्ताओं को प्रबंधित करने की अनुमति देता है, और विशिष्ट उपयोगकर्ताओं के लिए डेटा संग्रहीत करता है। सत्र डेटा कहीं भी, कहीं भी पहुंच योग्य हो सकता है, जहां आपके पास ऑब्जेक्ट का अनुरोध करने के लिए पहुंच है, अर्थात, सत्र नियंत्रकों, विचारों, सहायकों, कोशिकाओं और घटकों से सुलभ हैं।

एक्सेसिंग सेशन ऑब्जेक्ट

निम्न कोड को निष्पादित करके सत्र ऑब्जेक्ट बनाया जा सकता है।

$session = $this->request->session();

लेखन सत्र डेटा

सत्र में कुछ लिखने के लिए, हम इसका उपयोग कर सकते हैं write() session तरीका।

Session::write($key, $value)

उपरोक्त विधि दो तर्क देगी, value और यह key जिसके तहत, मूल्य संग्रहीत किया जाएगा।

उदाहरण

$session->write('name', 'Virat Gandhi');

सत्र डेटा पढ़ना

सत्र से संग्रहीत डेटा को पुनः प्राप्त करने के लिए, हम इसका उपयोग कर सकते हैं read() session तरीका।

Session::read($key)

उपरोक्त फ़ंक्शन केवल एक तर्क लेगा, वह है the key of the value,जिसका उपयोग सत्र डेटा लिखने के समय किया गया था। एक बार सही कुंजी प्रदान की गई, तो फ़ंक्शन अपना मान लौटा देगा।

उदाहरण

$session->read('name');

जब आप यह जांचना चाहते हैं कि सत्र में कोई विशेष डेटा मौजूद है या नहीं, तो आप इसका उपयोग कर सकते हैं check() session तरीका।

Session::check($key)

उपरोक्त फ़ंक्शन तर्क के रूप में केवल कुंजी लेगा।

उदाहरण

if ($session->check('name')) {
   // name exists and is not null.
}

सत्र डेटा हटाएं

सत्र से डेटा हटाने के लिए, हम इसका उपयोग कर सकते हैं delete() session डेटा को हटाने के लिए विधि।

Session::delete($key)

उपरोक्त फ़ंक्शन सत्र से हटाए जाने वाले मूल्य की केवल कुंजी लेगा।

उदाहरण

$session->delete('name');

जब आप पढ़ना और फिर सत्र से डेटा हटाना चाहते हैं, तब हम इसका उपयोग कर सकते हैं consume() session तरीका।

static Session::consume($key)

उपरोक्त फ़ंक्शन तर्क के रूप में केवल कुंजी लेगा।

उदाहरण

$session->consume('name');

एक सत्र को नष्ट करना

हमें उपयोगकर्ता सत्र को नष्ट करने की आवश्यकता है, जब उपयोगकर्ता साइट से लॉग आउट करता है और सत्र को नष्ट करने के लिए destroy() विधि का उपयोग किया जाता है।

Session::destroy()

उदाहरण

$session->destroy();

सत्र को नष्ट करने से सर्वर से सभी सत्र डेटा हटा दिए जाएंगे, लेकिन सत्र कुकी को नहीं हटाया जाएगा।

एक सत्र का नवीनीकरण करें

ऐसी स्थिति में, जहां आप उपयोगकर्ता सत्र को नवीनीकृत करना चाहते हैं, तब हम इसका उपयोग कर सकते हैं renew() session तरीका।

Session::renew()

उदाहरण

$session->renew();

पूरा सत्र

में बदलाव करें config/routes.php निम्नलिखित कार्यक्रम में दिखाया गया है।

config/routes.php

<?php
use Cake\Http\Middleware\CsrfProtectionMiddleware;
use Cake\Routing\Route\DashedRoute;
use Cake\Routing\RouteBuilder;
$routes->setRouteClass(DashedRoute::class);
$routes->scope('/', function (RouteBuilder $builder) {
   $builder->registerMiddleware('csrf', new CsrfProtectionMiddleware([ 'httpOnly' => true, ])); $builder->applyMiddleware('csrf');
   //$builder->connect('/pages',['controller'=>'Pages','action'=>'display', 'home']); $builder->connect('/session-object',['controller'=>'Sessions','action'=>'index']);
   $builder->connect('/session-read',['controller'=>'Sessions','action'=>'retrieve_session_data']); $builder->connect('/session-write',['controller'=>'Sessions','action'=> 'write_session_data']);
   $builder->connect('/session-check',['controller'=>'Sessions','action'=>'check_session_data']); $builder->connect('/session-delete',['controller'=>'Sessions','action'=>'delete_session_data']);
   $builder->connect('/session-destroy',['controller'=>'Sessions','action'=>'destroy_session_data']); $builder->fallbacks();
});

बनाओ SessionsController.php पर फ़ाइल करें src/Controller/SessionsController.php. नियंत्रक फ़ाइल में निम्न कोड की प्रतिलिपि बनाएँ

src/Controller/SessionsController.php

<?php
namespace App\Controller;
use App\Controller\AppController;
   class SessionsController extends AppController {
   public function retrieveSessionData() {
      //create session object
      $session = $this->request->getSession();
      //read data from session
      $name = $session->read('name');
      $this->set('name',$name);
   }
   public function writeSessionData(){
      //create session object
      $session = $this->request->getSession();
      //write data in session
      $session->write('name','Virat Gandhi'); } public function checkSessionData(){ //create session object $session = $this->request->getSession(); //check session data $name = $session->check('name'); $address = $session->check('address'); $this->set('name',$name); $this->set('address',$address); } public function deleteSessionData(){ //create session object $session = $this->request->getSession(); //delete session data $session->delete('name');
   }
   public function destroySessionData(){
      //create session object
      $session = $this->request->getSession();
      //destroy session
      $session->destroy();
   }
}
?>

एक निर्देशिका बनाएँ Sessions पर src/Template और उस निर्देशिका के तहत एक बनाएँ View फ़ाइल कहा जाता है write_session_data.php. उस फ़ाइल में निम्न कोड कॉपी करें।

src/Template/Sessions/write_session_data.php

The data has been written in session.

दूसरा बनाओ View फ़ाइल कहा जाता है retrieve_session_data.php उसी के तहत Sessions निर्देशिका और उस फ़ाइल में निम्न कोड की प्रतिलिपि बनाएँ।

src/Template/Sessions/retrieve_session_data.php

Here is the data from session.
Name: <?=$name;?>

दूसरा बनाओ View फ़ाइल कहा जाता है check_session_data.ctp उसी सत्र निर्देशिका के तहत और उस फ़ाइल में निम्न कोड कॉपी करें।

src/Template/Sessions/check_session_data.ctp

<?php if($name): ?> name exists in the session. <?php else: ?> name doesn't exist in the database <?php endif;?> <?php if($address): ?>
address exists in the session.
<?php else: ?>
address doesn't exist in the database
<?php endif;?>

दूसरा बनाओ View फ़ाइल कहा जाता है delete_session_data.ctp, उसी सत्र निर्देशिका के तहत और उस फ़ाइल में निम्न कोड कॉपी करें।

src/Template/Sessions/delete_session_data.ctp

Data deleted from session.

दूसरा बनाओ View फ़ाइल कहा जाता है destroy_session_data.ctp, उसी सत्र निर्देशिका के तहत और उस फ़ाइल में निम्न कोड कॉपी करें।

src/Template/Sessions/destroy_session_data.ctp

Session Destroyed.

उत्पादन

निम्न URL पर जाकर उपरोक्त उदाहरण देखें। यह URL आपको सत्र में डेटा लिखने में मदद करेगा।

http: // localhost / cakephp4 / सत्र-लिखने

निम्नलिखित URL पर जाएं to read session data − http://localhost/cakephp4/session-read

निम्नलिखित URL पर जाएं to check session data - http: // localhost / cakephp4 / session-check

निम्नलिखित URL पर जाएं to delete session data - http: // localhost / cakephp4 / session-delete पर जाएँ

निम्नलिखित URL पर जाएं to destroy session data - http: // localhost / cakephp4 / session-नष्ट

CakePHP के साथ कुकी को संभालना आसान और सुरक्षित है। एक CookComComponent क्लास है जिसका उपयोग कुकी के प्रबंधन के लिए किया जाता है। वर्ग कुकीज़ के साथ काम करने के लिए कई तरीके प्रदान करता है।

कुकीज़ के साथ काम करने के लिए, इस 2 वर्गों को अपने नियंत्रक में जोड़ें -

use Cake\Http\Cookie\Cookie;
use Cake\Http\Cookie\CookieCollection;

कुकी को पंजीकृत करने के लिए सबसे पहले कुकी ऑब्जेक्ट बनाना होगा।

$cookie = new Cookie(name,value,expiration time,path,domain);

नाम और मूल्य अनिवार्य हैं और अन्य वैकल्पिक परम हैं।

कुकी लिखें

कुकी लिखने के लिए वाक्य रचना निम्नलिखित है।

$cookie = new Cookie(name,value,expiration time,path,domain);

कुकी को कुकी में जोड़ा जाना चाहिए क्योंकि नीचे दिखाया गया है -

$cookie = new Cookie('name','XYZ'); $cookies = new CookieCollection([$cookie]);

यदि कुकी संग्रह ऑब्जेक्ट पहले से ही बनाया गया है, तो शेष कुकीज़ को नीचे दिखाए अनुसार जोड़ा जा सकता है -

$cookies = $cookies->add($cookie);

कुकी पढ़ें

कुकी को पढ़ने के लिए कुकी से प्राप्त विधि () विधि का उपयोग करें।

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

पढ़ने के लिए सिंटैक्स इस प्रकार है -

Cake\Http\Cookie\CookieCollection::get($name)

यह आपको cookiecollection Interface लौटा देगा, कुकी का मान पाने के लिए, आपको getValue () विधि को कॉल करना होगा।

Cake\Http\Cookie\CookieCollection Interface::getValue()

कुकी की जाँच करें

has() कुकी से विधि, आपको बताएगी कि कुकी मौजूद है या नहीं।

Cake\Http\Cookie\CookieCollection::has($name)

उदाहरण

echo $isPresent = $this->cookies->has('name');

कुकी को हटा दें

remove()कुकी को हटाने के लिए विधि का उपयोग किया जाता है। निम्नलिखित निकालें () विधि का वाक्यविन्यास है।

Cake\Http\Cookie\CookieCollection::remove($name)

हटाने () विधि को हटाने के लिए एक तर्क, कुकी चर ($ नाम) का नाम लगेगा।

उदाहरण 1

$test = $this->cookies->remove('name');

उदाहरण 2

निम्न प्रोग्राम में दिखाए गए अनुसार config / path.php फ़ाइल में परिवर्तन करें।

config/routes.php

<?php
use Cake\Http\Middleware\CsrfProtectionMiddleware;
use Cake\Routing\Route\DashedRoute;
use Cake\Routing\RouteBuilder;
$routes->setRouteClass(DashedRoute::class); $routes->scope('/', function (RouteBuilder $builder) { $builder->registerMiddleware('csrf', new CsrfProtectionMiddleware([
      'httpOnly' => true,
   ]));
   $builder->applyMiddleware('csrf'); //$builder->connect('/pages',['controller'=>'Pages','action'=>'display', 'home']);
   $builder->connect('cookie/testcookies',['controller'=>'Cookies','action'=>'testCookies']); $builder->fallbacks();
});

बनाओ CookiesController.php पर फ़ाइल करें src/Controller/CookiesController.php. नियंत्रक फ़ाइल में निम्न कोड की प्रतिलिपि बनाएँ।

src/Controller/Cookies/CookiesController.php

<?php
   namespace App\Controller;
   use App\Controller\AppController;
   use Cake\Http\Cookie\Cookie;
   use Cake\Http\Cookie\CookieCollection;
   class CookiesController extends AppController{
      public $cookies; public function testCookies() { $cookie = new Cookie('name','XYZ');
         $this->cookies = new CookieCollection([$cookie]);
         $cookie_val = $this->cookies->get('name');
         $this->set('cookie_val',$cookie_val->getValue());
         $isPresent = $this->cookies->has('name');
         $this->set('isPresent',$isPresent);
         $this->set('count', $this->cookies->count());
         $test = $this->cookies->remove('name');
         $this->set('count_afterdelete', $test->count());
      }
   }
?>

एक निर्देशिका बनाएँ Cookies पर src/Template और उस निर्देशिका के तहत एक बनाएँ View फ़ाइल कहा जाता है test_cookies.php. उस फ़ाइल में निम्न कोड कॉपी करें।

src/Template/Cookie/test_cookies.php

The value of the cookie is: <?php echo $cookie_val; ?> <br/> <?php if($isPresent):
?>
The cookie is present.
<?php
   else:
?>
The cookie isn't present.
<?php
   endif;
?>
<br/>
<?php
   echo "The count of cookie before delete is :" .$count; ?> <br/> <?php echo "The count of cookie after delete is :" .$count_afterdelete;
?>

उत्पादन

निम्नलिखित URL पर जाकर उपरोक्त उदाहरण देखें - http: // localhost / cakephp4 / कुकी / testcookies

वेब एप्लिकेशन बनाते समय सुरक्षा एक अन्य महत्वपूर्ण विशेषता है। यह वेबसाइट के उपयोगकर्ताओं को आश्वस्त करता है कि, उनका डेटा सुरक्षित है। CakePHP आपके एप्लिकेशन को सुरक्षित करने के लिए कुछ उपकरण प्रदान करता है।

एन्क्रिप्शन और डिक्रिप्शन

CakePHP में सुरक्षा लाइब्रेरी के तरीके प्रदान करते हैं, जिसके द्वारा हम डेटा एन्क्रिप्ट और डिक्रिप्ट कर सकते हैं। निम्नलिखित दो विधियाँ हैं, जिनका उपयोग उसी उद्देश्य के लिए किया जाता है।

static Cake\Utility\Security::encrypt($text, $key, $hmacSalt = null) static Cake\Utility\Security::decrypt($cipher, $key, $hmacSalt = null)

एन्क्रिप्टिंग विधि पाठ और कुंजी को डेटा एन्क्रिप्ट करने के तर्क के रूप में ले जाएगी और वापसी मूल्य एचएमएसी चेकसम के साथ एन्क्रिप्टेड मूल्य होगा।

एक डेटा हैश करने के लिए, hash()विधि का उपयोग किया जाता है। निम्नलिखित हैश () विधि का वाक्य विन्यास है।

static Cake\Utility\Security::hash($string, $type = NULL, $salt = false)

CSRF

CSRF का मतलब है Cross Site Request Forgery। CSRF घटक सक्षम करके, आपको हमलों से सुरक्षा मिलती है। CSRF वेब अनुप्रयोगों में एक आम भेद्यता है।

यह एक हमलावर को पिछले अनुरोध पर कब्जा करने और फिर से खेलना करने की अनुमति देता है, और कभी-कभी अन्य डोमेन पर छवि टैग या संसाधनों का उपयोग करके डेटा अनुरोध सबमिट करता है। CSRF को केवल जोड़कर सक्षम किया जा सकता हैCsrfComponent अपने घटकों के सरणी के रूप में नीचे दिखाया गया है -

public function initialize(): void {
   parent::initialize();
   $this->loadComponent('Csrf');
}

CsrfComponent के साथ मूल एकीकृत करता है FormHelper। हर बार जब आप फॉर्महेल्पर के साथ एक फॉर्म बनाते हैं, तो यह एक छिपे हुए फ़ील्ड को सम्मिलित करेगा जिसमें CSRF टोकन होगा।

हालांकि यह अनुशंसित नहीं है, आप कुछ अनुरोधों पर CsrfComponent को अक्षम करना चाह सकते हैं। आप नियंत्रक के घटना प्रेषण का उपयोग करके ऐसा कर सकते हैं, के दौरानbeforeFilter() तरीका।

public function beforeFilter(Event $event) { $this->eventManager()->off($this->Csrf);
}

सुरक्षा घटक

सिक्योरिटी कंपोनेंट आपके आवेदन के लिए सख्त सुरक्षा लागू करता है। यह विभिन्न कार्यों के लिए तरीके प्रदान करता है जैसे -

  • Restricting which HTTP methods your application accepts- साइड इफेक्ट्स को निष्पादित करने से पहले, आपको हमेशा HTTP विधि को सत्यापित करना चाहिए। आपको HTTP विधि या जाँच का उपयोग करना चाहिएCake\Network\Request::allowMethod() सुनिश्चित करने के लिए सही HTTP विधि का उपयोग किया जाता है।

  • Form tampering protection- डिफ़ॉल्ट रूप से, SecurityComponent उपयोगकर्ताओं को विशिष्ट तरीकों से फ़ॉर्म के साथ छेड़छाड़ करने से रोकता है। SecurityComponent निम्नलिखित चीज़ों को रोकेगा -

    • अज्ञात फ़ील्ड्स को प्रपत्र में नहीं जोड़ा जा सकता है।

    • फ़ील्ड को प्रपत्र से हटाया नहीं जा सकता।

    • छिपे हुए इनपुट में मानों को संशोधित नहीं किया जा सकता है।

  • Requiring that SSL be used - SSL की आवश्यकता के लिए सभी क्रियाएं- सुरक्षित

  • Limiting cross controller communication- हम प्रतिबंधित कर सकते हैं कि कौन सा नियंत्रक इस नियंत्रक को अनुरोध भेज सकता है। हम यह भी प्रतिबंधित कर सकते हैं कि कौन सी क्रियाएं इस नियंत्रक की कार्रवाई के लिए अनुरोध भेज सकती हैं।

उदाहरण

में बदलाव करें config/routes.php निम्नलिखित कार्यक्रम में दिखाया गया है।

config/routes.php

<?php
use Cake\Http\Middleware\CsrfProtectionMiddleware;
use Cake\Routing\Route\DashedRoute;
use Cake\Routing\RouteBuilder;
$routes->setRouteClass(DashedRoute::class);
$routes->scope('/', function (RouteBuilder $builder) {
   $builder->registerMiddleware('csrf', new CsrfProtectionMiddleware([ 'httpOnly' => true, ])); $builder->applyMiddleware('csrf');
   //$builder->connect('/pages', ['controller'=>'Pages','action'=>'display', 'home']); $builder->connect('login',['controller'=>'Logins','action'=>'index']);
   $builder->fallbacks();
});

बनाओ LoginsController.php पर फ़ाइल करें src/Controller/LoginsController.php. नियंत्रक फ़ाइल में निम्न कोड की प्रतिलिपि बनाएँ।

src/Controller/LoginsController.php

<?php
   namespace App\Controller;
   use App\Controller\AppController;
   class LoginsController extends AppController {
      public function initialize() : void {
         parent::initialize();
         $this->loadComponent('Security');
      }
         public function index(){
      }
   }
?>

एक निर्देशिका बनाएँ Logins पर src/Template और उस निर्देशिका के तहत एक बनाएँ Viewindex.php नामक फाइल। उस फ़ाइल में निम्न कोड कॉपी करें।

src/Template/Logins/index.php

<?php
   echo $this->Form->create(NULL,array('url'=>'/login')); echo $this->Form->control('username');
   echo $this->Form->control('password'); echo $this->Form->button('Submit');
   echo $this->Form->end();
?>

निम्नलिखित URL - http: // localhost / cakephp4 / login पर जाकर उपरोक्त उदाहरण देखें

उत्पादन

निष्पादन के बाद, आप निम्न आउटपुट प्राप्त करेंगे।

अक्सर वेबसाइट बनाते समय, हमें डेटा को संसाधित करने से पहले कुछ चीजों को मान्य करना होगा। CakePHP सत्यापन पैकेज प्रदान करता है, सत्यापनकर्ताओं का निर्माण करता है जो आसानी से डेटा को मान्य कर सकते हैं।

मान्यता विधियाँ

केकपीएचपी वैलिडेशन क्लास में विभिन्न सत्यापन के तरीके प्रदान करता है। उनमें से कुछ सबसे लोकप्रिय नीचे सूचीबद्ध हैं।

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

जोड़ें (स्ट्रिंग $ फ़ील्ड, सरणी | स्ट्रिंग $name, array|Cake\Validation\ValidationRule $नियम [])

मापदंडों
  • उस फ़ील्ड का नाम जिसमें से नियम जोड़ा जाएगा।

  • एकल नियम या एकाधिक नियम सरणी के लिए उपनाम।

  • जोड़ने का नियम

रिटर्न

इस $

विवरण

फ़ील्ड के नियम सेट में एक नया नियम जोड़ता है। यदि दूसरा तर्क एक सरणी है, तो फ़ील्ड के लिए नियम सूची को दूसरे तर्क से बदल दिया जाएगा और तीसरे तर्क को अनदेखा किया जाएगा।

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

allowEmpty (स्ट्रिंग $ फ़ील्ड , बूलियन | स्ट्रिंग | कॉल करने योग्य $ जब सत्य, स्ट्रिंग | शून्य $ संदेश शून्य)

मापदंडों
  • क्षेत्र का नाम।

  • इंगित करता है कि जब क्षेत्र खाली होने की अनुमति है। मान्य मूल्य हैंtrue (always), 'create', 'update'। यदि कोई कॉल करने योग्य पास किया जाता है, तो कॉलबैक के सही होने पर ही फ़ील्ड खाली रह जाएगी।

  • क्षेत्र नहीं है, तो दिखाने के लिए संदेश।

रिटर्न इस $
विवरण

किसी फ़ील्ड को खाली करने देता है।

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

अल्फ़ान्यूमेरिक (स्ट्रिंग $ फ़ील्ड , स्ट्रिंग | null $ मैसेज null, string | callable | null $ जब null

मापदंडों
  • जिस क्षेत्र में आप नियम लागू करना चाहते हैं।

  • नियम विफल होने पर त्रुटि संदेश।

  • या तो 'बनाएँ' या 'अपडेट' या एक कॉल करने योग्य जो सत्यापन नियम लागू होने पर सच हो जाता है।

रिटर्न

इस $

विवरण

किसी क्षेत्र में एक अल्फ़ान्यूमेरिक नियम जोड़ें।

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

क्रेडिट कार्ड (स्ट्रिंग $ फ़ील्ड , स्ट्रिंग $ प्रकार 'सब', स्ट्रिंग | शून्य $ संदेश अशक्त, स्ट्रिंग | कॉल करने योग्य | अशक्त $ जब शून्य)

मापदंडों
  • जिस क्षेत्र में आप नियम लागू करना चाहते हैं।

  • कार्ड के प्रकार जिसे आप अनुमति देना चाहते हैं। 'सभी' के लिए चूक। आप स्वीकृत कार्ड प्रकारों की एक सरणी भी प्रदान कर सकते हैं, उदाहरण के लिए, ['मास्टरकार्ड', 'वीजा', 'एमेक्स']।

  • नियम विफल होने पर त्रुटि संदेश।

  • या तो 'बनाएँ' या 'अपडेट' या एक कॉल करने योग्य जो सत्यता लौटाता है, जब सत्यापन नियम लागू किया जाना चाहिए।

रिटर्न

इस $

विवरण

किसी फ़ील्ड में क्रेडिट कार्ड नियम जोड़ें।

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

ईमेल (स्ट्रिंग $ फ़ील्ड, बूलियन $ checkMX झूठी, स्ट्रिंग | अशक्त $ संदेश अशक्त, स्ट्रिंग | कॉल करने योग्य | अशक्त, $ जब अशक्त)

मापदंडों
  • जिस क्षेत्र में आप नियम लागू करना चाहते हैं।

  • एमएक्स रिकॉर्ड की जांच करें या नहीं।

  • नियम विफल होने पर त्रुटि संदेश।

  • या तो 'बनाएँ' या 'अपडेट' या एक कॉल करने योग्य जो सत्यता लौटाता है, जब सत्यापन नियम लागू किया जाना चाहिए।

रिटर्न

इस $

विवरण

किसी फ़ील्ड में ईमेल सत्यापन नियम जोड़ें।

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

maxLength (स्ट्रिंग $ फ़ील्ड , पूर्णांक $ अधिकतम , स्ट्रिंग | नल $ संदेश अशक्त, स्ट्रिंग | कॉल करने योग्य | अशक्त $ जब सुस्त)

मापदंडों
  • जिस क्षेत्र में आप नियम लागू करना चाहते हैं।

  • अधिकतम लंबाई की अनुमति दी।

  • नियम विफल होने पर त्रुटि संदेश।

  • भी 'create' या 'update' या ए callable जब सत्यापन नियम लागू किया जाना चाहिए तो यह सही है।

रिटर्न

इस $

विवरण

किसी फ़ील्ड में स्ट्रिंग लंबाई सत्यापन नियम जोड़ें।

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

minLength (स्ट्रिंग $ क्षेत्र , पूर्णांक $ मिनट , स्ट्रिंग | अशक्त $ संदेश अशक्त, स्ट्रिंग | कॉल करने योग्य | अशक्त $ जब सुस्त)

मापदंडों
  • जिस क्षेत्र में आप नियम लागू करना चाहते हैं।

  • अधिकतम लंबाई की अनुमति दी।

  • नियम विफल होने पर त्रुटि संदेश।

  • भी 'create' या 'update' या ए callable, जब सत्यापन नियम लागू किया जाना चाहिए, तो यह सही है।

रिटर्न

इस $

विवरण

किसी फ़ील्ड में स्ट्रिंग लंबाई सत्यापन नियम जोड़ें।

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

notBlank (स्ट्रिंग $ फ़ील्ड , स्ट्रिंग | नल $ संदेश अशक्त, स्ट्रिंग | कॉल करने योग्य | अशक्त $ जब शून्य)

मापदंडों
  • जिस क्षेत्र में आप नियम लागू करना चाहते हैं।

  • नियम विफल होने पर त्रुटि संदेश।

  • भी 'create' या 'update' या ए callable जब सत्यापन नियम लागू किया जाना चाहिए तो यह सही है।

रिटर्न

इस $

विवरण

एक फ़ील्ड में एक नोटबैंक नियम जोड़ें।

नियंत्रक में निम्नलिखित दो पंक्तियों को जोड़कर सत्यापनकर्ता बनाया जा सकता है।

use Cake\Validation\Validator;
$validator = new Validator();

डेटा को मान्य करना

एक बार, हमने सत्यापनकर्ता बना लिया है, हम डेटा को मान्य करने के लिए सत्यापनकर्ता वस्तु का उपयोग कर सकते हैं। निम्नलिखित कोड बताता है, हम लॉगिन वेबपेज के लिए डेटा को कैसे मान्य कर सकते हैं।

$validator->notEmpty('username', 'We need username.')->add( 'username', 'validFormat', ['rule' => 'email','message' => 'E-mail must be valid']); $validator->notEmpty('password', 'We need password.');
$errors = $validator->errors($this->request->data());

$ सत्यापनकर्ता ऑब्जेक्ट का उपयोग करते हुए, हमने पहले कॉल किया है notEmpty()विधि, जो यह सुनिश्चित करेगी कि उपयोगकर्ता नाम रिक्त नहीं होना चाहिए। उसके बाद, हम जंजीर हैadd() उचित ईमेल प्रारूप के लिए एक और सत्यापन जोड़ने की विधि।

उसके बाद हमने notEmpty () पद्धति के साथ पासवर्ड फ़ील्ड के लिए सत्यापन जोड़ा है, जो पुष्टि करेगा कि पासवर्ड फ़ील्ड खाली नहीं होनी चाहिए।

उदाहरण

निम्न प्रोग्राम में दिखाए गए अनुसार config / मार्गों में परिवर्तन करें।

config/routes.php

<?php
use Cake\Http\Middleware\CsrfProtectionMiddleware;
use Cake\Routing\Route\DashedRoute;
use Cake\Routing\RouteBuilder;
$routes->setRouteClass(DashedRoute::class); $routes->scope('/', function (RouteBuilder $builder) { $builder->registerMiddleware('csrf', new CsrfProtectionMiddleware([
      'httpOnly' => true,
   ]));
   $builder->applyMiddleware('csrf'); //$builder->connect('/pages',['controller'=>'Pages','action'=>'display', 'home']);
   $builder->connect('validation',['controller'=>'Valids','action'=>'index']); $builder->fallbacks();
});

बनाओ ValidsController.php पर फ़ाइल करें src/Controller/ValidsController.php. नियंत्रक फ़ाइल में निम्न कोड की प्रतिलिपि बनाएँ।

src/Controller/ValidsController.php

<?php
   namespace App\Controller;
   use App\Controller\AppController;
   use Cake\Validation\Validator;
   class ValidsController extends AppController{
      public function index(){
         $validator = new Validator(); $validator->notEmpty('username', 'We need username.')->add(
            'username', 'validFormat', ['rule' => 'email','message' => 'E-mail must be valid']);
         $validator->notEmpty('password', 'We need password.'); $errors = $validator->errors($this->request->getData());
         $this->set('errors',$errors);
      }
   }
?>

एक निर्देशिका बनाएँ Valids पर src/Template और उस निर्देशिका के तहत एक बनाएँ View फ़ाइल कहा जाता है index.php. उस फ़ाइल में निम्न कोड कॉपी करें।

src/Template/Valids/index.php

<?php
   if($errors) { foreach($errors as $error) foreach($error as $msg) echo '<font color="red">'.$msg.'</font><br>';
   } else {
      echo "No errors.";
   }
   echo $this->Form->create(NULL,array('url'=>'/validation')); echo $this->Form->control('username');
   echo $this->Form->control('password'); echo $this->Form->button('Submit');
   echo $this->Form->end();
?>

निम्न URL पर जाकर उपरोक्त उदाहरण देखें -

http: // localhost / cakephp4 / सत्यापन

उत्पादन

बिना कुछ दर्ज किए सबमिट बटन पर क्लिक करें। आपको निम्न आउटपुट प्राप्त होगा।

Http - क्लाइंट

Http क्लाइंट का उपयोग GET, POST, PUT आदि जैसे अनुरोध करने के लिए किया जा सकता है।

Http क्लाइंट के साथ काम करने के लिए, निम्नलिखित जोड़ें -

use Cake\Http\Client;

HTTP क्लाइंट के काम को समझने के लिए उदाहरण पर काम करते हैं।

HTTP GET विधि

Http url से डेटा प्राप्त करने के लिए, आप निम्नानुसार कर सकते हैं -

$response = $http->get('https://jsonplaceholder.typicode.com/users');

मामले में, आपको कुछ क्वेरी पैरामेट्स पारित करने की आवश्यकता है, उन्हें निम्नानुसार पारित किया जा सकता है -

$response = $http->get('https://jsonplaceholder.typicode.com/users', ["id", 1]);

प्रतिक्रिया प्राप्त करने के लिए, आप निम्नानुसार कर सकते हैं -

के लिये normal text data -

$response->getBody();

के लिये Json -

$response->getJson();

के लिये Xml -

$response->getXml()

उदाहरण

निम्न प्रोग्राम में दिखाए गए अनुसार config / मार्गों में परिवर्तन करें।

config/routes.php

<?php
use Cake\Http\Middleware\CsrfProtectionMiddleware;
use Cake\Routing\Route\DashedRoute;
use Cake\Routing\RouteBuilder;
$routes->setRouteClass(DashedRoute::class); $routes->scope('/', function (RouteBuilder $builder) { $builder->registerMiddleware('csrf', new CsrfProtectionMiddleware([
      'httpOnly' => true,
   ]));
   $builder->applyMiddleware('csrf'); //$builder->connect('/pages',['controller'=>'Pages','action'=>'display', 'home']);
   $builder->connect('getData',['controller'=>'Requests','action'=>'index']); $builder->fallbacks();
});

बनाओ RequestsController.php पर फ़ाइल करें src/Controller/RequestsController.php. नियंत्रक फ़ाइल में निम्न कोड की प्रतिलिपि बनाएँ।

src/Controller/RequestsController.php

<?php
   namespace App\Controller;
   use App\Controller\AppController;
   use Cake\Http\Client;
   class RequestsController extends AppController{
      public function index(){
         $http = new Client(); $response = $http->get('https://jsonplaceholder.typicode.com/users'); $stream = $response->getJson(); $this->set('response',$stream);
      }
   }
?>

एक निर्देशिका बनाएँ Requests पर src/Template और उस निर्देशिका के तहत एक बनाएँ View फ़ाइल कहा जाता है index.php. उस फ़ाइल में निम्न कोड कॉपी करें।

src/Template/Requests/index.php

<h3>All Users from url : https://jsonplaceholder.typicode.com/users</h3>
<?php
   if($response) {
      foreach($response as $res => $val) { echo '<font color="gray">Name: '.$val["name"].' Email -'.$val["email"].'</font><br>';
      }
   }
?>

निम्न URL पर जाकर उपरोक्त उदाहरण देखें -

http://localhost/cakephp4/getData

उत्पादन

बिना कुछ दर्ज किए सबमिट बटन पर क्लिक करें। आपको निम्न आउटपुट प्राप्त होगा।

HTTP POST विधि

पोस्ट के साथ काम करने के लिए, आपको $ http क्लाइंट को निम्नानुसार कॉल करना होगा -

$response = $http->post('yoururl', data);

आइए हम एक उदाहरण देखें।

उदाहरण

निम्न प्रोग्राम में दिखाए गए अनुसार config / मार्गों में परिवर्तन करें।

config/routes.php

<?php
use Cake\Http\Middleware\CsrfProtectionMiddleware;
use Cake\Routing\Route\DashedRoute;
use Cake\Routing\RouteBuilder;
$routes->setRouteClass(DashedRoute::class); $routes->scope('/', function (RouteBuilder $builder) { $builder->registerMiddleware('csrf', new CsrfProtectionMiddleware([
      'httpOnly' => true,
   ]));
   $builder->applyMiddleware('csrf'); //$builder->connect('/pages',['controller'=>'Pages','action'=>'display', 'home']);
   $builder->connect('postData',['controller'=>'Requests','action'=>'index']); $builder->fallbacks();
});

बनाओ RequestsController.php पर फ़ाइल करें src/Controller/RequestsController.php.नियंत्रक फ़ाइल में निम्न कोड की प्रतिलिपि बनाएँ। अगर पहले से बना है तो अनदेखा करें।

src/Controller/RequestsController.php

<?php
   namespace App\Controller;
   use App\Controller\AppController;
   use Cake\Http\Client;
   class RequestsController extends AppController{
      public function index(){
         $http = new Client(); $response = $http->post('https://postman-echo.com/post', [
            'name'=> 'ABC',
            'email' => '[email protected]'
         ]);
      }
   }
?>

एक निर्देशिका बनाएँ Requests पर src/Template और उस निर्देशिका के तहत एक बनाएँ Viewindex.php नामक फाइल। उस फ़ाइल में निम्न कोड कॉपी करें।

src/Template/Requests/index.php

<h3>Testing Post Method</h3>

निम्न URL पर जाकर उपरोक्त उदाहरण देखें -

http: // localhost / cakephp4 / POSTDATA

उत्पादन

नीचे दिए गए कोड का उत्पादन है -

इसी तरह, आप PUT विधि के लिए प्रयास कर सकते हैं।

$http = new Client();
$response = $http->put('https://postman-echo.com/post', [
   'name'=> 'ABC',
   'email' => '[email protected]'
]);

यदि हम डेटा का एक सेट दिखाना चाहते हैं जो बहुत बड़ा है, तो हम पृष्ठांकन का उपयोग कर सकते हैं और यह सुविधा केक php 4 के साथ उपलब्ध है, जिसका उपयोग करना बहुत आसान है।

हमारे पास डेटा के साथ "लेख" शीर्षक वाली एक तालिका है -

पेजों के रूप में डेटा को प्रदर्शित करने के लिए पेजिंग का उपयोग करते हैं, बजाय सभी को एक साथ दिखाने के।

उदाहरण

निम्न प्रोग्राम में दिखाए गए अनुसार config / मार्गों में परिवर्तन करें।

config / routes.php

<?php
use Cake\Http\Middleware\CsrfProtectionMiddleware;
use Cake\Routing\Route\DashedRoute;
use Cake\Routing\RouteBuilder;
$routes->setRouteClass(DashedRoute::class); $routes->scope('/', function (RouteBuilder $builder) { $builder->registerMiddleware('csrf', new CsrfProtectionMiddleware([
      'httpOnly' => true,
   ]));
   $builder->applyMiddleware('csrf'); //$builder->connect('/pages',['controller'=>'Pages','action'=>'display', 'home']);
   $builder->connect('posts',['controller'=>'Posts','action'=>'index']); $builder->fallbacks();
});

बनाओ PostsController.php पर फ़ाइल करें src/Controller/PostsController.php.नियंत्रक फ़ाइल में निम्न कोड की प्रतिलिपि बनाएँ। पहले से निर्मित है, तो अनदेखा करें।

src / नियंत्रक / PostsController.php

<?php
   namespace App\Controller;
   use App\Controller\AppController;
   class PostsController extends AppController {
      public function index(){
         $this->loadModel('articles'); $articles = $this->articles->find('all')->order(['articles.id ASC']); $this->set('articles', $this->paginate($articles, ['limit'=> '3']));
      }
   }
?>

लेख तालिका के डेटा का उपयोग किया जाता है -

$this->loadModel('articles'); $articles = $this->articles->find('all')->order(['articles.id ASC']);

पेजिनेशन लागू करने के लिए और हम 3 रिकॉर्ड्स के साथ डेटा दिखाएंगे और निम्नानुसार किया जाएगा -

$this->set('articles', $this->paginate($articles, ['limit'=> '3']));

यह लेख तालिकाओं पर पृष्ठांकन सक्रिय करने के लिए पर्याप्त है ।

एक निर्देशिका बनाएँ Posts पर src/Template और उस निर्देशिका के तहत एक बनाएँ Viewindex.php नामक फाइल। उस फ़ाइल में निम्न कोड कॉपी करें।

src / खाका / पोस्ट / index.php

<div>
<?php foreach ($articles as $key=>$article) {?> <a href="#"> <div> <p><?= $article->title ?> </p>
   <p><?= $article->details ?></p> </div> </a> <br/> <?php } ?> <ul class="pagination"> <?= $this->Paginator->prev("<<") ?>
<?= $this->Paginator->numbers() ?> <?= $this->Paginator->next(">>") ?>
</ul>
</div>

पृष्ठों की सूची के लिए अंकन निम्नानुसार किया जाता है -

<ul class="pagination">
<?= $this->Paginator->prev("<<") ?> <?= $this->Paginator->numbers() ?>
<?= $this->Paginator->next(">>") ?>
</ul>

निम्न URL पर जाकर उपरोक्त उदाहरण देखें -

http: // localhost / cakephp4 / पदों

उत्पादन

जब आप कोड चलाते हैं, तो आपको निम्न आउटपुट दिखाई देंगे -

नीचे दिए गए नंबरों पर क्लिक करें, अगले पृष्ठ पर जाने के लिए, या अगले या पिछले बटन का उपयोग करें।

For example

आप उस पृष्ठ = 2 को ब्राउज़र में पृष्ठ url से जोड़कर देखेंगे।

Cakephp4 में दिनांक और समय के साथ काम करने के लिए, हम उपलब्ध फ्रोजनटाइम वर्ग का उपयोग करने जा रहे हैं।

दिनांक और समय के साथ काम करने के लिए, अपने नियंत्रक में कक्षा को शामिल करें

use Cake\I18n\FrozenTime;

जमीनी स्तर का उपयोग करते हुए, उदाहरण और प्रदर्शन तिथि और समय पर काम करते हैं।

उदाहरण

निम्न प्रोग्राम में दिखाए गए अनुसार config / मार्गों में परिवर्तन करें।

config / routes.php

<?php
use Cake\Http\Middleware\CsrfProtectionMiddleware;
use Cake\Routing\Route\DashedRoute;
use Cake\Routing\RouteBuilder;
$routes->setRouteClass(DashedRoute::class);
$routes->scope('/', function (RouteBuilder $builder) {
   $builder->registerMiddleware('csrf', new CsrfProtectionMiddleware([ 'httpOnly' => true, ])); $builder->applyMiddleware('csrf');
   //$builder->connect('/pages',['controller'=>'Pages','action'=>'display', 'home']); $builder->connect('datetime',['controller'=>'Dates','action'=>'index']);
   $builder->fallbacks();
});

बनाओ DatesController.php पर फ़ाइल करें src/Controller/DatesController.php.नियंत्रक फ़ाइल में निम्न कोड की प्रतिलिपि बनाएँ। अगर पहले से बना है तो अनदेखा करें।

src / नियंत्रक / DatesController.php

<?php
   namespace App\Controller;
   use App\Controller\AppController;
   use Cake\I18n\FrozenTime;
   class DatesController extends AppController{
      public function index(){
         $time = FrozenTime::now();
         $now = FrozenTime::parse('now'); $_now = $now->i18nFormat('yyyy-MM-dd HH:mm:ss'); $this->set('timenow', $_now); $now = FrozenTime::parse('now');
         $nice = $now->nice();
         $this->set('nicetime', $nice);
         $hebrewdate = $now->i18nFormat(\IntlDateFormatter::FULL, null, 'en-IR@calendar=hebrew');
         $this->set("hebrewdate",$hebrewdate);
         $japanesedate = $now->i18nFormat(\IntlDateFormatter::FULL, null, 'en-IR@calendar=japanese');
         $this->set("japanesedate",$japanesedate);
         $time = FrozenTime::now(); $this->set("current_year",$time->year); $this->set("current_month",$time->month); $this->set("current_day",$time->day);
      }
   }
?>

एक निर्देशिका बनाएँ Dates पर src/Template और उस निर्देशिका के तहत एक बनाएँ Viewindex.php नामक फाइल। उस फ़ाइल में निम्न कोड कॉपी करें।

src / खाका / दिनांक / index.php

<?php
   echo "The Current date and time is = ".$timenow;
   echo "<br/>";
   echo "Using nice format available = ".$nicetime; echo "<br/>"; echo "Date and Time as per Hebrew Calender =" .$hebrewdate;
   echo "<br/>";
   echo "Date and Time as per Japanese Calender =" .$japanesedate; echo "<br/>"; echo "Current Year = ".$current_year;
   echo "<br/>";
   echo "Current Month = ".$current_month; echo "<br/>"; echo "Current Day = ".$current_day;
?>

निम्न URL पर जाकर उपरोक्त उदाहरण देखें -

http: // localhost / cakephp4 / datetime

उत्पादन

जब आप कोड चलाते हैं, तो आपको निम्न आउटपुट दिखाई देंगे -

फ़ाइल अपलोड पर काम करने के लिए हम प्रपत्र सहायक का उपयोग करने जा रहे हैं। यहाँ, फ़ाइल अपलोड के लिए एक उदाहरण है।

उदाहरण

निम्न प्रोग्राम में दिखाए गए अनुसार, config / मार्गों में परिवर्तन करें।

config / routes.php

<?php
use Cake\Http\Middleware\CsrfProtectionMiddleware;
use Cake\Routing\Route\DashedRoute;
use Cake\Routing\RouteBuilder;
$routes->setRouteClass(DashedRoute::class); $routes->scope('/', function (RouteBuilder $builder) { $builder->registerMiddleware('csrf', new CsrfProtectionMiddleware([
      'httpOnly' => true,
   ]));
   $builder->applyMiddleware('csrf'); //$builder->connect('/pages',['controller'=>'Pages','action'=>'display', 'home']);
   $builder->connect('fileupload',['controller'=>'Files','action'=>'index']); $builder->fallbacks();
});

बनाओ FilesController.php पर फ़ाइल करें src/Controller/FilesController.php.नियंत्रक फ़ाइल में निम्न कोड की प्रतिलिपि बनाएँ। पहले से निर्मित है, तो अनदेखा करें।

अपलोड करें / src में निर्देशिका /। अपलोड की गई फ़ाइलों को अपलोड / फ़ोल्डर में सहेजा जाएगा।

src / नियंत्रक / FilesController.php

<?php
   namespace App\Controller;
   use App\Controller\AppController;
   use Cake\View\Helper\FormHelper;
   class FilesController extends AppController {
      public function index(){
         if ($this->request->is('post')) { $fileobject = $this->request->getData('submittedfile'); $uploadPath = '../uploads/';
            $destination = $uploadPath.$fileobject->getClientFilename(); // Existing files with the same name will be replaced. $fileobject->moveTo($destination);
         }
      }
   }
?>

एक निर्देशिका बनाएँ Files पर src/Template और उस निर्देशिका के तहत एक बनाएँ View फ़ाइल कहा जाता है index.php. उस फ़ाइल में निम्न कोड कॉपी करें।

src / खाका / फ़ाइलें / index.php

<?php
   echo $this->Form->create(NULL, ['type' => 'file']);
   echo $this-&gtl;Form->file('submittedfile'); echo $this->Form->button('Submit');
   echo $this->Form->end(); $uploadPath ='../uploads/';
   $files = scandir($uploadPath, 0);
   echo "Files uploaded in uploads/ are:<br/>";
   for($i = 2; $i < count($files); $i++)
      echo "File is - ".$files[$i]."<br>";
?>

अपलोड / फ़ोल्डर में सहेजी गई फ़ाइलें उपयोगकर्ता के लिए सूचीबद्ध हैं। निम्न URL पर जाकर उपरोक्त उदाहरण देखें -

http: // localhost / cakephp4 / fileupload -

उत्पादन

जब आप उपरोक्त कोड निष्पादित करते हैं, तो आपको निम्नलिखित आउटपुट देखना चाहिए -