Zend फ्रेमवर्क - प्रपत्र और मान्यता

Zend फ्रेमवर्क एक अलग घटक प्रदान करता है, zend-formप्रपत्र निर्माण और सत्यापन प्रक्रिया में तेजी लाने के लिए। यह मॉडल और व्यू लेयर को जोड़ता है। यह पूर्व-निर्धारित मॉडल से पूर्ण HTML प्रारूप बनाने के लिए फ़ॉर्म तत्वों का एक सेट प्रदान करता है, aInputFilter मॉडल से फॉर्म और विकल्पों के खिलाफ मॉडल को मान्य करने के लिए वर्ग को फॉर्म से मॉडल और इसके विपरीत डेटा को बांधने के लिए।

प्रपत्र घटक स्थापित करें

Zend फॉर्म घटक का उपयोग करके स्थापित किया जा सकता है Composer नीचे दिए गए आदेश के रूप में -

composer require zendframework/zend-form

रूपों को प्रबंधित करने के लिए एक Zend फॉर्म फ्रेमवर्क में तीन उपकेंद्र होते हैं। उन्हें नीचे विस्तार से बताया गया है -

  • Elements - मॉडल में एक संपत्ति के लिए मैप किए गए एकल HTML इनपुट नियंत्रण को परिभाषित करने के लिए उपयोग किया जाता है।

  • Fieldset - समूह तत्वों और अन्य के लिए इस्तेमाल किया fieldset एक नेस्टेड तरीके से।

  • Form - एचटीएमएल फॉर्म बनाने के लिए उपयोग किया जाता है और इसमें तत्व और फ़ील्ड शामिल होते हैं।

Zend Form आमतौर पर के तहत बनाए जाते हैं module//src/Form निर्देशिका।

उदाहरण

अब हमें जोड़ने के लिए एक सरल फ़ॉर्म बनाते हैं bookडेटाबेस में। ऐसा करने के लिए, हमें निम्नलिखित चरणों का पालन करना चाहिए -

चरण 1: बुकफोर्म बनाएं

* Myapp / मॉड्यूल / ट्यूटोरियल / src / फॉर्म "निर्देशिका के तहत" BookForm.php "बनाएँ। फ़ाइल में निम्नलिखित परिवर्तन जोड़ें -

<?php  
namespace Tutorial\Form;  
use Zend\Form\Form;  

class BookForm extends Form {
   
   public function __construct($name = null) { parent::__construct('book'); $this->add(array( 
         'name' => 'id', 
         'type' => 'Hidden', 
      ));  
      $this->add(array( 'name' => 'author', 'type' => 'Text', 'options' => array( 'label' => 'Author', ), )); $this->add(array( 
         'name' => 'title', 
         'type' => 'Text', 
         'options' => array( 
            'label' => 'Title', 
         ), 
      ));  
      $this->add(array( 
         'name' => 'submit', 
         'type' => 'Submit', 
         'attributes' => array( 
            'value' => 'Go', 
            'id' => 'submitbutton', 
         ), 
      )); 
   } 
}

Form कक्षा एक प्रदान करता है add methodमॉडल और उसके संबंधित फॉर्म विवरणों को देखना। हमने बनाया हैBookForm विस्तार करके Form वर्ग और के लिए फार्म विवरण जोड़ा Book नमूना।

चरण 2: पुस्तक मॉडल, Book.php अपडेट करें

मॉडल को अपडेट करें, ‘Book’ नीचे दिए गए अनुसार फिल्टर और सत्यापन के साथ -

<?php 
namespace Tutorial\Model;  
use Zend\InputFilter\InputFilterInterface; 
use Zend\InputFilter\InputFilterAwareInterface; 
use Zend\InputFilter\InputFilter;  

class Book implements InputFilterAwareInterface { 
   public $id; 
   public $author; public $title;  
   protected $inputFilter; public function setInputFilter(InputFilterInterface $inputFilter) { 
      throw new \Exception("Not used"); 
   }  
   public function getInputFilter() { 
      if (!$this->inputFilter) { $inputFilter = new InputFilter(); 
         $inputFilter->add(array( 'name' => 'id', 'required' => true, 'filters' => array( array('name' => 'Int'), ), )); $inputFilter->add(array( 
            'name' => 'author', 
            'required' => true, 
            'filters' => array( 
               array('name' => 'StripTags'), 
               array('name' => 'StringTrim'), 
            ), 
            'validators' => array( 
               array( 
                  'name' => 'StringLength', 
                  'options' => array( 
                     'encoding' => 'UTF-8', 
                     'min' => 1, 
                     'max' => 100, 
                  ), 
               ), 
            ), 
         )); 
         $inputFilter->add(array( 'name' => 'title', 'required' => true, 'filters' => array( array('name' => 'StripTags'), array('name' => 'StringTrim'), ), 'validators' => array( array( 'name' => 'StringLength', 'options' => array( 'encoding' => 'UTF-8', 'min' => 1, 'max' => 100, ), ), ), )); $this->inputFilter = $inputFilter; } return $this->inputFilter; 
   }  
   public function exchangeArray($data) { $this->id = (!empty($data['id'])) ? $data['id'] : null; 
      $this->author = (!empty($data['author'])) ? $data['author'] : null; $this->title = (!empty($data['title'])) ? $data['title'] : null; 
   } 
}

प्रत्येक मॉडल को लागू करना चाहिए InputFilterAwareInterface। InputFilterAwareInterface दो तरीके प्रदान करता है,setInputFilter() तथा getInputFilter()

GetInputFilter का उपयोग मॉडल के सत्यापन विवरण प्राप्त करने के लिए किया जाता है। Zend फ्रेमवर्क फॉर्म को मान्य करने के लिए फ़िल्टर और सत्यापनकर्ताओं का एक समृद्ध सेट प्रदान करता है। पुस्तक मॉडल में उपयोग किए गए कुछ फ़िल्टर और सत्यापनकर्ता निम्न हैं -

  • StripTags - अवांछित HTML हटाएं।

  • StringTrim - अनावश्यक सफेद स्थान को हटा दें।

  • StringLength validator - सुनिश्चित करें कि उपयोगकर्ता निर्दिष्ट सीमा से अधिक वर्ण दर्ज नहीं करता है।

चरण 3: बुकटेबल क्लास को अपडेट करें

को शामिल करें saveBook डेटाबेस में पुस्तक जोड़ने की विधि।

BookTable.php

<?php  
namespace Tutorial\Model;  
use Zend\Db\TableGateway\TableGatewayInterface;  

class BookTable {
   protected $tableGateway; public function __construct(TableGatewayInterface $tableGateway) { 
      $this->tableGateway = $tableGateway; 
   }  
   public function fetchAll() { 
      $resultSet = $this->tableGateway->select(); 
      return $resultSet; } public function getBook($id) { 
      $id = (int) $id; 
      $rowset = $this->tableGateway->select(array('id' => $id)); $row = $rowset->current(); if (!$row) { 
         throw new \Exception("Could not find row $id"); } return $row; 
   }  
   public function saveBook(Book $book) { $data = array ( 
         'author' => $book->author, 'title' => $book->title, 
      );  
      $id = (int) $book->id; 
      if ($id == 0) { $this->tableGateway->insert($data); } else { if ($this->getBook($id)) { $this->tableGateway->update($data, array('id' => $id));  
         } else { 
            throw new \Exception('Book id does not exist'); 
         } 
      } 
   } 
}

चरण 4: ट्यूटोरियलकंट्रोलर वर्ग को अपडेट करें

ट्यूटोरियल कंट्रोलर में एक नया एक्शन AddAction जोड़ें - myapp / मॉड्यूल / Tutorial / src / कंट्रोलर / TutorialController.php।

public function addAction() { 
   $form = new BookForm(); $form->get('submit')->setValue('Add');  
   $request = $this->getRequest(); 
   if ($request->isPost()) { $book = new Book(); 
      $form->setInputFilter($book->getInputFilter()); 
      $form->setData($request->getPost());  
      if ($form->isValid()) { $book->exchangeArray($form->getData()); $this->bookTable->saveBook($book); // Redirect to list of Tutorial return $this->redirect()->toRoute('tutorial'); 
      } 
   }  
   return array('form' => $form); 
}

addAction विधि निम्नलिखित प्रक्रियाएं करती है -

  • अनुरोध वस्तु प्राप्त करता है।

  • जाँचता है कि अनुरोध का http तरीका a है या नहीं post तरीका।

  • यदि अनुरोध की http विधि नहीं है post, यह सिर्फ टेम्पलेट को प्रस्तुत करता है, add.phtml

  • यदि अनुरोध की http विधि नहीं है post, तो यह सेट करता है inputfilter, अनुरोध डेटा प्राप्त करता है और इसे इनपुटफाइलर में सेट करता है।

  • जाँचता है कि क्या प्रपत्र का उपयोग करके वैध है isValid() फॉर्म क्लास की विधि।

  • यदि प्रपत्र मान्य नहीं है, तो यह फिर से टेम्पलेट प्रदान करता है, add.phtml

  • यदि प्रपत्र मान्य है, तो यह पुस्तक को डेटाबेस में सहेजता है और होम पेज पर रीडायरेक्ट करता है।

चरण 5: add.phtml टेम्पलेट जोड़ें

एक टेम्पलेट बनाएं - my.app / मॉड्यूल / ट्यूटोरियल / देखने / ट्यूटोरियल / ट्यूटोरियल / add.phtml के तहत add.phtml

Add.phtml

<?php  
$title = 'Add new Book'; 
$this->headTitle($title);  
?>  
<h1><?php echo $this->escapeHtml($title); ?></h1>  
<?php  
if(!empty($form)) { $form->setAttribute('action', $this->url('tutorial', array('action' => 'add'))); $form->prepare();  
   echo $this->form()->openTag($form); 
   echo $this->formHidden($form->get('id')); 
   echo $this->formRow($form->get('author'))."<br>"; 
   echo $this->formRow($form->get('title'))."<br>"; 
   echo $this->formSubmit($form->get('submit')); 
   echo $this->form()->closeTag(); 
}

यहां, हम पुस्तक फॉर्म का उपयोग कर प्रस्तुत कर रहे हैं Form उदाहरण के लिए, $form

चरण 6: अनुप्रयोग चलाएँ

अब, हम एप्लिकेशन चला सकते हैं - http://localhost:8080/tutorial/add

Form Page

Validate Error Page