Zend फ्रेमवर्क - इवेंट मैनेजर

सभी आधुनिक अनुप्रयोगों को ठोस और लचीले ईवेंट घटकों की आवश्यकता होती है। Zend फ्रेमवर्क एक ऐसा घटक प्रदान करता है,zend-eventmanager। Zend-eventmanager उच्च स्तरीय वास्तुकला डिजाइन करने में मदद करता है और विषय / प्रेक्षक पैटर्न और पहलू उन्मुख प्रोग्रामिंग का समर्थन करता है।

इवेंट मैनेजर स्थापित करें

इवेंट मैनेजर का उपयोग करके स्थापित किया जा सकता है Composer जैसा कि नीचे दिया गया है -

composer require zendframework/zend-eventmanager

इवेंट मैनेजर की अवधारणा

इवेंट मैनेजर की मुख्य अवधारणाएं इस प्रकार हैं -

  • Event - घटना मनमाने ढंग से कार्रवाई का नाम है, कहते हैं greet

  • Listener- कोई भी PHP कॉलबैक। वे घटनाओं से जुड़े होते हैं और जब घटना शुरू होती है तो उन्हें बुलाया जाता है। श्रोता का डिफ़ॉल्ट हस्ताक्षर है -

function(EventInterface $e)
  • EventInterface Class- घटना को स्वयं निर्दिष्ट करने के लिए उपयोग किया जाता है। इसमें नाम (सेट / getName), लक्ष्य (get / setTarget) और पैरामीटर (get / setParams) जैसी इवेंट जानकारी सेट करने और प्राप्त करने के तरीके हैं।

  • EventManager class- EventManager का उदाहरण एक अनुप्रयोग और उसके संबंधित श्रोताओं में सभी परिभाषित घटनाओं को ट्रैक करता है। EventManager एक विधि प्रदान करता है,attach किसी घटना में श्रोता को संलग्न करना और यह एक विधि प्रदान करता है, triggerकिसी भी पूर्व-परिभाषित घटना को ट्रिगर करने के लिए। एक बार ट्रिगर को कॉल करने के बाद, EventManager उस से जुड़े श्रोता को कॉल करता है।

  • EventManagerAwareInterface- घटना आधारित प्रोग्रामिंग का समर्थन करने के लिए एक वर्ग के लिए, इसे EventManagerAwareInterface को लागू करने की आवश्यकता है। यह दो तरीके प्रदान करता है,setEventManager तथा getEventManager इवेंट मैनेजर को पाने और सेट करने के लिए।

उदाहरण

आइए हम इवेंट मैनेजर कॉन्सेप्ट को समझने के लिए एक सरल PHP कंसोल एप्लिकेशन लिखते हैं। नीचे दिए गए चरणों का पालन करें।

  • एक फ़ोल्डर बनाएँ "Eventapp"।

  • इंस्टॉल zend-eventmanager संगीतकार का उपयोग करना।

  • एक PHP फ़ाइल बनाएँ Greeter.php "Eventapp" फ़ोल्डर के अंदर।

  • कक्षा बनाएँ Greeter और लागू करें EventManagerAwareInterface

require __DIR__ . '/vendor/autoload.php'; 
class Greeter implements EventManagerAwareInterface { 
   // code 
}

यहाँ, require सभी कंपोजर स्थापित घटकों को ऑटोलॉड करने के लिए उपयोग किया जाता है।

लिखना setEventManager कक्षा में विधि Greeter जैसा कि नीचे दिखाया गया है -

public function setEventManager(EventManagerInterface $events) { 
   $events->setIdentifiers([ __CLASS__, get_called_class(),]); $this->events = $events; return $this; 
}

यह विधि वर्तमान क्लास को दिए गए इवेंट मैनेजर ($ इवेंट्स तर्क) में सेट करती है और फिर इवेंट मैनेजर को लोकल वेरिएबल में सेट करती है $events

अगला कदम लिखना है getEventManager कक्षा में विधि Greeter जैसा कि नीचे दिखाया गया है -

public function getEventManager() { 
   if (null === $this->events) { $this->setEventManager(new EventManager()); 
   } 
   return $this->events; 
}

विधि को स्थानीय चर से इवेंट मैनेजर मिलता है। यदि यह उपलब्ध नहीं है, तो यह इवेंट मैनेजर का एक उदाहरण बनाता है और इसे वापस करता है।

एक विधि लिखें, greet, क्लास में Greeter

public function greet($message) { 
   printf("\"%s\" from class\n", $message); $this->getEventManager()->trigger(__FUNCTION__, $this, $message ]); 
}

इस विधि को इवेंट मैनेजर मिलता है और इससे जुड़ी घटनाओं को फायर / ट्रिगर करता है।

अगले चरण के एक उदाहरण बनाने के लिए है Greeter कक्षा और श्रोता को इसकी विधि में संलग्न करें, greet

$greeter = new Greeter(); $greeter->getEventManager()->attach('greet', function($e) { $event_name = $e->getName(); $target_name = get_class($e->getTarget()); $params_json = json_encode($e->getParams()); printf("\"%s\" event of class \"%s\" is called." . " The parameter supplied is %s\n", $event_name,  
      $target_name, $params_json); 
});

श्रोता कॉलबैक केवल घटना के नाम, लक्ष्य और आपूर्ति किए गए मापदंडों को प्रिंट करता है।

की पूरी सूची Greeter.php इस प्रकार है -

<?php  
require __DIR__ . '/vendor/autoload.php';  

use Zend\EventManager\EventManagerInterface; 
use Zend\EventManager\EventManager; 
use Zend\EventManager\EventManagerAwareInterface; 

class Greeter implements EventManagerAwareInterface { 
   protected $events; public function setEventManager(EventManagerInterface $events) { 
      $events->setIdentifiers([__CLASS__, get_called_class(), ]); $this->events = $events; return $this; 
   }  
   public function getEventManager() { 
      if (null === $this->events) { $this->setEventManager(new EventManager()); 
      } 
      return $this->events; } public function greet($message) { 
      printf("\"%s\" from class\n", $message); $this->getEventManager()->trigger(__FUNCTION__, $this, [$message ]); 
   } 
} 

$greeter = new Greeter(); $greeter->greet("Hello");  
$greeter->getEventManager()->attach('greet', function($e) { 
   $event_name = $e->getName(); 
   $target_name = get_class($e->getTarget()); 
   $params_json = json_encode($e->getParams()); 
   printf("\"%s\" event of class \"%s\" is called." . " The parameter supplied is %s\n",
      $event_name, $target_name,  
      $params_json); }); $greeter->greet("Hello");

अब, कमांड प्रॉम्प्ट php में एप्लिकेशन रन करें Greeter.php और परिणाम इस प्रकार होगा -

"Hello" from class 
"Hello" from class 
"greet" event of class "Greeter" is called. The parameter supplied is ["Hello"]

उपरोक्त नमूना आवेदन केवल एक घटना प्रबंधक की मूल बातें बताते हैं। इवेंट मैनेजर कई और अधिक उन्नत विकल्प प्रदान करता है जैसे किListener Priority, Custom Callback Prototype / Signature, Short Circuiting, आदि इवेंट मैनेजर का Zend MVC फ्रेमवर्क में बड़े पैमाने पर उपयोग किया जाता है।