Nette Framework: differenze tra le versioni

Contenuto cancellato Contenuto aggiunto
Recupero di 1 fonte/i e segnalazione di 0 link interrotto/i.) #IABot (v2.0
Nessun oggetto della modifica
 
(12 versioni intermedie di 8 utenti non mostrate)
Riga 1:
{{Software
|Sviluppatore = [[David Grudl]], [[Nette Foundation]]
|SistemaOperativo = multipiattaforma
|Genere = ideweb framework
|Licenza = [[Licenza MIT]]
|SoftwareLibero = sì
Riga 8:
'''Nette Framework''' è un [[framework]] open source per la creazione di applicazioni web in [[PHP]]&nbsp;5 e PHP 7. Nette Framework si focalizza sull'eliminazione dei rischi sulla sicurezza, supporta [[AJAX]], [[Don't repeat yourself|DRY]], [[KISS (principio)|KISS]], [[Model-view-controller|MVC]] e riutilizzo del codice. Utilizza la programmazione basata sugli eventi ed utilizza in gran parte l'utilizzo dei componenti. L'autore originale di Nette Framework è David Grudl e del suo sviluppo odierno se ne occupa la Nette Foundation.<ref>{{Cita web |url=https://nettefoundation.com/ |titolo=Nette Foundation |accesso=3 maggio 2019 |urlarchivio=https://web.archive.org/web/20161107062256/https://nettefoundation.com/ |dataarchivio=7 novembre 2016 |urlmorto=sì }}</ref> Nette Framework è un software libero, distribuito sotto licenza [[GNU General Public License|GNU GPL]] e licenza Nette,<ref>[https://nette.org/cs/licence Licenza] sul sito ufficiale</ref> che deriva dalla [[Licenze BSD|licenza BSD]] originale (vecchia a 4 clausole).
 
L'autore di Nette Framework organizza corsi di formazione che in parte possono sostituire pezzi di documentazione. Ogni mese si svolge un incontro non formale dei sostenitori di Nette Framework, chiamato l{{'}}''ultimo sabato'' organizzato a Praga, Brno ed altre città. L'ingresso è gratis.
 
== Requisiti ==
Riga 22:
=== NetteLoader ===
In ambiente di produzione è possibile caricare un unico file.
<sourcesyntaxhighlight lang="php">
<?php
require_once 'Nette/loader.php';
</syntaxhighlight>
</source>
 
=== RobotLoader ===
Riga 31:
* Invalidazione intelligente della cache
* Nel file netterobots.txt è possibile configurare i percorsi da ignorare
<sourcesyntaxhighlight lang="php">
$loader = new RobotLoader();
$loader->addDirectory('libs');
$loader->register();
</syntaxhighlight>
</source>
 
== Eliminazione e ricerca degli errori ==
Riga 42:
=== Tuning ===
Strumenti di debug per catturare gli errori che derivano dalla compilazione del programma. Semplifica i classici messaggi di errore permettendo quindi un debug efficace dell'applicazione. Per utilizzarli basta semplicemente attivare il debug.
<sourcesyntaxhighlight lang="php">
<?php
require 'libs/Nette/loader.php';
Debug::enable();
</syntaxhighlight>
</source>
=== Collegamento a FireBug ===
La comunicazione tra FireBug e Nette\Debug permette di inviare i messaggi attraverso un canale separato al di fuori del browser. Le informazioni non si perdono quindi nel caso in cui il testo si deforma nella pagina, ma si visualizzano chiaramente in una nuova finestra. Gli errori a livello di E_NOTICE e E_WARNING sono inviati a FireBug in maniera automatica. È necessario aver installata almeno la seconda versione di FireFox. Scaricasi Firebug e FirePHP almeno la versione 0.2. Nette \ debug comunica con Firebug tramite intestazioni HTTP. È quindi necessario chiamare la funzione di registrazione prima che lo script PHP inizi a scrivere qualche cosa. Naturalmente è possibile attivare il buffer di uscita e il ritardo di uscita.
Riga 53:
Nette Debug console è una finestra pop-up in cui è possibile visualizzare una variabile.
 
<sourcesyntaxhighlight lang="php">
<?php
$pole = array(1,2,3,5);
Debug::consoleDump($pole);
</syntaxhighlight>
</source>
 
=== Log degli errori ===
In un ambiente di produzione, dove non è appropriato ne auspicabile utilizzare alcuni dei metodi precedenti per visualizzare gli errori, Nette Framework ci fornisce uno strumento per catturare gli errori e registrarli in un log testuale dove si può vedere esattamente ciò che è accaduto e correggerli. Tale funzionalità deve essere abilitata ed impostare il percorso in cui è possibile scrivere.
<sourcesyntaxhighlight lang="php">
Debug::enable(Debug::DETECT, '%logDir%/php_error.log', 'admin@example.com');
</syntaxhighlight>
</source>
Il parametro Debug::DETECT significa che Nette deve da solo capire se è un server di produzione o di sviluppo. L'altro parametro è il percorso del log mentre l'ultimo parametro è l'indirizzo email a chi inviare un alert in caso di errori. La email viene inviata una solosola volta.
 
=== Modalità di sviluppo o di produzione ===
Riga 70:
 
Nette Framework riesce da solo a capire in quale ambiente si trova. Lo capisce tramite l'indirizzo IP del fornito dal server. Se i server sono dietro a proxy il riconoscimento non potrebbe avvenire correttamente, in questo caso è necessario impostare la modalità a mano.
<sourcesyntaxhighlight lang="php">
Debug::enable(Debug::DEVELOPMENT);
Debug::enable(Debug::PRODUCTION);
</syntaxhighlight>
</source>
 
== Forms ==
Nette dà al programmatore uno strumento molto potente per la creazione di form. Il Framework si occupa di organizzare e controllare tutti gli elementi del modulo. Controlla anche gli accessi/invii contro un probabile attacco.
 
=== Vantaggi di Nette Framework ===
Riga 85:
* Controllo contro gli attacchi: XSS, cross-site request forgery, UTF-8 attack
* Ottima protezione contro SQL injection, nel caso di utilizzo di notORM (database Nette)
<sourcesyntaxhighlight lang="php">
$form = new Form();
$form->addText('name','Inserire il nome')
Riga 93:
$form->addSubmit('login','Login');
echo $form;
</syntaxhighlight>
</source>
 
== Routing, Cool URL ==
A differenza di molti altri frameworks, è possibile impostare il formato dell'URL, come ultima cosa nell'intera applicazione. Permette il routing bidirezionale, che viene utilizzato sia per l'analisi e la generazione dei percorsi. Il Cool URL è importante anche per il SEO, i motori di ricerca valutano l'indirizzo che diventa parte importante del sito e quindi influisce sulla posizione del motore di ricerca. Allo stesso tempo, gli indirizzi sono più facili da leggere e deventadiventa più facile da ricordare. Nette nasconde le direttive mod_rewrite e non è necessario utilizzarle per definire le route. Ciò evita errori.
 
Esempi di URL classico:
Riga 112:
* [https://nette.org Pagina ufficiale]
* [https://api.nette.org/ Documentazione API]
* [https://addons.nette.org/ Componenti] {{Webarchive|url=https://web.archive.org/web/20160321141622/https://addons.nette.org/ |date=21 marzo 2016 }}
'''Articolo su Nette Framework'''
 
* https://kritek.it/blog/nette-framework
; Supporto in italiano su Nette Framework
;* https://web.archive.org/web/20190120152652/http://www.kritekprogrammatore-consultingphp.eu/
;* https://wwwphpprogramator.kritek.eucz/
;* https://wwwphpdeveloperexpert.kritek.itcom/
;* https://kritek.eu {{Webarchive|url=https://web.archive.org/web/20210302165054/https://kritek.eu/ |date=2 marzo 2021 }}
;* https://www.kritek.cz
;* https://kritek.it {{Webarchive|url=https://web.archive.org/web/20210416112301/https://kritek.it/ |date=16 aprile 2021 }}
;* https://kritek.cz {{Webarchive|url=https://web.archive.org/web/20210506060404/https://kritek.cz/ |date=6 maggio 2021 }}
 
{{PHP}}
{{Framework per applicazioni web}}