CakePHP - लॉगिंग

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

रिटर्न

बूलियन

विवरण

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

दूसरा उपयोग करना है 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 फ़ाइल में लॉग जोड़े जाएंगे -