सिम्फनी - घटक

जैसा कि पहले चर्चा की गई है, सिम्फनी घटक स्टैंडअलोन पीएचपी लाइब्रेरी हैं जो एक विशिष्ट सुविधा प्रदान करते हैं, जिसका उपयोग किसी भी पीएचपी एप्लिकेशन में किया जा सकता है। सिम्फनी के प्रत्येक रिलीज में उपयोगी नए घटकों को पेश किया जा रहा है। वर्तमान में, सिम्फनी फ्रेमवर्क में 30+ उच्च गुणवत्ता वाले घटक हैं। आइए इस अध्याय में सिम्फनी घटकों के उपयोग के बारे में जानें।

एक सिम्फनी घटक स्थापित करना

कम्पोज़र कमांड का उपयोग करके सिम्फनी घटकों को आसानी से स्थापित किया जा सकता है। जेनेरिक कमांड का पालन किसी भी सिम्फनी घटक को स्थापित करने के लिए किया जा सकता है।

cd /path/to/project/dir 
composer require symfony/<component_name>

आइए हम एक साधारण php एप्लिकेशन बनाएं और इंस्टॉल करने का प्रयास करें Filesystem घटक।

Step 1 - आवेदन के लिए एक फ़ोल्डर बनाएँ, filesystem-example

cd /path/to/dev/folder 
mdkir filesystem-example 
cd filesystem-example

Step 2 - निम्न कमांड का उपयोग करके फाइलसिस्टम घटक स्थापित करें।

composer require symfony/filesystem

Step 3 - एक फ़ाइल बनाएँ main.php और निम्न कोड दर्ज करें।

<?php 
   require_once __DIR__ . '/vendor/autoload.php'; 
   use Symfony\Component\Filesystem\Filesystem; 
   use Symfony\Component\Filesystem\Exception\IOExceptionInterface; 
   
   $fs = new Filesystem(); 
   try { 
      $fs->mkdir('./sample-dir'); 
      $fs->touch('./sample-dir/text.txt'); 
   } catch (IOExceptionInterface $e) { 
      echo $e; 
   } 
?>

पहली पंक्ति बहुत महत्वपूर्ण है, जो संगीतकार कमांड का उपयोग करके स्थापित सभी घटकों से सभी आवश्यक वर्गों को लोड करती है। अगली पंक्तियाँ Filesystem वर्ग का उपयोग करती हैं।

Step 4 - निम्नलिखित कमांड का उपयोग करके एप्लिकेशन को चलाएं और यह एक नया फ़ोल्डर बनाएगा sample-dir और एक फाइल test.txt इसके नीचे।

php main.php

सिम्फनी घटकों का विवरण

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

फाइल सिस्टम

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

composer require symfony/filesystem

खोजक

खोजक घटक एक निर्दिष्ट पथ में फ़ाइलों और निर्देशिकाओं को खोजने के लिए धाराप्रवाह कक्षाएं प्रदान करता है। यह एक पथ में फ़ाइलों पर पुनरावृति करने का एक आसान तरीका प्रदान करता है। निम्न आदेश का उपयोग करके खोजक घटक स्थापित किया जा सकता है।

composer require symfony/finder

कंसोल

कंसोल घटक आसानी से कमांड बनाने के लिए विभिन्न विकल्प प्रदान करता है, जिसे एक टर्मिनल में निष्पादित किया जा सकता है। सिम्फनी का उपयोग करता हैCommand बड़े पैमाने पर विभिन्न कार्यात्मकताएं प्रदान करने के लिए जैसे कि एक नया एप्लिकेशन बनाना, एक बंडल बनाना, आदि। यहां तक ​​कि वेब सर्वर में PHP बिल्ड को सिम्फनी कमांड का उपयोग करके इनवॉइस किया जा सकता है, php bin/console server:runके रूप में स्थापना अनुभाग में देखा। Console घटक को निम्न कमांड का उपयोग करके स्थापित किया जा सकता है।

composer require symfony/console

आइए हम एक साधारण एप्लिकेशन बनाएं और एक कमांड बनाएं, HelloCommand का उपयोग करते हुए Console घटक और यह आह्वान।

Step 1 - निम्नलिखित कमांड का उपयोग करके एक प्रोजेक्ट बनाएं।

cd /path/to/project 
composer require symfony/console

Step 2 - एक फ़ाइल बनाएँ main.php और निम्न कोड शामिल करें।

<?php 
   require __DIR__ . '/vendor/autoload.php'; 
   use Symfony\Component\Console\Application; 
   
   $app = new Application(); 
   $app->run(); 
?>

Application क्लास नंगे-बोन कंसोल एप्लिकेशन की आवश्यक कार्यक्षमता सेट करता है।

Step 3 - एप्लिकेशन चलाएँ, php main.php, जो निम्नलिखित परिणाम का उत्पादन करेगा।

Console Tool  
Usage: 
   command [options] [arguments]  
Options: 
   -h, --help            Display this help message 
   -q, --quiet           Do not output any message 
   -V, --version         Display this application version 
         --ansi            Force ANSI output 
         --no-ansi         Disable ANSI output 
   -n, --no-interaction  Do not ask any interactive question 
   -v|vv|vvv, --verbose  Increase the verbosity of messages: 1 for normal output, 
      2 for more verbose output and 3 for debug  
Available commands: 
   help  Displays help for a command 
   list  Lists commands

Step 4 - नामक एक कक्षा बनाएँ HelloCommand विस्तार Command कक्षा में main.php अपने आप।

use Symfony\Component\Console\Command\Command; 
use Symfony\Component\Console\Input\InputInterface; 
use Symfony\Component\Console\Output\OutputInterface; 
use Symfony\Component\Console\Input\InputArgument;

class HelloCommand extends Command { 
}

आवेदन चार वर्गों में उपलब्ध निम्नलिखित का उपयोग करता है Command घटक।

  • Command - एक नई कमांड बनाने के लिए उपयोग किया जाता है

  • InputInterface - उपयोगकर्ता इनपुट सेट करने के लिए उपयोग किया जाता है

  • InputArgument - उपयोगकर्ता इनपुट प्राप्त करने के लिए उपयोग किया जाता है

  • OutputInterface - कंसोल में आउटपुट प्रिंट करने के लिए उपयोग किया जाता है

step 5 - एक फंक्शन बनाएं configure() और सेट नाम, विवरण और मदद पाठ।

protected function configure() { 
   $this 
      ->setName('app:hello') 
      ->setDescription('Sample command, hello') 
      ->setHelp('This command is a sample command') 
}

step 6 - एक इनपुट तर्क बनाएं, user आदेश के लिए और अनिवार्य के रूप में सेट करें।

protected function configure() { 
   $this 
      ->setName('app:hello') 
      ->setDescription('Sample command, hello') 
      ->setHelp('This command is a sample command') 
      ->addArgument('name', InputArgument::REQUIRED, 'name of the user'); 
}

step 7 - एक फंक्शन बनाएं execute() दो तर्कों के साथ InputArgument तथा OutputArgument

protected function execute(InputInterface $input, OutputInterface $output) { 
}

step 8 - उपयोग करें InputArgument उपयोगकर्ता द्वारा उपयोगकर्ता विवरण प्राप्त करने के लिए और इसे कंसोल का उपयोग करके प्रिंट करें OutputArgument

protected function execute(InputInterface $input, OutputInterface $output) { 
   $name = $input->getArgument('name'); 
   $output->writeln('Hello, ' . $name); 
}

step 9 - रजिस्टर करें HelloCommand का उपयोग कर आवेदन में add उसकि विधि Application कक्षा।

$app->add(new HelloCommand());

पूरा आवेदन इस प्रकार है।

<?php 
   require __DIR__ . '/vendor/autoload.php'; 
   use Symfony\Component\Console\Application; 
   use Symfony\Component\Console\Command\Command; 
   use Symfony\Component\Console\Input\InputInterface; 
   use Symfony\Component\Console\Output\OutputInterface; 
   use Symfony\Component\Console\Input\InputArgument;  
   
   class HelloCommand extends Command { 
      protected function configure() { 
         $this 
            ->setName('app:hello') 
            ->setDescription('Sample command, hello') 
            ->setHelp('This command is a sample command') 
            ->addArgument('name', InputArgument::REQUIRED, 'name of the user'); 
      }  
      protected function execute(InputInterface $input, OutputInterface $output) { 
         $name = $input->getArgument('name'); 
         $output->writeln('Hello, ' . $name);
      }  
      $app = new Application(); 
      $app->add(new HelloCommand()); 
      $app->run(); 
   }         
?>

Step 10 - अब, निम्नलिखित कमांड का उपयोग करके एप्लिकेशन को निष्पादित करें और परिणाम हैलो, जॉन के रूप में अपेक्षित होगा।

php main.php app:hello Jon

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

प्रोसेस

प्रक्रिया घटक उप-प्रक्रिया में किसी भी सिस्टम कमांड को सुरक्षित और कुशल तरीके से चलाने के लिए विकल्प प्रदान करता है। प्रक्रिया घटक निम्नलिखित कमांड का उपयोग करके स्थापित किया जा सकता है।

composer require symfony/process

classloader

ClassLoader घटक दोनों के लिए कार्यान्वयन प्रदान करता है PSR-0 तथा PSR-4कक्षा लोडर मानक। इसका उपयोग कक्षाओं को ऑटो-लोड करने के लिए किया जा सकता है। निकट भविष्य में इसकी अवहेलना होगी। इस घटक पर कम्पोज़र-आधारित क्लास लोडर को प्राथमिकता दी जाती है। क्लास कमांड को निम्नलिखित कमांड का उपयोग करके स्थापित किया जा सकता है।

composer require symfony/class-loader

PropertyAccess

PropertyAccess घटक स्ट्रिंग संकेतन का उपयोग करके ऑब्जेक्ट और सरणी विवरण को पढ़ने और लिखने के लिए विभिन्न विकल्प प्रदान करता है। उदाहरण के लिए, एक सरणीProduct कुंजी के साथ price का उपयोग गतिशील रूप से पहुँचा जा सकता है [price] स्ट्रिंग।

$product = array( 
   'name' => 'Cake' 
   'price' => 10 
);  
var priceObj = $propertyAccesserObj->getValue($product, '[price]');

निम्न आदेश का उपयोग करके PropertyAccess घटक स्थापित किया जा सकता है।

composer require symfony/property-access

PropertyInfo

प्रॉपर्टीइंफो कंपोनेंट प्रॉपर्टी एसे घटक के समान है, हालांकि यह केवल PHP ऑब्जेक्ट्स के साथ काम करता है और बहुत अधिक कार्यक्षमता प्रदान करता है।

class Product { 
   private $name = 'Cake'; 
   private $price = 10;  
   
   public function getName() { 
      return $this->name; 
   }  
   public function getPrice() { 
      return $this->price; 
   } 
}  
$class = Product::class; 
$properties = $propertyInfoObj->getProperties($class);  
/* 
   Example Result 
   -------------- 
   array(2) { 
      [0] => string(4) "name" 
      [1] => string(5) "price" 
   } 
*/

प्रॉपर्टीइन्फो घटक निम्नलिखित कमांड का उपयोग करके स्थापित किया जा सकता है।

composer require symfony/property-info

EventDispatcher

EventDispatcher घटक PHP में एक घटना-आधारित प्रोग्रामिंग प्रदान करता है। यह वस्तुओं को घटनाओं को भेजकर और उन्हें सुनकर एक दूसरे के साथ संवाद करने में सक्षम बनाता है। हम सीखेंगे कि ईवेंट कैसे बनाएं और ईवेंट और ईवेंट श्रोता अध्याय में उन्हें कैसे सुनें।

EventDispatcher घटक को निम्न आदेश का उपयोग करके स्थापित किया जा सकता है।

composer require symfony/event-dispatcher

निर्भरता अन्तःक्षेपण

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

DependencyInjection घटक को निम्न कमांड का उपयोग करके स्थापित किया जा सकता है।

composer require symfony/dependency-injection

serializer

धारावाहिक घटक एक PHP ऑब्जेक्ट को एक विशिष्ट प्रारूप जैसे XML, JSON, बाइनरी, आदि में बदलने का विकल्प प्रदान करता है, और फिर इसे बिना डेटा हानि के मूल ऑब्जेक्ट में वापस परिवर्तित करने की अनुमति देता है।

सीरियल कमांडर को निम्नलिखित कमांड का उपयोग करके स्थापित किया जा सकता है।

composer require symfony/serializer

कॉन्फ़िग

कॉन्फ़िगर घटक XML, YAML, PHP और ini प्रकार के लोड, पार्स, पढ़ने और मान्य कॉन्फ़िगरेशन को विकल्प प्रदान करता है। यह डेटाबेस से कॉन्फ़िगरेशन विवरणों को लोड करने के लिए विभिन्न विकल्प प्रदान करता है। यह स्पष्ट और संक्षिप्त तरीके से वेब एप्लिकेशन को कॉन्फ़िगर करने में उपयोगी महत्वपूर्ण घटकों में से एक है। निम्न आदेश का उपयोग करके कॉन्फ़िगर घटक स्थापित किया जा सकता है।

composer require symfony/config

ExpressionLanguage

ExpessionLanguage घटक एक पूर्ण-अभिव्यक्ति अभिव्यक्ति इंजन प्रदान करता है। भाव एक-लाइनर हैं जिसका उद्देश्य एक मूल्य वापस करना है। अभिव्यक्ति इंजन आसानी से संकलित करने, पार्स करने और एक अभिव्यक्ति से मूल्य प्राप्त करने में सक्षम बनाता है। यह एक सिस्टम प्रशासक का कहना है कि एक गैर-PHP प्रोग्रामर द्वारा कॉन्फ़िगरेशन वातावरण (फ़ाइल) में एक या अधिक अभिव्यक्ति का उपयोग करने में सक्षम बनाता है। ExpressionLanguage घटक को निम्न आदेश का उपयोग करके स्थापित किया जा सकता है।

composer require symfony/expression-language

OptionsResolver

OptionsResolver घटक हमारे सिस्टम में प्रयुक्त विकल्प प्रणाली को मान्य करने का एक तरीका प्रदान करता है। उदाहरण के लिए, डेटाबेस सेटिंग को एक सरणी में रखा जाता है, कुंजी के रूप में होस्ट, उपयोगकर्ता नाम, पासवर्ड, आदि के साथ dboption। डेटाबेस से कनेक्ट करने के लिए आपको उपयोग करने से पहले प्रविष्टियों को मान्य करना होगा। OptionsResolver एक सरल वर्ग प्रदान करके इस कार्य को सरल करता है OptionsResolver और एक विधि रिज़ॉल्वर, जो डेटाबेस सेटिंग को हल करता है और यदि कोई सत्यापन समस्या है, तो वह इसे रिपोर्ट करेगा।

$options = array( 
   'host'     => '<db_host>', 
   'username' => '<db_user>', 
   'password' => '<db_password>', 
);  
$resolver = new OptionsResolver(); 
$resolver->setDefaults(array( 
   'host'     => '<default_db_host>', 
   'username' => '<default_db_user>', 
   'password' => '<default_db_password>', 
)); 
$resolved_options = $resolver->resolve($options);

OptionsResolver घटक निम्नलिखित कमांड का उपयोग करके स्थापित किया जा सकता है।

composer require symfony/options-resolver

Dotenv

Dotenv घटक .env फ़ाइलों को पार्स करने के लिए विभिन्न विकल्प प्रदान करता है और उनके द्वारा परिभाषित चर को सुलभ होने के लिए getenv(), $_ENV, या $_SERVER। Dotenv घटक को निम्न कमांड का उपयोग करके स्थापित किया जा सकता है।

composer require symfony/dotenv

कैश

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

composer require symfony/cache

Intl

Intl घटक C Intl एक्सटेंशन के लिए प्रतिस्थापन पुस्तकालय है। Intl घटक निम्नलिखित कमांड का उपयोग करके स्थापित किया जा सकता है।

composer require symfony/intl

अनुवाद

अनुवाद घटक हमारे आवेदन का अंतर्राष्ट्रीयकरण करने के लिए विभिन्न विकल्प प्रदान करता है। आम तौर पर, विभिन्न भाषाओं के अनुवाद विवरण एक फ़ाइल, प्रति भाषा एक फ़ाइल में संग्रहीत किए जाएंगे, और यह एप्लिकेशन के रनटाइम के दौरान गतिशील रूप से लोड किया जाएगा। अनुवाद फ़ाइल लिखने के लिए विभिन्न प्रारूप हैं। अनुवाद घटक किसी भी प्रकार के प्रारूप को लोड करने के लिए विभिन्न विकल्प प्रदान करता है, जैसे कि सादे PHP फ़ाइल, CSV, ini, Json, Yaml, ICU संसाधन फ़ाइल, आदि। अनुवाद घटक को निम्न आदेश का उपयोग करके स्थापित किया जा सकता है।

composer require symfony/translation

कार्यप्रवाह

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

वर्कफ़्लो घटक को निम्न कमांड का उपयोग करके स्थापित किया जा सकता है।

composer require symfony/workflow

YAML

यमल घटक एक विकल्प प्रदान करता है जो यम्ल फ़ाइल प्रारूप को पार्स करता है और इसे PHP सरणियों में परिवर्तित करता है। यह सादे php सरणी से YAML फ़ाइल लिखने में भी सक्षम है। निम्न आदेश का उपयोग करके यमल घटक स्थापित किया जा सकता है।

composer require symfony/yaml

एलडीएपी

Ldap घटक PHP वर्गों को एक LDAP या सक्रिय निर्देशिका सर्वर से कनेक्ट करने और इसके विरुद्ध उपयोगकर्ता को प्रमाणित करने के लिए प्रदान करता है। यह विंडोज डोमेन कंट्रोलर से कनेक्ट करने का विकल्प प्रदान करता है। Ldap घटक को निम्न कमांड का उपयोग करके स्थापित किया जा सकता है।

composer require symfony/ldap

डिबग

डीबग घटक PHP वातावरण में डीबगिंग को सक्षम करने के लिए विभिन्न विकल्प प्रदान करता है। आमतौर पर, PHP कोड डीबग करना कठिन होता है, लेकिन डीबग घटक डीबगिंग की प्रक्रिया को आसान बनाने और इसे साफ और संरचित बनाने के लिए सरल कक्षाएं प्रदान करता है। डिबग घटक को निम्न कमांड का उपयोग करके स्थापित किया जा सकता है।

composer require symfony/debug

स्टॉपवॉच देखनी

स्टॉपवॉच घटक हमारे PHP कोड को प्रोफाइल करने के लिए स्टॉपवॉच वर्ग प्रदान करता है। एक साधारण उपयोग इस प्रकार है।

use Symfony\Component\Stopwatch\Stopwatch; 
$stopwatch = new Stopwatch(); 
$stopwatch->start('somename');  

// our code to profile 
$profiled_data = $stopwatch->stop('somename');  
echo $profiled_data->getPeriods()

स्टॉपवॉच घटक निम्नलिखित कमांड का उपयोग करके स्थापित किया जा सकता है।

composer require symfony/stopwatch

VarDumper

VarDumper घटक बेहतर प्रदान करता है dump()समारोह। बस VarDumper घटक को शामिल करें और बेहतर कार्यक्षमता प्राप्त करने के लिए डंप फ़ंक्शन का उपयोग करें। निम्न आदेश का उपयोग कर VarDumper घटक स्थापित किया जा सकता है।

composer require symfony/var-dumper

BrowserKit

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

composer require symfony/browser-kit

PHPUnit ब्रिज

PHPUnit ब्रिज घटक PHPUnit परीक्षण वातावरण को बेहतर बनाने के लिए कई विकल्प प्रदान करता है। PHPUnit ब्रिज घटक को निम्न कमांड का उपयोग करके स्थापित किया जा सकता है।

composer require symfony/phpunit-bridge

एसेट

एसेट कंपोनेंट एक वेब एप्लिकेशन में एक सामान्य एसेट हैंडलिंग प्रदान करता है। यह CSS, HTML, JavaScript जैसी संपत्तियों के लिए URL जनरेट करता है और संस्करण रखरखाव भी करता है। हम दृश्य इंजन अध्याय में विस्तार से परिसंपत्ति घटक की जांच करेंगे। निम्नलिखित आदेश का उपयोग करके एसेट घटक स्थापित किया जा सकता है।

composer require symfony/asset

CssSelector

CssSelector घटक CSS आधारित चयनकर्ताओं को XPath अभिव्यक्ति में बदलने का विकल्प प्रदान करता है। एक वेब डेवलपर XPath अभिव्यक्ति से अधिक CSS आधारित चयनकर्ताओं की अभिव्यक्ति जानता है, लेकिन HTML और XML दस्तावेज़ में एक तत्व खोजने के लिए सबसे कुशल अभिव्यक्ति हैXPath Expression

CssSelector डेवलपर को CSS चयनकर्ताओं में अभिव्यक्ति लिखने में सक्षम बनाता है , हालांकि, घटक इसे निष्पादित करने से पहले इसे XPath अभिव्यक्ति में बदल देता है। इस प्रकार, डेवलपर को सीएसएस चयनकर्ताओं की सादगी और XPath अभिव्यक्ति की दक्षता का एक फायदा है।

CssSelector घटक निम्नलिखित कमांड का उपयोग करके स्थापित किया जा सकता है।

composer require symfony/css-selector

DomCrawler

DOMCrawler घटक DOM और कॉन्सेप्ट का उपयोग करके HTML और XML डॉक्यूमेंट में एलिमेंट खोजने के लिए विभिन्न विकल्प प्रदान करता है। यह एक तत्व खोजने के लिए XPath अभिव्यक्ति का उपयोग करने का विकल्प भी प्रदान करता है। XPC अभिव्यक्ति के बजाय CSS चयनकर्ताओं का उपयोग करने के लिए CssSelector घटक के साथ DomCrawler घटक का उपयोग किया जा सकता है। DomCrawler घटक को निम्न कमांड का उपयोग करके स्थापित किया जा सकता है।

composer require symfony/dom-crawler

प्रपत्र

प्रपत्र घटक वेब एप्लिकेशन में फ़ॉर्म के आसान निर्माण को सक्षम बनाता है। हम प्रपत्र अध्याय में विस्तार से फॉर्म प्रोग्रामिंग सीखेंगे। निम्न आदेश का उपयोग करके प्रपत्र घटक स्थापित किया जा सकता है।

composer require symfony/form

HttpFoundation

HttpFoundation घटक HTTP विनिर्देशन के लिए एक वस्तु-उन्मुख परत प्रदान करता है। डिफ़ॉल्ट रूप से, PHP HTTP- अनुरोध और प्रतिक्रिया विवरण जैसे सरणी-आधारित ऑब्जेक्ट प्रदान करता है$_GET, $_POST, $_FILES, $_SESSION, आदि HTTP आधारित कार्यक्षमता जैसे कि कुकी सेट करना सरल, सादे पुराने फ़ंक्शन का उपयोग करके किया जा सकता है setCookie()। HttpFoundation अनुरोध, प्रतिक्रिया, पुनर्निर्देशन, आदि जैसे वर्गों के एक छोटे समूह में सभी HTTP संबंधित कार्यक्षमता प्रदान करता है, हम बाद के अध्यायों में इन कक्षाओं के बारे में जानेंगे।

HttpFoundation घटक निम्नलिखित कमांड का उपयोग करके स्थापित किया जा सकता है।

composer require symfony/http-foundation

HttpKernel

HttpKernel घटक सिम्फनी वेब सेटअप में मुख्य घटक है। यह वेब एप्लिकेशन के लिए आवश्यक सभी प्रकार्य प्रदान करता है - प्राप्त करने सेRequest वस्तु वापस भेजने के लिए Responseवस्तु। सिम्फनी वेब एप्लिकेशन की पूरी वास्तुकला HttpKernel द्वारा दी गई है जैसा कि सिम्फनी वेब फ्रेमवर्क की वास्तुकला में चर्चा की गई है।

निम्न कमांड का उपयोग करके HttpKernel घटक स्थापित किया जा सकता है।

composer require symfony/http-kernel

मार्ग

रूटिंग घटक कॉन्फ़िगरेशन चर के पूर्व-निर्धारित सेट पर HTTP अनुरोध को मैप करता है। रूटिंग निर्णय लेता है कि हमारे आवेदन के किस हिस्से को एक अनुरोध को संभालना चाहिए। हम रूटिंग चैप्टर में राउटिंग के बारे में अधिक जानेंगे।

रूटिंग घटक को निम्न कमांड का उपयोग करके स्थापित किया जा सकता है।

composer require symfony/filesystem

templating

अस्थायी घटक एक कुशल टेम्पलेट सिस्टम बनाने के लिए आवश्यक बुनियादी ढांचा प्रदान करता है। सिम्फनी अपने व्यू इंजन कार्यान्वयन के लिए टेंपलेटिंग घटक का उपयोग करता है। हम इंजन अध्याय में टेंपलेटिंग घटक के बारे में अधिक जानेंगे।

निम्नलिखित कमांड का उपयोग करके टेंपलेटिंग घटक स्थापित किया जा सकता है।

composer require symfony/templating

सत्यापनकर्ता

सत्यापनकर्ता घटक का कार्यान्वयन प्रदान करता है JSR-303 Bean Validation Specification। इसका उपयोग किसी वेब वातावरण में प्रपत्र को मान्य करने के लिए किया जा सकता है। हम मान्यकरण अध्याय के बारे में अधिक जानकारी प्राप्त करेंगे।

निम्नलिखित कमांड का उपयोग करके वैलिडेटर घटक स्थापित किया जा सकता है।

composer require symfony/validator

सुरक्षा

सुरक्षा घटक हमारे वेब एप्लिकेशन के लिए पूर्ण सुरक्षा प्रणाली प्रदान करता है, चाहे वह HTTP बेसिक ऑथेंटिकेशन हो, HTTP डाइजेस्ट ऑथेंटिकेशन हो, इंटरेक्टिव फॉर्म बेस्ड ऑथेंटिकेशन हो, एक्स 509 सर्टिफिकेशन लॉगइन हो, आदि यह इन-बिल्ट एसीएल सिस्टम के जरिए यूजर रोल पर आधारित ऑथराइजेशन मैकेनिज्म प्रदान करता है। । हम एडवांस्ड कॉन्सेप्ट चैप्टर में और विस्तार से जानेंगे।

निम्न आदेश का उपयोग करके सुरक्षा घटक स्थापित किया जा सकता है।

composer require symfony/security