फाल्कन - त्वरित गाइड

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

फाल्कन पीएचपी में अन्य फ्रेमवर्क (पारंपरिक या मौजूदा) की तुलना में कुछ अनूठी विशेषताएं प्रदान करता है। फाल्कन की कुछ प्रमुख विशेषताएं निम्नलिखित हैं -

  • यह एक पूर्ण स्टैक ओपन सोर्स फ्रेमवर्क है।

  • एक उपयोगकर्ता को कई घटकों का लाभ उठाने के लिए कोड की काफी कम मात्रा की आवश्यकता होती है।

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

  • एक डेवलपर के लिए जिसका ज्ञान है Model-View-Controller (MVC) और Object- Relational Modeling (ORM), फाल्कन के साथ काम करना एक काकवेल की तरह है।

प्रदर्शन

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

सी भाषा

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

डेवलपर उपकरण

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

ऑब्जेक्ट रिलेशनल मैपिंग

फाल्कन डेटाबेस की एक विस्तृत श्रृंखला का समर्थन करता है। यह रिलेशनल डेटाबेस के एक्सेस तक सीमित नहीं है। यह रिलेशनल और नॉन-रिलेशनल दोनों तरह के डेटाबेस को सपोर्ट करता है जो फाल्कन फ्रेमवर्क की कैप में पंख जोड़ने जैसा है।

फाल्कन बनाम अन्य फ्रेमवर्क

निम्नलिखित तालिका इस बात पर प्रकाश डालती है कि फाल्कन अन्य लोकप्रिय रूपरेखाओं जैसे कि Yii और लारवेल से कैसे भिन्न है।

Yii laravel फाल्कन
परियोजनाओं के प्रकार Yii बड़े पैमाने पर परियोजनाएं बनाने में मदद करता है जैसे फ़ोरम, पोर्टल्स, सीएमएस, रेस्टफुल वेब सेवाएं, आदि। वेब अनुप्रयोगों के निर्माण के लिए लारवेल का उपयोग किया जाता है। यह उत्तम और परिष्कृत वाक्य रचना के लिए जाना जाता है। फाल्कन का उपयोग विभिन्न प्रकार की परियोजनाओं को डिजाइन करने के लिए किया जाता है।
डेटाबेस का समर्थन Yii सभी रिलेशनल और नॉन-रिलेशनल डेटाबेस का समर्थन करता है। लारवेल सभी रिलेशनल डेटाबेस का समर्थन करता है। फाल्कन रिलेशनल और नॉन-रिलेशनल डेटाबेस को समान समर्थन देता है।
भाषा: हिन्दी Yii फ्रेमवर्क विशुद्ध रूप से PHP में लिखा गया है। Laravel PHP में लिखा गया है और MVC पैटर्न का अनुसरण करता है। फाल्कन में पीएचपी और सी दोनों शामिल हैं।
अनुमापकता Yii छोटे और मध्यम परियोजनाओं के लिए काफी स्केलेबल है। लारवेल के लिए सभी प्रकार की परियोजनाओं के साथ स्केलेबिलिटी अधिक है। मध्यम परियोजनाओं के लिए अच्छा है।
प्रदर्शन तुलनात्मक रूप से कम है। फाल्कन के साथ तुलना में उच्च लेकिन कम। उच्च प्रदर्शन।

Prerequisites - हमें इस ढांचे के लिए WAMP / LAMP / MAMP या XAMPP स्टैक चाहिए।

विंडोज में फाल्कन फ्रेमवर्क की स्थापना प्रक्रिया के लिए निम्नलिखित चरण हैं।

Step 1 - फाल्कन इंस्टॉलेशन पूरी तरह से निर्भर है dllफ़ाइल। DLL (डायनेमिक लिंक लाइब्रेरी) फाल्कन के लिए आवश्यक पैकेज और प्लगइन्स बनाता है।

निम्न लिंक dll फ़ाइल डाउनलोड करने के लिए प्रयोग किया जाता है - https://phalconphp.com/en/download

Step 2- आवश्यक dll फ़ाइल डाउनलोड करें। सिस्टम के उपयुक्त कॉन्फ़िगरेशन के लिए जाँच करें और आवश्यक dll फ़ाइल डाउनलोड करें। फ़ाइल को डाउनलोड करने के बाद, निकालेंphalcon-php.dll सेवा /php/ext में xampp फ़ोल्डर।

Step 3 - में पथ संपादित करें php.ini file इसे दूसरे तरीके से कॉन्फ़िगर करने के लिए .dll फ़ाइलें।

Step 4 - पथ संपादित होने के बाद, पथ को पुनरारंभ करें xampp/wampढेर। यह डैशबोर्ड में एक बार स्पष्ट रूप से दिखाई देगाdll फ़ाइल ठीक से सेट है।

Step 5 - पैकेज डाउनलोड करने के बाद, सिस्टम गुणों में पथ चर सेट करें।

Step 6 - dllफाइल्स और फाल्कन टूल्स मिलकर प्रोजेक्ट / वेब एप्लिकेशन बनाने में मदद करते हैं। उपयोगकर्ता कमांड प्रॉम्प्ट के माध्यम से सत्यापित कर सकता है कि क्या फाल्कन फ्रेमवर्क सफलतापूर्वक स्थापित किया गया है। आउटपुट को निम्न स्क्रीनशॉट में दिखाया गया है।

Step 7 - जब यह आवश्यक आउटपुट प्राप्त हो जाता है, तो निम्नलिखित कमांड का उपयोग करके एक प्रोजेक्ट बनाएं -

phalcon create-project <project-name>

निम्न आउटपुट प्रदर्शित किया जाएगा।

Step 8- वेब एप्लिकेशन सफलतापूर्वक बनाया गया है। निम्नलिखित URL पर क्लिक करें -http://localhost/demo1

आउटपुट को निम्न स्क्रीनशॉट में दिखाया गया है। यह फाल्कन PHP के लिए स्वागत योग्य पृष्ठ है।

इस अध्याय में, हम फाल्कन के अनुप्रयोग संरचना पर चर्चा करेंगे। निम्नलिखित एक फाल्कन परियोजना की पूरी निर्देशिका संरचना है।

एक रूट फ़ोल्डर है जिसे माना जाता है code baseऔर सार्वजनिक रूप से वेब सर्वर के लिए उपलब्ध है। इसे भी कहा जाता हैweb directory। वेब रूट डायरेक्टरी के बाहर के अन्य फोल्डर को वेब सर्वर और फाल्कन प्रोजेक्ट के लिए पहुंच से बाहर माना जाता है।

प्रोजेक्ट बन जाने के बाद, डायरेक्टरी स्ट्रक्चर निम्नानुसार दिखाई देगा wamp/xamppफ़ोल्डर। उस परियोजना के लिए विचार करें, जिसे हमने पिछले अध्याय में बनाया था।

निम्नलिखित फ़ोल्डर और परियोजना के उप-फ़ोल्डर हैं।

एप्लिकेशन

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

नीचे दिए गए फाल्कन वेब एप्लिकेशन के लिए ऐप फ़ोल्डर का विस्तृत दृश्य है।

इसमें कॉन्फ़िगरेशन, कंट्रोलर, लाइब्रेरी, माइग्रेशन, मॉडल और विचार शामिल हैं।

कॉन्फ़िग

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

नियंत्रकों

इस फ़ोल्डर में सभी नियंत्रक शामिल हैं। उनका उपयोग प्रसंस्करण अनुरोधों और प्रतिक्रिया उत्पन्न करने के लिए किया जाता है।

पुस्तकालय

वेब एप्लिकेशन के लिए थर्ड-पार्टी लाइब्रेरी (मौजूदा फाल्कन फ्रेमवर्क के अलावा)।

माइग्रेशन

इस उप-फ़ोल्डर में डेटा माइग्रेशन से जुड़ी सभी फाइलें हैं, जिनका उपयोग किसी अन्य फ्रेमवर्क में भी किया जा सकता है।

मॉडल

मॉडल में डेटाबेस के साथ बातचीत करने के लिए आवश्यक सभी तर्क शामिल हैं। यह वास्तव में डेटा प्रतिनिधित्व के लिए उपयोग किया जाता है।

विचारों

यह वेब एप्लिकेशन से संबंधित सभी विचारों का गठन करता है। ये दृश्य अंतिम उपयोगकर्ताओं को नियंत्रकों की सहायता से प्रदर्शित किए जाते हैं।

कैश

इस निर्देशिका में कैशिंग से संबंधित डेटा शामिल हैं, जो प्रदर्शन को बेहतर बनाने में मदद करता है।

जनता

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

.htaccess फ़ाइल

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

उदाहरण के लिए, किसी वेबसाइट को कॉन्फ़िगर करना संभव है, ताकि यह केवल विशिष्ट आईपी पते के साथ ही उपलब्ध हो .htaccess फ़ाइल।

Model View Controller (MVC)वेब डिज़ाइन किए गए अनुप्रयोगों को विकसित करने के लिए एक सॉफ्टवेयर डिज़ाइन और संरचनात्मक पैटर्न है। यह सॉफ्टवेयर आर्किटेक्चर इसके साथ उपयोगकर्ता की बातचीत से सूचना के प्रतिनिधित्व को अलग करता है।

MVC मॉडल वेब अनुप्रयोगों को तीन तर्क परतों के साथ परिभाषित करता है।

नमूना

मॉडल ऐसी वस्तुएं हैं जो ज्ञान का प्रतिनिधित्व करती हैं। मॉडल और उसके भागों के बीच एक-से-एक संबंध होना चाहिए। इसमें डेटाबेस कनेक्टिविटी और CRUD संचालन करने के लिए उपयोग किए जाने वाले सभी तर्क शामिल हैं।

राय

एक दृश्य अपने मॉडल का एक दृश्य प्रतिनिधित्व है। मॉडल या उसके भागों के साथ इंटरैक्ट देखें और मॉडल से प्रस्तुति के लिए आवश्यक डेटा प्राप्त करें। यह अनुरोध भेजने और उचित प्रतिक्रिया प्राप्त करने के द्वारा प्राप्त किया जाता है। देखें में वह सभी डेटा शामिल हैं जो उपयोगकर्ता देखता है।

नियंत्रक

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

नियंत्रक ऐसे उपयोगकर्ता आउटपुट प्राप्त करता है और इसे उपयुक्त संदेशों में अनुवाद करता है। इन संदेशों को उपयुक्त प्रतिक्रियाओं के रूप में प्रदर्शित करने के लिए उपयोग किया जाता है।

फाल्कन में वर्कफ़्लो

फाल्कन में वर्कफ़्लो इस प्रकार है -

  • उपयोगकर्ता उपयोगकर्ता इंटरफ़ेस (दृश्य) के साथ बातचीत करता है और कुछ विधि / घटना की मदद से बातचीत को बनाए रखा जाता है।

  • इन विधियों और घटनाओं को नियंत्रक द्वारा नियंत्रित किया जाता है।

  • नियंत्रक उपयोगकर्ता की कार्रवाई को अपडेट करके मॉडल तक पहुंचता है।

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

  • इसके मॉडल से प्राप्त डेटा देखें। मॉडल का दृश्य के साथ कोई सीधा संपर्क नहीं है।

  • उपयोगकर्ता इंटरफ़ेस आगे के उपयोगकर्ता इंटरैक्शन की प्रतीक्षा करता है, जो अनुरोध और प्रतिक्रिया के एक नए चक्र के साथ शुरू होता है।

फाल्कन में मॉडल, दृश्य और नियंत्रक के लिए निर्देशिकाएं शामिल हैं। निम्न स्क्रीनशॉट एक बेहतर परिदृश्य देता है।

सभी व्यावसायिक तर्क नियंत्रक में वर्णित हैं, और मॉडल डेटाबेस के साथ बातचीत करता है जिसमें प्रत्येक और प्रत्येक तालिका के संबंध में सभी फाइलें शामिल हैं।

Note -

  • फाल्कन वेब एप्लिकेशन में बनाए गए सभी नियंत्रक फैली हुई हैं Phalcon\Mvc\Controller

  • डेटाबेस टेबल के साथ जुड़े सभी मॉडल फैली हुई हैं \Phalcon\Mvc\Model

वेब एप्लिकेशन के कॉन्फ़िगर फ़ोल्डर में निम्न फाइलें शामिल हैं -

  • config.php
  • loader.php
  • services.php

config.php

इसमें डेटाबेस कनेक्टिविटी और निर्देशिका पथ के अनुसार मार्ग के लिए कॉन्फ़िगरेशन शामिल हैं।

<?php 

/*
   * Modified: preppend directory path of current file, 
      because of this file own different ENV under between Apache and command line. 
   * NOTE: please remove this comment. 
*/ 

defined('BASE_PATH') || define('BASE_PATH', getenv('BASE_PATH') ?: 
   realpath(dirname(__FILE__) . '/../..')); 
defined('APP_PATH') || define('APP_PATH', BASE_PATH . '/app');  

return new \Phalcon\Config([ 
   'database' => [ 
      'adapter'     => 'Mysql', 
      'host'        => 'localhost', 
      'username'    => 'root', 
      'password'    => '', 
      'dbname'      => 'test', 
      'charset'     => 'utf8', 
   ], 
   'application' => [ 
      'appDir'         => APP_PATH . '/', 
      'controllersDir' => APP_PATH . '/controllers/', 
      'modelsDir'      => APP_PATH . '/models/', 
      'migrationsDir'  => APP_PATH . '/migrations/', 
      'viewsDir'       => APP_PATH . '/views/', 
      'pluginsDir'     => APP_PATH . '/plugins/', 
      'libraryDir'     => APP_PATH . '/library/', 
      'cacheDir'       => BASE_PATH . '/cache/', 
      'baseUri'        => '/demo1/', 
   ] 
]);

loader.php

यह मौजूदा वर्ग का विस्तार करता है \Phalcon\Loader()। लोडर वर्ग उन निर्देशिकाओं को पंजीकृत करता है जिनके लिए वेब एप्लिकेशन की आवश्यकता होती है।

<?php  
$loader = new \Phalcon\Loader();  

/** 
   * We're a registering a set of directories taken from the configuration file 
*/ 

$loader->registerDirs( [ 
      $config->application->controllersDir, 
      $config->application->modelsDir 
   ] 
)->register();

services.php

यह फ़ाइल उन सभी फ़ंक्शंस को संबद्ध करती है जो वेब प्रोजेक्ट की सेवाओं को कार्यान्वित करते हैं। यह लागू होता हैPhalcon\Diइंटरफेस। यह उन्हें लोड करके सेवाओं के एक निर्भरता इंजेक्शन को भी लागू करता है।

मूल रूप से, config फ़ोल्डर के अंदर services.php फ़ाइल सभी सेवाओं के कंटेनर के रूप में कार्य करती है। यह इंटरफ़ेस डेटाबेस कनेक्शन, कुकीज़ स्थापित करने, एक नया सत्र बनाने या NoSQL डेटाबेस के साथ जुड़ने जैसी सभी सेवाओं को आरंभ करने में मदद करता है।

<?php  

use Phalcon\Mvc\View; 
use Phalcon\Mvc\View\Engine\Php as PhpEngine; 
use Phalcon\Mvc\Url as UrlResolver; 
use Phalcon\Mvc\View\Engine\Volt as VoltEngine; 
use Phalcon\Mvc\Model\Metadata\Memory as MetaDataAdapter; 
use Phalcon\Session\Adapter\Files as SessionAdapter; 
use Phalcon\Flash\Direct as Flash;   

/** 
   * Shared configuration service 
*/ 

$di->setShared('config', function () { 
   return include APP_PATH . "/config/config.php"; 
});  

/** 
   * The URL component is used to generate all kind of urls in the application 
*/ 

$di->setShared('url', function () { 
      $config = $this->getConfig(); 
      $url = new UrlResolver(); 
      $url->setBaseUri($config->application->baseUri);  
   return $url; 
});  

/** 
   * Setting up the view component 
*/ 
   
$di->setShared('view', function () { 
   $config = $this->getConfig();  
   $view = new View(); 
   $view->setDI($this); 
   $view->setViewsDir($config->application->viewsDir);  
   
   $view->registerEngines([ 
      '.volt' => function ($view) { 
         $config = $this->getConfig();  
         $volt = new VoltEngine($view, $this);  
         
         $volt->setOptions([ 
            'compiledPath' => $config->application->cacheDir, 
            'compiledSeparator' => '_' 
         ]);  
         return $volt; 
      }, 
      '.phtml' => PhpEngine::class  
   ]);  
   return $view; 
}); 

/** 
   * Database connection is created based in the parameters defined in the configuration 
      file 
*/ 

$di->setShared('db', function () { 
   $config = $this->getConfig();  
   $class = 'Phalcon\Db\Adapter\Pdo\\' . $config->database->adapter; 
   $connection = new $class([ 
      'host'     => $config->database->host, 
      'username' => $config->database->username, 
      'password' => $config->database->password, 
      'dbname'   => $config->database->dbname, 
      'charset'  => $config->database->charset 
   ]);  
   return $connection; 
});

एमवीसी ढांचे में, "सी" नियंत्रक के लिए खड़ा है जो वेब एप्लिकेशन के स्विचबोर्ड को संदर्भित करता है। नियंत्रक द्वारा किए गए कार्य, दृश्य को मापदंडों को पारित करने में मदद करते हैं ताकि यह उपयोगकर्ता इनपुट के अनुसार प्रदर्शित और प्रतिक्रिया कर सके।

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

एक नियंत्रक की विशेषताएं

controller दृश्य से इनपुट स्वीकार करता है और संबंधित मॉडल के साथ बातचीत करता है।

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

  • एक नियंत्रक मॉडल और दृश्य के बीच मध्यस्थ के रूप में कार्य करता है।

फाल्कन में एक एमवीसी का वर्कफ़्लो

निम्नलिखित उदाहरण फाल्कन में एमवीसी के वर्कफ़्लो को दर्शाता है

फाल्कन में एक नियंत्रक बनाने के लिए कदम

Step 1- कमांड प्रॉम्प्ट की मदद से प्रोजेक्ट पथ पर पुनर्निर्देशित करें। निम्नलिखित स्क्रीनशॉट का संदर्भ लें।

जैसा कि ऊपर स्क्रीनशॉट में कहा गया है, "डेमो" फाल्कन PHP फ्रेमवर्क से जुड़ा प्रोजेक्ट है।

Step 2 - संबंधित कंट्रोलर बनाने के लिए निम्न कमांड का उपयोग करें।

phalcon controller <controller-name>

निम्नलिखित कमांड के सफल निष्पादन पर आउटपुट है।

Note- नियंत्रकों के वर्ग नामों में प्रत्यय "नियंत्रक" होना चाहिए। इसका मतलब है कि एक अच्छा नामकरण सम्मेलन जिसका पालन फाल्कन में किया जाता है।

डिफ़ॉल्ट रूप से, जब एप्लिकेशन को फाल्कन PHP फ्रेमवर्क में बनाया जाता है, तो इसमें "IndexController" नामक एक नियंत्रक शामिल होता है। क्रियाओं को ट्रिगर करने के लिए डिफ़ॉल्ट रूप से यह नियंत्रक है।

यह नियंत्रक अन्य नियंत्रकों के विपरीत नियंत्रक-आधार द्वारा बढ़ाया जाता है जो विस्तारित होता है \Phalcon\Mvc\Controller

Code -

<?php 
class IndexController extends ControllerBase { 
   public function indexAction() { 
      echo "This is my first web application in Phalcon"; 
   } 
}

Output -

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

फाल्कन PHP ढांचे में मॉडल इंटरैक्शन को समझने के लिए, निम्नलिखित चरणों का पालन किया जाना चाहिए।

Step 1 - डेटाबेस का निर्माण।

किसी के लिए LAMP, WAMP, XAMPP सॉफ्टवेयर स्टैक, इसकी मदद से डेटाबेस बनाना काफी आसान है phpmyadmin डेटाबेस उपकरण।

डेटाबेस बनाने के लिए SQL क्वेरी निम्न है।

create database <database-name>

Step 2 - में phpmyadmin अनुभाग, डेटाबेस टैब पर क्लिक करें, डेटाबेस नाम का उल्लेख करें और आगे स्क्रीनशॉट में दिखाए अनुसार क्रिएट बटन पर क्लिक करें।

Step 3 - एक बार डेटाबेस सफलतापूर्वक बनने के बाद, एक तालिका बनाएं जो फाल्कन फ्रेमवर्क में एक मॉडल बनाने के लिए इसके सहयोग में मदद करेगा।

"उपयोगकर्ताओं" नामक एक नई तालिका बनाने के लिए निम्नलिखित क्वेरी का उपयोग करें।

DROP TABLE IF EXISTS `users`;  

CREATE TABLE `users` ( 
   `id` int(11) NOT NULL AUTO_INCREMENT, 
   `name` varchar(25), 
   `emailid` varchar(50), 
   `contactNumber` number 
   PRIMARY KEY (`id`) 
) 
ENGINE = InnoDB DEFAULT CHARSET = utf8;

एक बार तालिका बनाने के बाद, इसकी संरचना निम्न स्क्रीनशॉट की तरह दिखाई देती है।

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

Step 5 - फाल्कन फ्रेमवर्क में किसी भी मॉडल को बनाने के लिए निम्न कमांड का उपयोग करें।

phalcon model <model-name>

निम्नलिखित कमांड के निष्पादन पर आउटपुट है।

इसका मतलब है कि मॉडल सफलतापूर्वक बनाया गया है।

Step 6- सफलतापूर्वक बनाया गया मॉडल मॉडल फ़ोल्डर में मौजूद है। मॉडल कहाँ बनाया गया है यह देखने के लिए निम्न पथ का उपयोग करें।

C:\xampp\htdocs\demo1\app\models

निम्नलिखित के लिए पूरा कोड है Users.php

<?php  

class Users extends \Phalcon\Mvc\Model {
   /**      
      *      
      * @var integer 
      * @Primary 
      * @Identity
      * @Column(type = "integer", length = 11, nullable = false)      
   */      

   public $id; 
   /**
      *
      * @var string
      * @Column(type = "string", length = 25, nullable = true)      
   */ 

   public $name; 
   /**
      *
      * @var string
      * @Column(type = "string", length = 50, nullable = true)
   */      

   public $emailid; 
   /**
      *
      * @var integer
      * @Column(type = "integer", length = 11, nullable = true)
   */      

   public $contactNumber; 
   /**
      * Returns table name mapped in the model.
      *
      * @return string
   */      

   public function getSource() {
      return 'users';
   }  
   /**
      * Allows to query a set of records that match the specified conditions
      *
      * @param mixed $parameters
      * @return Users[]
   */ 

   public static function find($parameters = null) { 
      return parent::find($parameters);
   }  
   /**
      * Allows to query the first record that match the specified conditions
      *
      * @param mixed $parameters
      * @return Users
   */   
   
   public static function findFirst($parameters = null) {
      return parent::findFirst($parameters);
   } 
}

Step 7- नियंत्रक मॉडल और आवश्यक आउटपुट प्राप्त करने के लिए दृश्य के साथ बातचीत करता है। मॉडल के साथ, नियंत्रक बनाने के लिए निम्न कमांड टर्मिनल का उपयोग करें।

Phalcon controller <controller-name>

उपरोक्त आदेश के सफल निष्पादन पर, निम्नलिखित आउटपुट है।

निम्नलिखित के लिए कोड है UserController.php

<?php  

class UsersController extends \Phalcon\Mvc\Controller { 
   public function indexAction() { 
      echo "Users Controller has been called"; 
   } 
}

यदि हम निम्न URL को हिट करते हैं तो आउटपुट प्रदर्शित किया जाएगा - http://localhost/demo1/users

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

विशेष रूप से फाल्कन में, दृश्य वोल्ट कोड, PHP और HTML के होते हैं। वोल्ट मोड में प्रवेश करने के लिए विशेष सीमांकक का एक सेट उपलब्ध है।{% ... %} का उपयोग स्टेटमेंट्स को निष्पादित करने के लिए किया जाता है जैसे कि लूप या असाइन किए गए मान और {{ ... }} टेम्पलेट के लिए एक अभिव्यक्ति का परिणाम प्रिंट करता है।

फाल्कन में दृश्य मूल रूप से दो प्रकारों में वर्गीकृत किए गए हैं -

  • Volt
  • phtml

वाल्ट

निम्नलिखित उस आउटपुट का स्क्रीनशॉट है जिसे हमने प्रोजेक्ट के लिए बनाया था demo1 पिछले अध्याय में।

यह आउटपुट फाइल की मदद से हासिल किया जाता है views/index/index.volt

वोल्ट फ़ाइलों की सुविधाएँ

  • यह C भाषा में लिखा गया एक टेम्प्लेट है और अन्य भाषाओं की तुलना में काफी तेज़ है।

  • इसमें अत्यधिक एकीकृत घटकों का एक सेट शामिल है, जो फाल्कन में बहुत फायदेमंद हैं।

  • इसे स्टैंड-अलोन घटक के रूप में भी इस्तेमाल किया जा सकता है।

  • वोल्ट को शुद्ध PHP कोड में संकलित किया जाता है।

निम्नलिखित के लिए कोड है index.volt जो किसी भी परियोजना के लिए डिफ़ॉल्ट रूप से लोड होता है।

<!--<div class = "page-header"> 
   <h1>Congratulations!</h1> 
</div>--> 

<p>This is my first web application in Phalcon </p> 
<!--<p>You're now flying with Phalcon. Great things are about to happen!</p>

<p>This page is located at <code>views/index/index.volt</code></p>-->

पदानुक्रमित प्रतिपादन

फाल्कन समर्थन श्रेणीबद्ध प्रतिपादन में दृश्य और Phalcon\Mvc\Viewडिफ़ॉल्ट रेंडरिंग घटक के रूप में उपयोग किया जाता है। यह घटक पीएचपी का उपयोग वोल्ट फाइलों की तुलना में इंजन के रूप में करता है जो सी का उपयोग टेम्पलेट भाषा के रूप में करता है।

ये विचार होना चाहिए .phtmlविस्तार। दी गई परियोजना के लिए विचारों की डिफ़ॉल्ट निर्देशिका में निम्नलिखित तीन फाइलें शामिल हैं -

  • Action view- यह दृश्य किसी विशेष कार्रवाई को निष्पादित करने के लिए कहा जाता है। इसे तब दिखाया जाता है जब "शो" कार्रवाई निष्पादित होती है।

  • Controller layout- यह दृश्य लेआउट फ़ोल्डर के अंदर मौजूद है। उदाहरण के लिए,C:\xampp\htdocs\demo\app\views\layouts। यह उपयुक्त नियंत्रक के साथ जुड़े विधि कॉल को आमंत्रित करता है। लेआउट में लागू कोड आवश्यकतानुसार और जब भी लागू किया जाएगा।

  • Main layout - यह लेआउट दृश्य मुख्य कार्रवाई को आमंत्रित करेगा और इसे वेब एप्लिकेशन के भीतर प्रत्येक नियंत्रक या कार्रवाई के लिए दिखाया जाएगा।

.Vtt और .phtml फ़ाइलों के बीच अंतर

.volt .phtml
.volt एक्सटेंशन का उपयोग तब किया जाता है जब एप्लिकेशन में सेट किया गया टेम्पलेट इंजन C में लिखा जाता है .phtml का उपयोग तब किया जाता है जब टेम्पलेट इंजन PHP ही होता है
इसका उपयोग स्टैंड-अलोन घटक के रूप में किया जा सकता है इसे स्टैंड-अलोन घटक के रूप में उपयोग नहीं किया जा सकता है
वोल्ट विचारों को PHP कोड में संकलित किया जाता है phtml फाइलों में स्वयं PHP कोड शामिल होता है ताकि फाल्कन फ्रेमवर्क में संकलन की आवश्यकता न हो

चर

वेरिएबल्स को 'सेट' का उपयोग करके टेम्प्लेट में दिया और बदला गया है

एक ऐलान की घोषणा

{% set fruits = ['Apple', 'Banana', 'Orange'] %}

एक स्ट्रिंग की घोषणा

{% set name = ”John Kennedy” %}

टिप्पणियाँ

टिप्पणियों का उपयोग करके टेम्पलेट में भी जोड़ा जा सकता है {# ... #}सीमांकक। उनके अंदर के सभी पाठ को केवल अंतिम आउटपुट में अनदेखा किया जाता है।

{# note: this is a comment 
   {% set price = 100; %} 
#}

उदाहरण

{% set fruits = ['Apple', 'Banana', 'Orange'] %} 

<h1>Fruits</h1> 

<ul> 
   {% for fruit in fruits %} 
   <li>{{ fruit|e }}</li> 
   {% endfor %} 
</ul>  

{% set robots = ['Voltron', 'Astro Boy', 'Terminator', 'C3PO'] %}  

<ul> 
   {% for robot in robots %} 
   <li>{{ robot }}</li> 
   {% endfor %} 
</ul>

उत्पादन

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

राउटर घटक उन मार्गों को परिभाषित करने की अनुमति देता है जो नियंत्रकों या हैंडलर को मैप किए जाते हैं जिन्हें अनुरोध प्राप्त करना चाहिए। प्राप्त जानकारी के अनुसार एक राउटर एक URI को पार्स करता है।

वेब एप्लिकेशन के प्रत्येक राउटर के दो मोड हैं -

  • एमवीसी मोड
  • मैच केवल मोड

पहला मोड एमवीसी अनुप्रयोगों के साथ काम करने के लिए आदर्श है। फाल्कन में एक मार्ग को परिभाषित करने के लिए सिंटैक्स निम्नलिखित है।

$router = new Router();  

// Define a route 

$router->add( 
   "<URI-Name>", 
   [ 
      "controller" => "<controller-name>", 
      "action"     => "<action-name>", 
   ] 
);

उदाहरण

श्रेणी खोजने के लिए, आइए हम एक मार्ग बनाते हैं routes.php विन्यास फ़ोल्डर का।

एक मार्ग बनाने पर विचार करें जो एक विधि लॉगिन कहेगा जैसा कि हम आह्वान करते हैं “UsersController”। ऐसे मामले में, यह एक मार्ग बनाने का सुझाव दिया गया है जो दिए गए URL को मैप करता है।

<?php  

$router = new Phalcon\Mvc\Router();  

$router->add('/login', array( 
   'controller' => 'users', 
   'action' => 'login', 
));
  
return $router;

उत्पादन

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

इस अध्याय में, हम फाल्कन से संबंधित डेटाबेस कनेक्टिविटी पर चर्चा करेंगे।

डेटाबेस और डिजाइन का निर्माण

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

डेटाबेस का नाम: ब्लॉग-ट्यूटोरियल

डेटाबेस बनाने के लिए प्रयुक्त क्वेरी -

drop database blog-tutorial (if exists) 
create database blog-tutorial

डेटाबेस के निर्माण के बाद, डेटाबेस को निम्न स्क्रीनशॉट में दिखाया गया है।

फाल्कन के निर्माण के लिए आदेशों का उपयोग करता है models, controllers, और यहां तक ​​कि परियोजनाओं। आइए देखें कि यह कैसे काम करता है।

Step 1 - ब्लॉग-ट्यूटोरियल नामक एक प्रोजेक्ट बनाएं।

Step 2 - वेब एप्लिकेशन को कॉन्फ़िगर करें जो उस डेटाबेस से जुड़ता है जिसे हमने ब्लॉग प्रबंधित करने के लिए बनाया था।

<?php  
return new \Phalcon\Config (array ( 
   'database' => array ( 
      'adapter'  => 'Mysql', 
      'host'     => 'localhost', 
      'username' => 'root', 
      // 'dbname'   => 'blog_tutorial', 
      'password' => '', 
      'name'     => 'blog_tutorial', 
   ), 
   'application' => array ( 
      'controllersDir' => __DIR__ . '/../../app/controllers/', 
      'modelsDir'      => __DIR__ . '/../../app/models/', 
      'viewsDir'       => __DIR__ . '/../../app/views/', 
      'baseUri'        => '/blog-tutorial/', 
   ) 
));

हमने अपने आवेदन में एक MySQL डेटाबेस का उपयोग किया है। यदि हम डेटाबेस सॉफ्टवेयर को मिडस्ट्रीम में बदलना चाहते हैं, तो यह बहुत कठिन नहीं होगा, जब तक कि हमारे नए डेटाबेस में समान डेटा संरचना न हो।

PostgreSQL

वेब एप्लिकेशन को कॉन्फ़िगर करें जो PostgreSQL डेटाबेस से कनेक्ट होगा।

यह निम्नलिखित कोड का उपयोग करके प्राप्त किया जा सकता है। सेवाओं में शामिल होंगेPhalcon\Db\Adapter\Pdo\Postgresql

use Phalcon\Db\Adapter\Pdo\Postgresql;  

$config = [ 
   'host'     => 'localhost', 
   'dbname'   => 'blog_tutorial', 
   'port'     => 5432, 
   'username' => 'root', 
   'password' => '' 
];  

$connection = new Postgresql($config);

SQLite

SQLite कनेक्शन को लागू करने के लिए, कॉन्फ़िगरेशन को बढ़ाया जाना चाहिए Phalcon\Db\Adapter\Pdo\Sqlite अमूर्त वर्ग।

<?php  
 
use Phalcon\Db\Adapter\Pdo\Sqlite;  

$connection = new Sqlite(['dbname' => '/tmp/blog_tutorial.sqlite']);

आकाशवाणी

फाल्कन में ओरेकल डेटाबेस कनेक्शन को लागू करने के लिए, कॉन्फ़िगरेशन को बढ़ाया जाना चाहिए Phalcon\Db\Adapter\Pdo\Oracle अमूर्त वर्ग।

<?php  

use Phalcon\Db\Adapter\Pdo\Oracle;  

$config = array ( 
   "dbname" => "//localhost/blog_tutorial", 
   "username" => "root", 
   "password" => "" 
); 

$connection = new Phalcon\Db\Adapter\Pdo\Oracle($config);

मचान आमतौर पर एक प्रकार की कोड पीढ़ी को संदर्भित करता है जहां हम इसे वेब एप्लिकेशन डेटाबेस पर इंगित करते हैं, जिसके परिणामस्वरूप एक मूल सीआरयूडी (क्रिएट, रीड, अपडेट, डिलीट) एप्लिकेशन तैयार होता है।

सीआरयूडी एप्लिकेशन को डिजाइन करने से पहले, एप्लिकेशन की आवश्यकता के अनुसार डेटाबेस टेबल डिजाइन करना महत्वपूर्ण है।

Step 1 - एक मचान अनुप्रयोग बनाएं जिसमें सभी क्रूड संचालन शामिल होंगे।

Command: phalcon scaffold <table-name>

फाल्कन के मचान जनरेटर को एक बार निष्पादित करने के बाद निम्न तालिका में वर्णित फ़ाइलों और फ़ोल्डरों का निर्माण होगा।

Step 2 - एक इंडेक्स पेज (phtml और वोल्ट का कॉम्बिनेशन) बनाएं।

उपयोगकर्ताओं फ़ोल्डर में index.phtml में शामिल होने के लिए कोड।

<?php use Phalcon\Tag as Tag ?> 
<!DOCTYPE html> 
<html> 
   <head> 
      <meta charset = "utf-8"> 
      <title>Blog Tutorial</title> 
      <link rel = "stylesheet" type = "text/css" 
         href = "http://netdna.bootstrapcdn.com/twitter-bootstrap/2.2.1/css/bootstrapcombined.min.css"/> 
      <meta name = "viewport" content = "width = device-width, initial-scale = 1.0"> 
   </head> 
   
   <body>  
      <div class = "navbar navbar-fixed-top"> 
         <div class = "navbar-inner"> 
            <div class = "container"> 
               <a class = "btn btn-navbar" data-toggle = "collapse" datatarget = ".nav-collapse"> 
                  <span class = "icon-bar"></span> 
                  <span class = "icon-bar"></span> 
                  <span class = "icon-bar"></span> 
               </a> 
               <a class = "brand" href = "#">Blog Collection</a> 
               
               <div class = "nav-collapse"> 
                  <ul class = "nav pull-left"> 
                     <li> 
                        <?php echo Phalcon\Tag::linkTo('index', 'Home Page') ?> 
                     </li> 
                     
                     <?php if ($this->session->has('auth')) { ?> 
                        <li> 
                           <?php echo Phalcon\Tag::linkTo('posts/index', '+Posts') ?> 
                        </li> 
                     
                        <li> 
                           <?php echo Phalcon\Tag::linkTo('categories/index', '+Categories') ?> 
                        </li> 
                     
                        <li> 
                           <?php echo Phalcon\Tag::linkTo('users/logout', 'Log out') ?> 
                        </li> 
                     <?php } else { ?> 
                        <li> 
                           <?php echo Phalcon\Tag::linkTo('users/index', 'Log in') ?> 
                        </li> 
                     <?php } ?> 
                  </ul> 
               </div> 
               
            </div> 
         </div>  
      </div>
      <?php echo $this->getContent() ?>  
      
      <script src = "http://netdna.bootstrapcdn.com/twitterbootstrap/2.2.1/js/bootstrap.min.js"></script> 
   </body> 
</html>

डिफ़ॉल्ट फ़ाइल index.volt निम्नलिखित कोड शामिल होंगे।

<?php echo $this->getContent() ?>  

<div align = "center">  
   <h1>Welcome!</h1>  
   <p>Welcome to the blog collection of Phalcon</p>  
</div>

उपरोक्त कोड का सफल निष्पादन निम्नलिखित आउटपुट का उत्पादन करता है।

Step 3 - संबंधित मॉडल के साथ बदलें।

Users.php

<?php  

class Users extends \Phalcon\Mvc\Model {  
   /** 
      * @var integer 
      * 
   */ 
   
   public $id;  
   /** 
      * @var string 
      * 
   */ 
    
   public $login;  
   /** 
      * @var string 
      * 
   */ 
   
   public $password; 
   /** 
      * Initializer method for model. 
   */ 
    
   public function initialize() { 
      $this->hasMany("id", "Posts", "users_id"); 
   } 
}

समारोह का नाम ‘initialize’ पोस्ट तालिका में आईडी और users_id के बीच संबंध को लागू करने में मदद करता है, जिसका अर्थ है कि प्रत्येक अद्वितीय उपयोगकर्ता के पास तालिका में जुड़े कई पद हैं।

Posts.php

<?php  

class Posts extends \Phalcon\Mvc\Model {  
   /** 
      * @var integer 
      * 
   */ 
   
   public $id;  
   /** 
      * @var string 
      * 
   */ 
    
   public $title;  
   /** 
      * @var string 
      * 
   */ 
   
   public $slug;  
   /** 
      * @var string 
      * 
   */ 
   
   public $content;  
   /** 
      * @var string 
      * 
   */ 
   
   public $created; 
   /** 
      * @var integer 
      * 
   */ 
   
   public $users_id;  
   /** 
      * @var integer 
      * 
   */ 
    
   public $categories_id;   
   /** 
      * Initializer method for model. 
      */ 
   
   public function initialize() { 
      $this->belongsTo("users_id", "Users", "id"); 
      $this->belongsTo("categories_id", "Categories", "id"); 
   } 
}

कार्यक्रम ‘initialize’ टेबल के साथ विदेशी कुंजी और प्राथमिक कुंजी संबंध का उल्लेख करते हुए संबंध बाधा भी शामिल है।

users_id "उपयोगकर्ता" तालिका में आईडी को संदर्भित करता है।

categories_id आईडी को "श्रेणियाँ" तालिका में संदर्भित करता है।

Categories.php

<?php  

class Categories extends \Phalcon\Mvc\Model {  
   /** 
      * @var integer 
      * 
   */ 

   public $id;  
   /** 
      * @var string 
      * 
   */ 

   public $name;  
   /** 
      * @var string 
      * 
   */ 

   public $slug;   
   /** 
      * Initializer method for model. 
   */ 
   
   public function initialize() { 
      $this->hasMany("id", "Posts", "categories_id"); 
   } 
}

उपयोगकर्ता मॉडल के समान, ए ‘initialize’ फ़ंक्शन निर्दिष्ट करता है कि इसमें कई शामिल हैं categories_id दिए गए पोस्ट के लिए।

लॉगिन पेज डिजाइन करना

दृश्य बनाना

निम्नलिखित ब्लॉग-ट्यूटोरियल-मास्टर प्रोजेक्ट की पूरी संरचना है।

उपयोगकर्ता सफलतापूर्वक लॉग इन करने के बाद होम पेज प्रदर्शित करने के लिए संबंधित दृश्य “index.phtml”

<?php use Phalcon\Tag as Tag ?> 
<!DOCTYPE html> 
<html> 
   <head> 
      <meta charset = "utf-8"> 
      <title>Blog Tutorial</title> 
      <link rel = "stylesheet" type = "text/css" href = "http://netdna.bootstrapcdn.com/twitter-bootstrap/2.2.1/css/bootstrapcombined.min.css"/> 
      <meta name = "viewport" content = "width = device-width, initial-scale = 1.0"> 
   </head> 

   <body>  
      <div class = "navbar navbar-fixed-top"> 
         <div class = "navbar-inner"> 
            <div class = "container"> 
               <a class = "btn btn-navbar" data-toggle = "collapse" datatarget = ".nav-collapse"> 
                  <span class = "icon-bar"></span> 
                  <span class = "icon-bar"></span> 
                  <span class = "icon-bar"></span> 
               </a> 
               <a class = "brand" href = "#">Blog Collection</a> 
               
               <div class = "nav-collapse"> 
                  <ul class = "nav pull-left"> 
                     <li> 
                        <?php echo Phalcon\Tag::linkTo('index', 'Home Page') ?> 
                     </li> 
                     <?php if ($this->session->has('auth')) { ?> 
                        <li> 
                           <?php echo Phalcon\Tag::linkTo('posts/index', '+Posts') ?> 
                        </li> 
                        
                        <li> 
                           <?php echo Phalcon\Tag::linkTo('categories/index', '+Categories') ?> 
                        </li> 
                        
                        <li> 
                           <?php echo Phalcon\Tag::linkTo('users/logout', 'Log out') ?> 
                        </li> 
                     <?php } else { ?> 
                        <li>
                           <?php echo Phalcon\Tag::linkTo('users/index', 'Log in') ?> 
                        </li> 
                     <?php } ?> 
                  </ul> 
               </div>
               
            </div> 
         </div>
      </div>            
      <?php echo $this->getContent() ?>  
      <script src = "http://netdna.bootstrapcdn.com/twitterbootstrap/2.2.1/js/bootstrap.min.js"></script> 
   </body> 
</html>

श्रेणी प्रबंधन

फाल्कन क्वेरी लैंग्वेज (PHQL) को भी कहा जाता है PhalconQL एक उच्च स्तरीय एसक्यूएल बोली है जो फाल्कन द्वारा समर्थित डेटाबेस सिस्टम के लिए एसक्यूएल प्रश्नों का मानकीकरण करती है।

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

यहाँ फाल्कन क्वेरी भाषा की कुछ प्रमुख विशेषताओं की सूची दी गई है -

  • वेब एप्लिकेशन की सुरक्षा के लिए, यह बाध्य मापदंडों का उपयोग करता है।

  • टेबल्स को मॉडल के रूप में माना जाता है जबकि कॉलम को क्लास की विशेषताओं के रूप में माना जाता है।

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

  • SQL क्वेरी को एक बार में SQL क्वेरी कॉल रखने से रोका जाता है।

PHQL क्वेरी बनाना

क्वैश्चिंग क्लास द्वारा क्वैरी बनाई जाती हैं Phalcon\Mvc\Model\Query

उदाहरण

// Instantiate the Query 
$query = new Query( 
   "SELECT * FROM Users", 
   $this->getDI() 
);  

// Execute the query returning a result if any 
$cars = $query->execute();

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

निम्नलिखित खोज के लिए शामिल कोड है।

public function searchAction() {  
   $numberPage = 1; 
   if ($this->request->isPost()) { 
      $query = Criteria::fromInput($this->di, "Categories", $_POST); 
      $this->session->conditions = $query->getConditions(); 
   } else { 
      $numberPage = $this->request->getQuery("page", "int"); 
      if ($numberPage <= 0) { 
         $numberPage = 1; 
      } 
   } 
   
   $parameters = array(); 
   if ($this->session->conditions) { 
      $parameters["conditions"] = $this->session->conditions; 
   } 
   
   // $parameters["order"] = "id"; 
   $categories = Categories::find($parameters); 
   if (count($categories) == 0) { 
      $this->flash->notice("The search did not find any categories"); 
      
      return $this->dispatcher->forward(array( 
         "controller" => "categories", 
         "action" => "index" 
      )); 
   } 
   
   $paginator = new \Phalcon\Paginator\Adapter\Model(array( 
      "data" => $categories, 
      "limit"=> 10, 
      "page" => $numberPage 
   )); 
   
   $page = $paginator->getPaginate(); 
   $this->view->setVar("page", $page); 
}

नियंत्रक में निष्पादित (हाइलाइट) PHQL क्वेरी खोज स्थिति के अनुसार सभी परिणाम लाएगा। स्क्रीनशॉट के अनुसार किसी भी खोज क्वेरी का परिणाम स्क्रीनशॉट में प्रदर्शित किया जाएगा।

निम्नलिखित कोड के सफल निष्पादन पर प्राप्त आउटपुट है।

PHQL जीवन चक्र

उच्च-स्तरीय भाषा होने के नाते, पीएचक्यूएल डेवलपर्स को आवश्यकताओं के अनुसार विभिन्न पहलुओं को निजीकृत और अनुकूलित करने की क्षमता प्रदान करता है।

फाल्कन में निष्पादित प्रत्येक PHQL बयान का जीवन चक्र निम्नलिखित है -

  • हर PHQL स्टेटमेंट को पार्स और इंटरमीडिएट रिप्रेजेंटेशन (IR) के रूप में परिवर्तित किया जाता है, जो डेटाबेस सिस्टम द्वारा कार्यान्वित SQL से पूरी तरह स्वतंत्र होता है।

  • IR को डेटाबेस सिस्टम के अनुसार SQL स्टेटमेंट में परिवर्तित किया जाता है जो वेब एप्लिकेशन में उपयोग किया जाता है। उत्पन्न एसक्यूएल बयान मॉडल के साथ जुड़े हुए हैं।

  • सभी PHQL बयानों को एक बार पार्स किया जाता है और मेमोरी में कैश किया जाता है। यदि एक ही कथन परिणाम निष्पादित किया जाता है, तो यह तेज प्रदर्शन में मदद करेगा।

डेटाबेस माइग्रेशन निम्न कारणों से महत्वपूर्ण है -

  • डेटाबेस माइग्रेशन निर्दिष्ट भंडारण प्रकारों के बीच डेटा स्थानांतरित करने में मदद करता है।

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

  • यह प्रक्रिया आमतौर पर डेटा का ट्रैक रखने के लिए होती है जो पुराना हो रहा है।

फाल्कन निम्नलिखित तरीके से डेटाबेस माइग्रेशन प्रक्रिया करता है -

Step 1 - नाम से एक प्रोजेक्ट बनाएं “dbProject” में xampp/wamp निर्देशिका।

Step 2 - उचित डेटाबेस कनेक्टिविटी के साथ प्रोजेक्ट को कॉन्फ़िगर करें।

<?php 

/*  
   * Modified: preppend directory path of current file, 
      because of this file own different ENV under between Apache and command line.  
   * NOTE: please remove this comment.  
*/

defined('BASE_PATH') || define('BASE_PATH', getenv('BASE_PATH') ?: realpath(dirname(__FILE__) . '/../..')); 
defined('APP_PATH') || define('APP_PATH', BASE_PATH . '/app');  
return new \Phalcon\Config(['database' => [
   'adapter' => 'Mysql', 
   'host' => 'localhost', 
   'username' => 'root', 
   'password' => '', 
   'dbname' => 'demodb', 
   'charset' => 'utf8', ],

'application' => [ 'appDir' => APP_PATH . '/', 
   'controllersDir' => APP_PATH . 
   '/controllers/', 'modelsDir' => APP_PATH . 
   '/models/', 'migrationsDir' => APP_PATH . 
   '/migrations/', 'viewsDir' => APP_PATH . 
   '/views/','pluginsDir' => APP_PATH . 
   '/plugins/', 'libraryDir' => APP_PATH . 
   '/library/', 'cacheDir' => BASE_PATH . 
   '/cache/', 'baseUri' => '/dbProject/', 
] ]);

Step 3- डेटाबेस "demodb" के भीतर शामिल तालिकाओं के प्रवास के लिए कमांड निष्पादित करें। अभी के लिए, इसमें एक तालिका "उपयोगकर्ता" शामिल है।

Step 4 - माइग्रेट की गई फ़ाइलों को "एप्लिकेशन" फ़ोल्डर में माइग्रेशन निर्देशिका के अंदर संग्रहीत किया जाता है।

इस प्रकार, तालिकाओं को सफलतापूर्वक माइग्रेट किया जाता है।

माइग्रेटेड फ़ाइलों के एनाटॉमी को समझना

माइग्रेटेड फ़ाइल में एक विशिष्ट वर्ग होता है जो विस्तारित होता है Phalcon\Mvc\Model\Migrationकक्षा। फाल्कन में प्रवासन वर्ग में विधियाँ शामिल हैंup() तथा down()up() पद्धति का उपयोग माइग्रेशन करने के लिए किया जाता है, जबकि डाउन विधि ऑपरेशन को वापस रोल करती है।

Users.php

<?php  

use Phalcon\Db\Column; 
use Phalcon\Db\Index; 
use Phalcon\Db\Reference; 
use Phalcon\Mvc\Model\Migration;  

/**  
   * Class UserMigration_100  
*/ 

class UserMigration_100 extends Migration {     
   /**      
      * Define the table structure      
      *      
      * @return void 
   */      
   public function morph() { 
      $this->morphTable('user', [ 
         'columns' => [ 
            new Column( 'Id', [ 
               'type' => Column::TYPE_INTEGER, 
               'notNull' => true, 
               'autoIncrement' => true, 
               'size' => 11, 'first' => true ] ), 
            new Column( 'username', [ 
               'type' => Column::TYPE_VARCHAR, 
               'notNull' => true, 
               'size' => 40, 
               'after' => 'Id' ] ), 
            new Column( 'email', [ 
               'type' => Column::TYPE_VARCHAR, 
               'notNull' => true, 
               'size' => 40, 
               'after' => 'username' ] ), 
            new Column( 'password', [ 
               'type' => Column::TYPE_VARCHAR, 
               'notNull' => true, 
               'size' => 10, 
               'after' => 'email' ] ) 
         ],  
         'indexes' => [new Index('PRIMARY', ['Id'], 'PRIMARY') ], 
            'options' => [ 'TABLE_TYPE' => 'BASE TABLE', 
               'AUTO_INCREMENT' => '3', 'ENGINE' => 'InnoDB', 
               'TABLE_COLLATION' => 'latin1_swedish_ci' ], 
      ] ); 
   }  
   
   /**      
      * Run the migrations      
      *      * @return void      
   */     

   public function up() {  
   }  

   /**      
      * Reverse the migrations      
      *
      * @return void      
   */
   public function down() {  
   } 
}

कक्षा UserMigration_100 जैसा कि ऊपर दिए गए उदाहरण में दिखाया गया है चार वर्गों के साथ साहचर्य सरणी शामिल हैं जो हैं -

  • Columns - टेबल कॉलम का एक सेट शामिल है।

  • Indexes - टेबल इंडेक्स का एक सेट शामिल है।

  • References - सभी संदर्भात्मक अखंडता बाधाओं (विदेशी कुंजी) शामिल हैं।

  • Options - तालिका निर्माण विकल्पों के एक सेट के साथ सरणी।

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

कुकीज़ के रूप में भी जाना जाता है browser cookiesब्राउज़र में संग्रहीत छोटी पाठ फ़ाइलें हैं। यह उपयोगकर्ता की पहचान से संबंधित सभी जानकारी को बचाता है। यह जानकारी विभिन्न पृष्ठों के माध्यम से ब्राउज़ करने के बाद उपयोगकर्ताओं को मान्य करने के लिए उपयोग की जाती है।

कुकीज़ के दो अलग-अलग प्रकार हैं -

  • Session Cookies- इस प्रकार की कुकीज़ ब्राउज़र पर रहती हैं और ब्राउज़र के बंद होने तक जानकारी को बनाए रखती हैं। जैसे ही ब्राउज़र खोला जाता है, इसे उसी उपयोगकर्ता के लिए एक नए सत्र के रूप में माना जाएगा।

  • Persistent Cookies- इसमें एक निर्धारित जीवनकाल शामिल है और दिए गए जीवनकाल के भीतर ब्राउज़र में रहता है। वे वेबसाइटें जो लगातार कुकीज़ का उपयोग करती हैं, प्रत्येक उपयोगकर्ता का ध्यान रखती हैं, भले ही उपयोगकर्ता द्वारा ब्राउज़र को बंद कर दिया गया हो।

आइए अब चर्चा करते हैं कि फाल्कन में कुकीज़ कैसे काम करती हैं।

फाल्कन में कुकीज़

फाल्कन उपयोग करता है Phalcon\Http\Response\Cookiesकुकीज़ के लिए एक वैश्विक भंडारण के रूप में। सर्वर से अनुरोध भेजने के दौरान फाल्कन में कुकीज़ संग्रहीत की जाती हैं।

कुकी स्थापित करने के लिए निम्नलिखित सिंटैक्स है -

$this->cookies->set( 
   "<cookie-name>", 
   "<cookie-value>", 
   time 
);

निम्नलिखित उदाहरण पर विचार करें। निम्नलिखित कोड का उपयोग करके, हम उपयोगकर्ता के कुकीज़ तब बनाएंगे जब उपयोगकर्ता वेब एप्लिकेशन में लॉग इन करेगा।

<?php  

class UsersController extends \Phalcon\Mvc\Controller { 
   public function indexAction() { 
      if ($this->cookies->has("login-action")) { 
         // Get the cookie 
         $loginCookie = $this->cookies->get("login-action"); 
         
         // Get the cookie's value 
         $value = $loginCookie->getValue(); 
         echo($value); 
      } 
      $this->cookies->set( 
         "login-action", 
         "abc", 
         time() + 15 * 86400 
      ); 
   } 
}

एन्क्रिप्टेड कुकीज़ को आउटपुट के रूप में प्रदर्शित किया जाएगा।

विवरण

कुकी नाम दिया “loginAction” मूल्य के साथ बनाया गया है “abc”

प्रक्रिया “indexAction” जाँचता है कि कुकी मौजूद है या नहीं और उसके अनुसार मूल्य प्रिंट करता है।

कुकीज़ का एन्क्रिप्शन

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

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

/** 
   * Enable encryption key for setting values of cookies 
*/  

$di->set( 
   "cookies", function () { 
      $cookies = new Cookies();  
      $cookies->useEncryption(false);  
      return $cookies; 
   } 
); 

/** 
   * Set encryption key 
*/ 

$di->set( 
   "crypt", function () { 
      $crypt = new Crypt(); 
      $crypt->setKey('AED@!sft56$'); // Use a unique Key!  
      return $crypt; 
   } 
);

Note -

  • सर्वर पर कुकीज़ भेजते समय हमेशा एन्क्रिप्शन का उपयोग करने का सुझाव दिया जाता है।

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

  • कुकीज़ में छोटे डेटा और शाब्दिक रूप से संग्रहीत करने की भी सिफारिश की जाती है।

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

फाल्कन में सत्र

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

फाल्कन में विशेषताएं निम्नलिखित हैं -

  • एक ही डोमेन पर सत्र डेटा को अन्य घटकों से अलग किया जा सकता है।

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

फाल्कन में एक सत्र शुरू करना

सभी सत्र गतिविधियाँ एडेप्टर फ़ाइलों के साथ जुड़ी होती हैं, जिन्हें घोषित किया जाता है Services.php अंदर फ़ाइल करें /config वेब एप्लिकेशन का फ़ोल्डर।

/** 
   * Start the session the first time some component requests the session service 
*/ 
$di->setShared('session', function () { 
   $session = new SessionAdapter(); 
   $session->start();  
   return $session; 
});

एक सत्र बनाना

Step 1 - एक सत्र को तत्काल करने के लिए एक सत्र नियंत्रक बनाएं जैसे कि डेटा को उचित रूप से पुनर्प्राप्त किया जा सकता है।

Step 2 - एक नाम और मूल्य के साथ एक सत्र बनाएँ।

<?php  

class SessionController extends \Phalcon\Mvc\Controller { 
   public function indexAction() { 
      //Define a session variable 
      $this->session->set("user-name", "Omkar"); 
      
      //Check if the variable is defined 
      if ($this->session->has("user-name")) { 
         //Retrieve its value 
         $name = $this->session->get("user-name"); 
         echo($name); 
      } 
   } 
}

उपरोक्त कोड निम्नलिखित आउटपुट का उत्पादन करता है।

एक सत्र निकालना

सत्र को नष्ट करना संभव है या फाल्कन में सत्र के भीतर कुछ चर मूल्यों को परेशान करना संभव है।

सत्र में चर मानों को अनसेट करने के लिए सिंटैक्स है।

$this->session->remove(<variable-name>);

जैसा कि ऊपर दिए गए उदाहरण में दिखाया गया है, सत्र में बनाया गया चर नाम है “data-content” जिसे निम्नलिखित कोड का उपयोग करके हटाया जा सकता है।

public function removeAction() { 
   // Remove a session variable with associated session 
   $this->session->remove("data-content"); 
}

पूर्ण सत्र को नष्ट करने के लिए वाक्य रचना निम्नलिखित है।

$this->session->destroy();

फाल्कन में एक घटक शामिल है Phalcon\Translate जो बहुभाषी सहायता प्रदान करता है और यह वेब पेज बनाने में बहुत सहायक होता है, जो कई भाषाओं में अनुवादित होता है।

इसमें एक एडेप्टर शामिल है जो सरणियों को बांधने में मदद करता है और अनुवाद संदेशों को पढ़ने में सहायता करता है।

उदाहरण

फाल्कन में अनुवाद घटक की मदद से एक आउटपुट बनाते हैं, जो सुझाए गए भाषा के अनुसार आउटपुट प्रदर्शित करने में मदद करेगा।

Step 1- फाल्कन हर डेवलपर को अनुवाद स्ट्रिंग को व्यवस्थित करने की स्वतंत्रता देता है। दो अलग-अलग फ़ाइलों को रखने पर विचार करें:en.php (अंग्रेजी तार के लिए) और fr.php (फ्रेंच स्ट्रिंग्स के लिए)।

फ़ाइल में की-वैल्यू पेयर की एक सरणी होगी, जहाँ कुंजियाँ अद्वितीय हैं और मान अनुवाद के अनुसार भिन्न होंगे।

en.php

<?php  

// app/messages/en.php 

$messagesContent = [ 
   "bye"     => "Good Bye", 
   "hi-name" => "Hello %name%", 
   "song"    => "Your favorite song is %song%", 
];

fr.php

<?php 

// app/messages/fr.php 

$messagesContent = [ 
   "bye"        => "Au revoir", 
   "hello-name" => "Bonjour %name%", 
   "song"       => "Votre chanson préférée est %song%", 
];

Step 2 - एक आवेदन में, एक बनाएँ UserController जो मापदंडों के रूप में ले जाएगा जो फ़ाइल अनुवाद के लिए इस्तेमाल किया जाना चाहिए।

<?php 

use Phalcon\Translate\Adapter\NativeArray; 

class UserController extends \Phalcon\Mvc\Controller {  
   protected function getMessageTransalation() { 
      // Ask for the best language 
      // Display the output in desired language 
      require "en.php";   
      
      // Return a translation object 
      return new NativeArray( ["content" => $messagesContent,]); 
   }  
   public function indexAction() { 
      $this->view->name = "Radhika"; 
      $this->view->song= "Ton sourire m'ensorcelle Je suis fou de toi Le désir coule dans mes veines Guidé par ta voix"; 
      $this->view->t    = $this->getMessageTransalation(); 
   } 
}

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

अभी के लिए, हम अंग्रेजी में आउटपुट चाहते हैं।

Step 3 - संबंधित code view demo\app\views\User\index.volt निम्नलिखित कोड शामिल होंगे -

<p><?php echo $t->_("hello-name", ["name" => $name]); ?></p> 
<p><?php echo $t->_("song", ["song" => $song]); ?></p>

यदि हम चाहते हैं कि पूर्ण आउटपुट फ़्रेंच में प्रदर्शित हो, तो हमें केवल फ़ाइल का नाम बदलना होगा।

require "fr.php";

निम्नलिखित फ्रेंच में उत्पादन है।

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

उपयोग की जाने वाली सामान्य विधियाँ हैं -

तरीका महत्त्व
__construct (चर $ विकल्प) घटक Phalcon \ Assets \ Manager को प्रारंभ करता है
addCss (स्ट्रिंग $ पथ, चर $ स्थानीय, चर $ फ़िल्टर, चर $ विशेषताएँ) सीएसएस संसाधन को 'सीएसएस' संग्रह से एक विशेष दृश्य में जोड़ता है
addJs (स्ट्रिंग $ पथ, चर $ स्थानीय, चर $ फ़िल्टर, चर $ विशेषताएँ) जावास्क्रिप्ट संसाधन को 'js' संग्रह में जोड़ता है

उदाहरण

फाल्कन की नमूना परियोजना पर विचार करें “vokuro” जो जोड़ने के लिए सबसे अच्छा चित्रण है cssफ़ाइलें। इसमें सभी को शामिल करने के लिए संपत्ति / प्रबंधक शामिल होंगेcss फ़ाइलें।

परियोजना के लिए डिफ़ॉल्ट नियंत्रक सभी को आमंत्रित करेगा css फ़ाइलें।

<?php 

namespace Vokuro\Controllers; 
use Phalcon\Assets\Manager;  

/** 
   * Display the default index page. 
*/ 

class IndexController extends ControllerBase {  
   /** 
      * Default action. Set the public layout (layouts/public.volt) 
   */ 
   public function indexAction() { 
      $this->assets->addCss("public/style.css"); 
      $this->view->setVar('logged_in', is_array($this->auth->getIdentity())); 
      $this->view->setTemplateBefore('public'); 
   } 
}

style.css

div.remember { 
   margin-top: 7px; 
   color: #969696; 
}  
div.remember label { 
   padding-top: 15px; 
}  
div.forgot { 
   margin-top: 7px; 
   color: #dadada; 
}  
footer { 
   background: url("../img/feature-gradient.png") no-repeat scroll center 100% white; 
   color: #B7B7B7; 
   font-size: 12px; 
   padding: 30px 0; 
   text-align: center; 
}  
footer a { 
   margin-left: 10px; 
   margin-right: 10px; 
}  
table.signup td { 
   padding: 10px; 
}  
table.signup .alert { 
   margin-bottom: 0; 
   margin-top: 3px; 
}  
table.perms select { 
   margin-top: 5px; 
   margin-right: 10px; 
}  
table.perms label { 
   margin-right: 10px; 
}  
div.main-container { 
   min-height: 450px; 
}

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

Index.volt

{{ content() }} 
{{ assets.outputCss() }} 

<header class = "jumbotron subhead" id = "overview"> 
   <div class = "hero-unit"> 
      <h1>Welcome!</h1> 
      <p class = "lead">This is a website secured by Phalcon Framework</p> 
      <div align = "right"> 
         {{ link_to('session/signup', '<i class="icon-ok icon-white">
            </i> Create an Account', 'class': 'btn btn-primary btn-large') }} 
      </div> 
   </div> 
</header>

उत्पादन

यह निम्नलिखित उत्पादन का उत्पादन करेगा -

अनुरोध के रूप में उपयोगकर्ता से इनपुट स्वीकार करने के लिए सभी वेब एप्लिकेशन में फॉर्म का उपयोग किया जाता है। डेटा को इनपुट के रूप में स्वीकार किया जाता है, फिर डेटाबेस में हेरफेर और सहेजा जाता है या कोई अन्य ऑपरेशन किया जा रहा है।

फाल्कन में एक घटक शामिल है जिसका नाम है Phalcon\Forms जो रूपों के निर्माण और रखरखाव में मदद करता है।

ब्लॉग-ट्यूटोरियल के उदाहरण पर विचार करें, जिसे हमने पिछले अध्यायों में बनाया था। इसमें एक फॉर्म शामिल है जिसका उपयोग एक नई श्रेणी बनाने के लिए किया जाता है।

<?php echo \Phalcon\Tag::form(array("categories/create", "autocomplete" => "off")) ?>  
   <table width = "100%"> 
      <tr> 
         <td align = "left">
            <?php echo \Phalcon\Tag::linkTo(array("categories", "Go Back", "class" => "btn")) ?>
         </td> 
         <td align = "right"><
            ?php echo \Phalcon\Tag::submitButton(array("Save", "class" => "btn")) ?>
         </td> 
      <tr> 
   </table>  
   
   <?php echo $this->getContent(); ?>  
   
   <div align = "center"> 
      <h1>Create categories</h1> 
   </div>  
   <table align = "center"> 
      <tr> 
         <td align = "right"> 
            <label for = "name">Name</label> 
         </td> 
         <td align = "left"> 
            <?php echo \Phalcon\Tag::textField(array("name", "size" => 30)) ?> 
         </td> 
      </tr> 
     
      <tr> 
         <td align = "right"> 
            <label for = "slug">Slug</label> 
         </td> 
         <td align = "left"> 
            <?php echo \Phalcon\Tag::textField(array("slug", "size" => 30)) ?> 
         </td> 
      </tr> 
   </table> 
</form>

Output - यह निम्नलिखित आउटपुट का उत्पादन करेगा।

प्रपत्र के इनपुट फ़ील्ड की सहायता से प्रदान किए जाते हैं Phalcon/tagघटक। प्रपत्र में प्रत्येक तत्व को डेवलपर की आवश्यकता के अनुसार प्रदान किया जा सकता है।

निम्नलिखित मान प्रदान करने के लिए सिंटैक्स है।

echo $form->render(element-name)

Validation -

एक बार नियंत्रक में मान प्रदान किए जाने के बाद, मूल्यों को मॉडल की मदद से डेटाबेस में दर्ज किया जाएगा। फाल्कन रूपों को तत्काल सत्यापन की पेशकश करने के लिए सत्यापन घटक के साथ एकीकृत किया जाता है। अंतर्निहित या कस्टम सत्यापनकर्ता प्रत्येक तत्व पर सेट किए जा सकते हैं।

<?php  
use Phalcon\Forms\Element\Text; 
use Phalcon\Validation\Validator\PresenceOf; 
use Phalcon\Validation\Validator\StringLength;  

$name = new Text( 
   "Name" 
); 

$name->addValidator( 
   new PresenceOf([ "message" => "name is required", ]) 
); 

$form->add($name);

Output - यह निम्नलिखित आउटपुट का उत्पादन करेगा।

की अवधारणाओं के साथ शुरू करने से पहले Object Relational Mapper (ORM) और ऑब्जेक्ट डॉक्यूमेंट मैपर (ODM), SQL और NoSQL डेटाबेस के बीच अंतर को समझना महत्वपूर्ण है।

निम्न तालिका SQL और NoSQL के बीच के अंतर को उजागर करती है -

एसक्यूएल NoSQL
उन्हें रिलेशनल डेटाबेस (RDBMS) भी कहा जाता है उन्हें गैर-संबंधपरक या वितरित डेटाबेस कहा जाता है
डेटाबेस की संरचना तालिकाओं और विचारों के रूप में गठित की जाती है इसमें दस्तावेज़ आधारित और ग्राफ़ डेटाबेस शामिल हैं
इसमें एक पूर्वनिर्धारित स्कीमा शामिल है इसमें डायनेमिक स्कीमा है
यह डेटा को परिभाषित करने और हेरफेर करने के लिए बहुत शक्तिशाली है यह दस्तावेजों के संग्रह के रूप में डेटा को बनाए रखने में शक्तिशाली है

फाल्कन में SQL और NoSQL डेटाबेस के साथ मैप करने की क्षमता है। यह SQL डेटाबेस के लिए ऑब्जेक्ट दस्तावेज़ मैपर (ODM) की मदद से और SQL डेटाबेस के लिए ऑब्जेक्ट रिलेशनल मैपर (ORM) के साथ प्राप्त किया गया है।

फाल्कन में, ORM अवधारणा में दिए गए तालिका-नाम से जुड़ा एक मॉडल बनाना शामिल है जैसा कि हमने पिछले अध्यायों में देखा है। यह सभी संदर्भात्मक अखंडता बाधाओं का अनुसरण करता है।

ऑब्जेक्ट दस्तावेज़ मैपर (ODM)

यह NoSQL डेटाबेस से जुड़ी वस्तु है। जैसा कि नाम से पता चलता है कि यह दस्तावेज़ से संबंधित मॉड्यूल को मैप करता है। फाल्कन इसका उपयोग MongoDB जैसे डेटाबेस के साथ मैप करने के लिए करता है।

उदाहरण

Step 1 - MongoDB नाम का एक डेटाबेस बनाएं “test”। हम इस डेटाबेस का उपयोग मानचित्र के साथ करेंगे और उचित प्रतिक्रिया प्राप्त करेंगे।

Step 2- डेटाबेस में सम्मिलित रिकॉर्ड की जाँच करें। इससे जुड़ी कमांड है -

db.collection.find()

यह देखा गया है कि हर दस्तावेज को ObjectId के साथ मैप किया जाता है जो कि ODM की एक विशेषता है। का मूल्यObjectId अद्वितीय है और बाद में उस विशेष आईडी के संबंध में संग्रहीत सभी डेटा प्राप्त करने के लिए उपयोग किया जाता है।

Step 3- बनाए गए डेटाबेस के लिए मॉडल सेट करें। एक मॉडल एक वर्ग है जो विस्तार करता हैPhalcon\Mvc\CollectionTest.php मॉडल में निम्नलिखित कोड शामिल होंगे।

<?php 
use Phalcon\Mvc\Collection;  

class Test extends Collection { 
   public function initialize() { 
      $this->setSource("test"); 
   } 
}

Step 4 - डेटाबेस कनेक्टिविटी सहित परियोजना को कॉन्फ़िगर करें services.php

// Simple database connection to localhost 

$di->set( 
   "mongo", 
   function () { 
      $mongo = new MongoClient();  
      return $mongo->selectDB("test"); 
   }, 
   true 
); 

// Connecting to a domain socket, falling back to localhost connection 

$di->set( 
   "mongo", 
   function () { 
      $mongo = new MongoClient( 
         "mongodb:///tmp/mongodb-27017.sock,localhost:27017" 
      );  
      return $mongo->selectDB("test"); 
   }, 
   true 
);

Step 5 - सम्मान के साथ मूल्यों को प्रिंट करें ObjectId की मदद से TestController.php

<?php  

use Phalcon\Mvc\Controller;  

class TestController extends Controller { 
   public function index() { 
      // Find record with _id = "5087358f2d42b8c3d15ec4e2" 
      $test = Test::findById("5819ab6cfce9c70ac6087821"); 
      echo $test->data; 
   } 
}

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

फाल्कन सुरक्षा घटक की सहायता से सुरक्षा सुविधाएँ प्रदान करता है, जो पासवर्ड हैशिंग और जैसे कुछ कार्यों को करने में मदद करता है Cross-Site Request Forgery (CSRF)।

पासवर्ड हैक करना

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

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

फाल्कन पासवर्ड को एन्क्रिप्टेड रूप में संग्रहीत करने का एक आसान तरीका प्रदान करता है जो एक एल्गोरिथ्म का अनुसरण करता है md5, base64 या sh1

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

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

<?php  
class UsersController extends Phalcon\Mvc\Controller {  
   public function indexAction() {  
   }  
   public function registerUser() { 
      $user = new Users();  
      $login    = $this->request->getPost("login"); 
      $password = $this->request->getPost("password");
      $user->login = $login;  
      
      // Store the hashed pasword 
      $user->password = $this->security->sh1($password);  
      $user->save(); 
   }  
   public function loginAction() {  
      if ($this->request->isPost()) {  
         $user = Users::findFirst(array( 
            'login = :login: and password = :password:', 
            'bind' => array( 
               'login' => $this->request->getPost("login"), 
               'password' => sha1($this->request->getPost("password")) 
            ) 
         ));  
         if ($user === false) { 
            $this->flash->error("Incorrect credentials"); 
            return $this->dispatcher->forward(array( 
               'controller' => 'users', 
               'action' => 'index' 
            )); 
         }
         $this->session->set('auth', $user->id);  
         $this->flash->success("You've been successfully logged in"); 
      }  
      return $this->dispatcher->forward(array( 
         'controller' => 'posts', 
         'action' => 'index' 
      )); 
   }  
   public function logoutAction() { 
      $this->session->remove('auth'); 
      return $this->dispatcher->forward(array( 
         'controller' => 'posts', 
         'action' => 'index' 
      )); 
   }  
}

डेटाबेस में संग्रहीत पासवर्ड एन्क्रिप्टेड प्रारूप में हैं sh1 कलन विधि।

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

क्रॉस-साइट अनुरोध क्षमा (CSRF)

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

प्रत्येक रूप में डेटा टोकन पीढ़ी की मदद से सुरक्षित किया जाता है। उत्पन्न टोकन यादृच्छिक है और यह उस टोकन से मेल खाता है, जिसे हम प्रपत्र डेटा भेज रहे हैं (ज्यादातर वेब एप्लिकेशन के बाहर POST विधि के माध्यम से)।

कोड:

<?php echo Tag::form('session/login') ?>  
   <!-- Login and password inputs ... -->  
   <input type = "hidden" name = "<?php echo $this->security->getTokenKey() ?>" 
      value = "<?php echo $this->security->getToken() ?>"/>  
</form>

Note - फॉर्म के टोकन भेजते समय सत्र एडाप्टर का उपयोग करना महत्वपूर्ण है, क्योंकि सत्र में सभी डेटा बनाए रखा जाएगा।

में सत्र एडाप्टर शामिल करें services.php निम्नलिखित कोड का उपयोग कर।

/** 
   * Start the session the first time some component request the session service 
*/ 

$di->setShared('session', function () { 
   $session = new SessionAdapter(); 
   $session->start();  
   return $session; 
});