abclinuxu.cz AbcLinuxu.cz itbiz.cz ITBiz.cz HDmag.cz HDmag.cz abcprace.cz AbcPráce.cz
AbcLinuxu hledá autory!
Inzerujte na AbcPráce.cz od 950 Kč
Rozšířené hledání
×
    dnes 18:11 | IT novinky

    Dnes a zítra probíhá vývojářská konference Google I/O 2025. Sledovat lze na YouTube a na síti 𝕏 (#GoogleIO).

    Ladislav Hagara | Komentářů: 0
    dnes 15:22 | Komunita

    V Bostonu probíhá konference Red Hat Summit 2025. Vybrané přednášky lze sledovat na YouTube. Dění lze sledovat na síti 𝕏 (#RHSummit).

    Ladislav Hagara | Komentářů: 0
    dnes 15:00 | Nová verze

    Společnost Red Hat oficiálně oznámila vydání Red Hat Enterprise Linuxu 10. Vedle nových vlastností přináší také aktualizaci ovladačů a předběžné ukázky budoucích technologií. Podrobnosti v poznámkách k vydání.

    Ladislav Hagara | Komentářů: 0
    dnes 12:22 | Pozvánky

    Tuto sobotu 24. května se koná historicky první komunitní den projektu Home Assistant. Zváni jsou všichni příznivci, nadšenci a uživatelé tohoto projektu. Pro účast je potřebná registrace. Odkazy na akce v Praze a v Bratislavě.

    jose17 | Komentářů: 0
    dnes 04:44 | IT novinky

    Troy Hunt představil Have I Been Pwned 2.0, tj. nový vylepšený web služby, kde si uživatelé mohou zkontrolovat, zda se jejich hesla a osobní údaje neobjevili v únicích dat a případně se nechat na další úniky upozorňovat.

    Ladislav Hagara | Komentářů: 13
    včera 23:22 | Zajímavý software

    Microsoft představil open source textový editor Edit bežící v terminálu. Zdrojové kódy jsou k dispozici na GitHubu pod licencí MIT.

    Ladislav Hagara | Komentářů: 7
    včera 22:22 | Zajímavý software

    V Seattlu a také online probíhá konference Microsoft Build 2025. Microsoft představuje své novinky. Windows Subsystem for Linux je nově open source. Zdrojové kódy jsou k dispozici na GitHubu pod licencí MIT.

    Ladislav Hagara | Komentářů: 0
    včera 13:11 | Zajímavý článek

    Z příspěvku Turris Sentinel – co přinesl rok 2024 na blogu CZ.NIC: "Za poslední rok (únor 2024 – únor 2025) jsme zachytili 8,3 miliardy incidentů a to z 232 zemí a z jejich závislých území. Tyto útoky přišly od 6,2 milionu útočníků (respektive unikátních adres). SMTP minipot je stále nejlákavější pastí, zhruba 79 % útoků bylo směřováno na tento minipot, 16 % útoků směřovalo na minipot Telnet, 3 % útoků směřovaly na minipot HTTP a 2 % na minipot FTP. Dále jsme zaznamenali 3,2 milionu unikátních hesel a 318 tisíc unikátních loginů, které útočníci zkoušeli."

    Ladislav Hagara | Komentářů: 1
    včera 12:44 | Nová verze

    Byla vydána (Mastodon, 𝕏) nová verze 3.0.4 svobodné aplikace pro úpravu a vytváření rastrové grafiky GIMP (GNU Image Manipulation Program). Přehled novinek v oznámení o vydání a v souboru NEWS na GitLabu. Nový GIMP je již k dispozici také na Flathubu.

    Ladislav Hagara | Komentářů: 0
    včera 12:33 | Nová verze

    Byla vydána nová stabilní verze 7.4 webového prohlížeče Vivaldi (Wikipedie). Postavena je na Chromiu 136. Přehled novinek i s náhledy v příspěvku na blogu.

    Ladislav Hagara | Komentářů: 0
    Jaký je váš oblíbený skriptovací jazyk?
     (60%)
     (24%)
     (10%)
     (0%)
     (0%)
     (0%)
     (7%)
    Celkem 42 hlasů
     Komentářů: 4, poslední včera 22:41
    Rozcestník

    Zend framework V

    18.4.2008 22:51 | Přečteno: 3121×

    Zend framework - formuláře

    Podstatná část dat, která uživatel předává serveru je předávána přes formulář, který uživatel vyplní a odešle na server. Tam je ověřeno, zda jsou data validní a případně zpracovány. Zend obsahuje třídu Zend_Form, která krom toho, že umožňuje vytvořit formulář a získat z něj data navíc umožňuje další věci, jako navěšení validátorů pro validaci obsahu, přidání filtrů a nebo obalení jednotlivých elementů formuláře HTML tagy. Toto vše ani nemusíme provádět v php kódu, celý formulář totiž můžeme definovat v konfiguračním souboru. Osobně ale nejvíce oceňuji právě možnost přidání validátorů, případně filtrů, na jednotlivé elementy, přičemž většina běžně používaných validátorů i filtrů je již v Zendu implementovaná.

    Po vytvoření formuláře obvykle jako první nastavíme akci, která se provede při odeslání formuláře a metodu, jakou se budou předávat data:

      $form = new Zend_Form();
      $form->setAction('/zendTest/login/auth')
           ->setMethod('post');
    
    Pomocí metody setAttrib('attribName','attribValue') můžeme formuláři nastavit jakýkoli další atribut. Elementy formuláře vytvoříme zavoláním metody createElement('elementType', 'elementName'). Na elementy formuláře pak můžeme navěsit validátory (a filtry):
      $login = $form->createElement('text', 'username');
      $login->addValidator('alnum')
            ->addValidator('stringLength', false, array(5))
    	->setRequired(true)
    		
      $passwd = $form->createElement('password', 'passwd');
      $passwd->addValidator('StringLength', false, array(5))
    	 ->setRequired(true)
    
    V tomto příkladě jsme vytvořili dva elementy formuláře, pole pro zadání uživatelského jména a pole pro zadání hesla. Obě políčka musí být vyplněná (setRequired(true)) a obsahovat minimálně pět znaků (addValidator('StringLength', false, array(5))). První parametr metody addValidator je jméno validátoru, druhý říká, zda má pokracovat vyhodnocování dalších validátorů, pokud podmínka aktuálního validátoru není splněná a poslední předává další parametry potřebné pro vyhodnocení. První validátor (alphanum) vyžaduje, jak již název napovídá, aby login uživatele obsahoval jen alfanumerické znaky. Filtry by se přidávaly obdobně:
      $login->addFilter('StringtoLower');
    
    Seznam všech již naprogramovaných filtrů a validátorů naleznete v manuálu a pokud vám nebudou vyhovovat, můžete si napsat vlastní.

    Na závěr oba prvky přidáme do formuláře (zatím jsme je jen vytvořili, ale nikoli přidali do formuláře) a přidáme ještě poslední element - tlačítko pro odeslání:

      $form->addElement($login)
           ->addElement($passwd)
           ->addElement('submit', 'login', array('label' => 'Login'));
    
    Formulář pak předáme do view:
      $this->view->form = $form;
      $this->render('showform');
    
    a ve view (showform.phtml) zobrazíme:
    <?= $this->form ?>
    

    Zda jsou data odeslaná přes formulář validní zjistíme zavoláním metody isValid():

    $form->isValid($_POST)
    
    Pokud ano, data z formuláře můžeme získat několika způsoby, např:
      $values = $form->getValues();
    
    (a nebo třeba přímo z requestu: this->_request->getPost('username'))

    Na závěr se ještě letmo zmíním o dekoratérech - prvcích, které elementy formuláře obalují HTML tagy. Opět platí, že si můžeme definovat vlastní. Pokud neučíme jinak, jsou k formuláři připojeny tyto čtyři dekoratéry:

    Dekoratéry můžeme odstranit zavoláním metody removeDecorator('name') na daném elementu:
      $login->removeDecorator('Errors');
    

    Celý kontroler pro přihlášení uživatele (zatím bez autentizace uživatele, jen odelání formuláře) by mohl vypadat takto (příklad je až na drobné úpravy celý převzatý z manuálu Zendu):

    <?php
    class LoginController extends Zend_Controller_Action
    {
    	public function getLoginForm(){
    		$form = new Zend_Form();
    		$form->setAction('/zendTest/login/auth')
    		->setMethod('post');
    		
    		$login = $form->createElement('text', 'username');
    		$login->addValidator('alnum')
    		->addValidator('stringLength', false, array(5))
    		->setRequired(true)
    		->removeDecorator('Errors');
    
    		$passwd = $form->createElement('password', 'passwd');
    		$passwd->addValidator('StringLength', false, array(5))
    		->setRequired(true)
    		->removeDecorator('Errors');
    		
    		$form->addElement($login)
    		->addElement($passwd)
    		->addElement('submit', 'login', array('label' => 'Login'));
    		return $form;
    	}
    
    	public function indexAction(){
    		$this->view->form = $this->getLoginForm();
    		$this->render('showform');
    	}
    
    	public function authAction(){
    		if (!$this->getRequest()->isPost()) {
    			return $this->_forward('index');
    		}
    		$form = $this->getLoginForm();
    		if (!$form->isValid($_POST)) {
    			$this->view->form = $form;
    			return $this->render('showform');
    		}
    		// authentization 
    		// ...
    	}
    }
    

           

    Hodnocení: 75 %

            špatnédobré        

    Tiskni Sdílej: Linkuj Jaggni to Vybrali.sme.sk Google Del.icio.us Facebook

    Komentáře

    Vložit další komentář

    Daniel Kvasnička ml. avatar 18.4.2008 23:42 Daniel Kvasnička ml. | skóre: 52 | blog: The Joys and Sorrows of Being an IT Freak | Ostrava
    Rozbalit Rozbalit vše Re: Zend framework V
    No vida, pred chvili jsem se prave rozhodl v jedne aplikaci pouzit Zend_Form misto formularoveho/validacniho reseni dodavaneho s Kohanou. Kazdopadne ale jen na tu validacni cast, markup si pisu rucne.
    FSF: “screw you for not wanting the stuff we produce”, People: “screw you for not producing the stuff we want."
    19.4.2008 09:50 changeit | Bratislava
    Rozbalit Rozbalit vše Re: Zend framework V
    ja som si napisal skript ktory parsuje html formular, a podla neho vytvori Zend_Form, takze v podstate pisem len markup a metodu na spracovanie hodnot z formu.
    Daniel Kvasnička ml. avatar 19.4.2008 17:54 Daniel Kvasnička ml. | skóre: 52 | blog: The Joys and Sorrows of Being an IT Freak | Ostrava
    Rozbalit Rozbalit vše Re: Zend framework V
    A jak do toho markupu zaclenis veskere informace o validatorech a omezenich na jednotlivych polich tak, aby ten vygenerovany Zend_Form byl plnohodnotny? A jak resis znovunaplneni formu (texty, selecty, checkboxy) a vypisy validacnich chyb, kdyz mas ten formular jen v HTML? ...ja pouzivam pro templaty PHPTAL, takze me napada, ze by podobna vec sla docela zajimave resit pres XSLT. Ale uz jsem si integraci vyresil jinak.
    FSF: “screw you for not wanting the stuff we produce”, People: “screw you for not producing the stuff we want."
    20.4.2008 17:02 changeit | Bratislava
    Rozbalit Rozbalit vše Re: Zend framework V
    formular je v html ale ten nevykreslujem, vykreslujem len zend_form ktory som podla neho vytvoril. zatial som nejak validatory neriesil ale napr. aby to bola povinna hodnota staci elemntu pridat atribut required="true" a je to. Robene je to ako smarty block plugin.
    19.4.2008 20:00 Ladicek | skóre: 28 | blog: variace | Havlíčkův brod
    Rozbalit Rozbalit vše Re: Zend framework V
    Ajťáci obvykle decorator do češtiny převádějí jako dekorátor, ovšem jednoduchý "test Googlem" dává dekoratérovi řádově větší váhu. Byl by někdo schopný argumentovat pro a proti dekorátoru a dekoratérovi ve smyslu návrhového vzoru Decorator?
    Ještě na tom nejsem tak špatně, abych četl Viewegha.
    19.4.2008 20:37 dementni.lojzik | skóre: 19 | blog: ze zivota na vsi
    Rozbalit Rozbalit vše Re: Zend framework V
    Heh, taky jsem psal dekorator, pak jsem to ale projel kontrolou pravopisu a ta mi dekorator opravovala na dekorater. Moc jsem to neresil a nechal dekorater. Ted jsem se na to zkousel podivat a vypada to, ze v cestine existuje pouze slovo dekorater, dekorator patrne bude anglicismus zatazeny sem ajtaky:-) Aspon podle www.pravidla.cz slovo dekoratér neexistuje. Stejne tak slovnik.cz dekorator neprelozi, ale dekorater prelozi mimo jine i jako decorator.
    23.12.2008 11:23 noname sry
    Rozbalit Rozbalit vše Re: Zend framework V

    muzu se optat jakej je  rozdil, ve volani metody? diky

    $this -> getLoginForm();

    a

    self::getLoginForm();

     

    Založit nové vláknoNahoru

    ISSN 1214-1267   www.czech-server.cz
    © 1999-2015 Nitemedia s. r. o. Všechna práva vyhrazena.