Un framework per applicazioni web (web application framework), in informatica e specialmente nella programmazione web, è un framework software progettato per supportare lo sviluppo di siti web dinamici, applicazioni web e servizi web.
Lo scopo è quello di alleggerire il lavoro associato allo sviluppo delle attività più comuni di un'applicazione web da parte dello sviluppatore. Uno dei principi fondamentali è riassunto dall'acronimo DRY (don't repeat yourself), nel senso che viene fortemente consigliata l'adozione di tecniche di riuso di codice. Molti framework forniscono ad esempio delle librerie per l'accesso alle basi di dati, per la creazione di template HTML o per gestire la sessione dell'utente[1].
Esempi di framework per applicazioni web sono Apache Struts, Spring, Swing, Java Server Faces (Oracle ADF), Django, Flask, Symfony, Phalcon, CodeIgniter, Angular, ReactJS, Laravel. In grandi organizzazioni come banche o grandi aziende si utilizzano spesso framework proprietari, varianti dei framework in tecnologie note, per aumentare il livello di sicurezza[1].
Caratteristiche
[modifica | modifica wikitesto]I framework in genere impostano il flusso di controllo di un programma e consentono all'utente del framework di "agganciarsi" a quel flusso esponendo vari eventi[2]. Questo modello di progettazione "inversione del controllo" è considerato un principio che definisce un framework e avvantaggia il codice imponendo un flusso comune per un team che tutti possono personalizzare in modi simili[2]. Ad esempio, alcuni popolari "microframework" come Sinatra di Ruby (che ha ispirato Express.js) consentono agganciamenti middleware prima e dopo le richieste HTTP. Queste funzioni middleware possono essere qualsiasi cosa e consentono all'utente di definire la registrazione, l'autenticazione, la gestione delle sessioni e il reindirizzamento[3].
Tipi di architetture framework
[modifica | modifica wikitesto]Model-view-controller
[modifica | modifica wikitesto]Molti framework seguono il modello architetturale MVC (Model-view-controller) per separare il modello di dati con regole di business dall'interfaccia utente[4].
Push-based vs. pull-based
[modifica | modifica wikitesto]La maggior parte dei framework MVC segue un'architettura basata su push chiamata anche "basata sull'azione". Questi framework utilizzano azioni che eseguono l'elaborazione richiesta e quindi "trasmettono" i dati al livello di visualizzazione per eseguire il rendering dei risultati[5]. Django, Ruby on Rails, Symfony, Spring MVC, Laravel, Stripes, Sails.js, CodeIgniter[6] sono esempi di questa architettura.
Organizzazione a tre livelli
[modifica | modifica wikitesto]Nell'organizzazione a tre livelli, le applicazioni sono strutturate su tre livelli fisici: client, applicazione e database[7][8][9][10]. Il database è normalmente un RDBMS. L'applicazione contiene la logica di business, gira su un server e comunica con il client tramite HTTP[11]. Il client sulle applicazioni Web è un browser Web che esegue l'HTML generato dal livello dell'applicazione[12][13]. Il termine non deve essere confuso con MVC, dove, a differenza dell'architettura a tre livelli, è considerata una buona pratica mantenere la logica di business lontana dal controller, il "livello intermedio"[14][15].
Applicazioni
[modifica | modifica wikitesto]I framework sono costruiti per supportare la costruzione di applicazioni Internet basate su un singolo linguaggio di programmazione, che vanno da strumenti di uso generale come Zend Framework e Ruby on Rails, che aumentano le capacità di un linguaggio specifico, a pacchetti programmabili in linguaggio nativo costruiti intorno un'applicazione utente specifica, come i sistemi di gestione dei contenuti, alcuni strumenti di sviluppo mobile e alcuni strumenti del portale[16].
Note
[modifica | modifica wikitesto]- ^ a b Laura Bartoli, Cos'è un web framework, su nephila.digital, 3 ottobre 2014. URL consultato il 25 agosto 2021.
- ^ a b Martin Fowler, bliki: InversionOfControl, su martinfowler.com. URL consultato il 6 marzo 2016.
- ^ Qiang Xue, Capital One Engineering – Philosophies that Shaped Successful Frameworks, su capitalone.io. URL consultato il 6 marzo 2016 (archiviato dall'url originale il 13 marzo 2016).
- ^ pdf (PDF), su dia.uniroma3.it.
- ^ Kris Thomson, Clarification on MVC= Pull and MVC Push, su theserverside.com, 29 ottobre 2003. URL consultato il 29 luglio 2007.
- ^ What are the fundamental differences between Struts and JSF, su cwiki.apache.org, Struts.apache.org, 14 febbraio 2011. URL consultato il 14 giugno 2013.
- ^ Microsoft, Three-tiered distribution, su msdn.microsoft.com. URL consultato il 19 settembre 2011.
- ^ Oracle, clustering_concepts_10en (PDF), su download.oracle.com. URL consultato il 19 settembre 2011.
- ^ Robert R. Perkoski, Introduction to Web Development (PPT), su sis.pitt.edu (archiviato dall'url originale il 7 novembre 2013).
- ^ IBM, Using Client Access Express in a three tier environment, su publib.boulder.ibm.com. URL consultato il 19 settembre 2011.
- ^ Oracle, Understanding the Three-Tier Architecture, su download.oracle.com. URL consultato il 19 settembre 2011.
- ^ Microsoft, Pragmatic Architecture: Layering, su msdn.microsoft.com. URL consultato il 19 settembre 2011.
- ^ Arokia, 3-Tier Web Architecture, su arokiait.com. URL consultato il 19 settembre 2011 (archiviato dall'url originale il 18 luglio 2012).
- ^ ASP.NET MVC Controller Best Practices, su arrangeactassert.com. URL consultato il 19 settembre 2011 (archiviato dall'url originale l'11 ottobre 2011).
- ^ Jamis Buck, Skinny Controller, Fat Model, su weblog.jamisbuck.org (archiviato dall'url originale il 16 maggio 2015).
- ^ (EN) Getting Started With Web Frameworks, Wired Magazine. URL consultato il 2 aprile 2018.
Voci correlate
[modifica | modifica wikitesto]Altri progetti
[modifica | modifica wikitesto]- Wikimedia Commons contiene immagini o altri file sul framework per applicazioni web