Mokabyte

Dal 1996, architetture, metodologie, sviluppo software

  • Argomenti
    • Programmazione & Linguaggi
      • Java
      • DataBase & elaborazione dei dati
      • Frameworks & Tools
      • Processi di sviluppo
    • Architetture dei sistemi
      • Sicurezza informatica
      • DevOps
    • Project Management
      • Organizzazione aziendale
      • HR
      • Soft skills
    • Lean/Agile
      • Scrum
      • Teoria della complessità
      • Apprendimento & Serious Gaming
    • Internet & Digital
      • Cultura & Società
      • Conferenze & Reportage
      • Marketing & eCommerce
    • Hardware & Tecnologia
      • Intelligenza artificiale
      • UX design & Grafica
  • Ultimo numero
  • Archivio
    • Archivio dal 2006 ad oggi
    • Il primo sito web – 1996-2005
  • Chi siamo
  • Ventennale
  • Libri
  • Contatti
Menu
  • Argomenti
    • Programmazione & Linguaggi
      • Java
      • DataBase & elaborazione dei dati
      • Frameworks & Tools
      • Processi di sviluppo
    • Architetture dei sistemi
      • Sicurezza informatica
      • DevOps
    • Project Management
      • Organizzazione aziendale
      • HR
      • Soft skills
    • Lean/Agile
      • Scrum
      • Teoria della complessità
      • Apprendimento & Serious Gaming
    • Internet & Digital
      • Cultura & Società
      • Conferenze & Reportage
      • Marketing & eCommerce
    • Hardware & Tecnologia
      • Intelligenza artificiale
      • UX design & Grafica
  • Ultimo numero
  • Archivio
    • Archivio dal 2006 ad oggi
    • Il primo sito web – 1996-2005
  • Chi siamo
  • Ventennale
  • Libri
  • Contatti
Cerca
Chiudi

Nel numero:

97 giugno
, anno 2005

La JSP Standard Tag Library

IV parte: JSTL e XML

Alfredo Larotonda

Alfredo Larotonda

Alfredo Larotonda, laureato in Ingegneria Elettronica, lavora da diversi anni nel settore IT. Dal 1999 si occupa di Java ed in particolare dello sviluppo di applicazioni web J2EE. Dopo diverse esperienze di disegno e sviluppo di applicazioni web per il mercato finanziario e industriale, si occupa ora in particolare di aspetti architetturali per progetti rivolti al mercato della pubblica amministrazione. È Sun Certified Enterprise Architect (SCEA) e ha inoltre conseguito le certificazioni SCJP, SCWCD 1.3, SCWCD 1.4, SCBCD.

MokaByte

La JSP Standard Tag Library

IV parte: JSTL e XML

Alfredo Larotonda

Alfredo Larotonda

  • Questo articolo parla di: Architetture dei sistemi, Java, Programmazione & Linguaggi

L‘elaborazione di documenti XML è ormai uno dei compiti più ricorrenti nello sviluppo di applicazioni J2EE. La JSTL consente di elaborare documenti XML in modo semplice ed efficace. Esaminiamo le principali caratteristiche dei tag che servono allo scopo.

Introduzione

L‘elaborazione di documenti XML è ormai uno dei compiti più ricorrenti nello sviluppo di applicazioni J2EE. JSTL fornisce diverse possibilità  interessanti per il parsing e per la gestione dei documenti XML. Inoltre consente in maniera molto semplice di applicare trasformazioni XSL a documenti XML. Le funzionalità  fornite da JSTL sono un‘alternativa alle diverse tecniche usate per l‘elaborazione XML e sono sicuramente le più indicate per sviluppatori di pagine web che non hanno una conoscenza approfondita della tecnologia XML e delle varie tecnologie ad essa collegate.
Alla base dell‘utilizzo della libreria di tag JSTL che riguardano XML c‘è XPath. XPath è un linguaggio che consente di specificare parti di un documento XML. La sintassi con la quale è possibile fare riferimento a sezioni di un documento XML con XPath riprende quella in uso nei file-system; il documento XML è visto come un albero gerarchico in cui vi è un nodo radice e al di sotto di esso tutti i vari nodi con i loro figli. I vari nodi dell‘albero sono individuati navigando in modo analogo a quello che si fa con le cartelle di un file-system. Non è possibile fare una trattazione approfondita di XPath per il quale si rimanda alla documentazione specifica. Di seguito invece vengono elencati i tag della libreria xml.

Parsing di documenti XML con

Prima di poter elaborare un documento XML è necessario trasformarlo in una rappresentazione in qualche modo elaborabile. Questa operazione è detta parsing. Per effettuare il parsing di un documento XML è possibile usare il tag .

L‘utilizzo del tag è piuttosto immediato. Il tag accetta il file di cui fare il parsing o nella variabile xml o nel suo body. Il risultato del parsing è esposto nella variabile definita in var memorizzata nello scope specificato nell‘attributo scope. Un esempio di utilizzo del tag parse è il seguente:

Definizione di variabili

La libreria XML contiene alcuni tag che sono equivalenti ai tag corrispondenti della libreria core. così come nella libreria core esistono tag per assegnare valori a variabili o visualizzare il contenuto di variabili, così nella libreria xml esistono tag analoghi che però lavorano con variabili che rappresntano documenti XML o parti di questi.
Il tag consente di visualizzare un valore da un file XML espresso in formato XPath.

Se ad esempio nella pagina viene effettuato il parsing del seguente documento:

Testo

per visualizzare il testo contenuto tra i tag si potrà  usare il nel seguente modo:

così come è possibile scrivere in output il valore di una variabile che contiene una parte di un documento XML è possibile anche assegnare ad una variabile un valore ottenuto da una espressione XPath. Il tag che lo consente è :

L‘utilizzo è esattamente analogo a quello del .

Controllo di flusso

Nella libreria xml esistono anche i tag per il controllo di flusso, corrispondenti a quelli della libreria core. Esistono tag per eseguire test condizionali su variabili contenenti valori estratti da file XML e tag per eseguire loop su nodi di un documento XML. Il permette di eseguire test condizionali su espressioni XPath:

Il tag valuta un‘espressione XPath e memorizza il risultato nella variabile booleana specificata. In base al valore della variabile possono può essere scelta l‘elaborazione da compiere nella pagina. Analogamente ai tag della libreria core abbiamo poi i tag , per fare test condizionali nella forma di un costrutto switch/case.

così come è possibile iterare su array o collections mediante il tag , così è possibile utilizzare il tag della libreria xml per eseguire una iterazione in base ad una espressione XPath che restituisce più nodi di un documento XML.
Gli attributi del tag sono:

Se ad esempio abbiamo un documento XML come segue

Prodotto1 Prodotto2 Prodotto3

supponendo di aver effettuato il parsing del documento e di aver memorizzato il risultato nella variabile docXml con la seguente espressione verranno trovati tre elementi del documento e il body del tag sarà  valutato tre volte.

Prodotto trovato

Trasformazione di documenti XML con JSTL

XSLT è un linguaggio che consente di trasformare un documento XML in un altro documento XML o in documento di un altro formato come PDF, RTF,HTML. XSLT consente di definire una serie di regole che governano la trasformazione e che vengono applicate al documento.Il file che contiene queste regole è denominato stylesheet. XSLT è una linguaggio molto utilizzato nelle trasformazioni di file XML e richiede comunque una conoscenza specifica che spessova oltre quelle di uno sviluppatore di pagine web.
JSTl consente di effettuare una trasformazione in modo molto semplice senza che lo sviluppatore conosca tutti i dettagli della tecnologia XSLT purchè abbia a disposizione lo stylesheeet necessario alla trasformazione stessa,
JSTL mette a disposizione il tag i cui attributi sono:

Il tag accetta nella variabile xml il documento di cui fare il parsing e nella variabile xsl lo stylesheet XSLT da applicare nella trasformazione e visualizza in output il risultato della stessa.
Il documento XML e lo stylesheeet possono essere specificati con variabili risultato di una .
Il risultato della trasformazione può anche essere memorizzato nella variabile specificata da var ad esempio nel caso in cui si vogliano fare più trasformazioni a cascata su un documento.
JSTL consente quindi di eseguire trasformazioni XSLT senza la necessità  di avere la padronanza di API Java adatte allo scopo e quindi è si adatta particolarmente a sviluppatori di pagine web che vogliano usare XSLT senza necessariamente dover acquisirne una conoscenza approfondita.

Conclusioni

Nei precedenti paragrafi abbiamo fatto una carrellata sui principali tag della libreria XML evidenziando come questi permettano di eseguire numerose operazioni di elaborazione dei file XML. Come sempre si rimanda alla bibliografia per l‘approfondimento sugli argomenti.
Con questo articolo si conclude la serie su JSTL. L‘intento era di fornire le nozioni di base per iniziare ad utilizzare i tag della libreria e soprattutto di far comprendere i vantaggi dello sviluppo di pagine JSP scriptless.

Riferimenti

[1]
Bryan Basham – Kathy Sierra – Bert Bates, “Head First – Servlet & JSP”, O‘Reilly, 2004

[2]
AAVV, “The J2EE 1.4 Tutorial “, Sun Microsystems, 2003

[3]
Shawn Bayern, “JSTL in Action” , Manning Publications Co., 2004

Facebook
Twitter
LinkedIn
Alfredo Larotonda

Alfredo Larotonda

Alfredo Larotonda, laureato in Ingegneria Elettronica, lavora da diversi anni nel settore IT. Dal 1999 si occupa di Java ed in particolare dello sviluppo di applicazioni web J2EE. Dopo diverse esperienze di disegno e sviluppo di applicazioni web per il mercato finanziario e industriale, si occupa ora in particolare di aspetti architetturali per progetti rivolti al mercato della pubblica amministrazione. È Sun Certified Enterprise Architect (SCEA) e ha inoltre conseguito le certificazioni SCJP, SCWCD 1.3, SCWCD 1.4, SCBCD.

Alfredo Larotonda

Alfredo Larotonda

Alfredo Larotonda, laureato in Ingegneria Elettronica, lavora da diversi anni nel settore IT. Dal 1999 si occupa di Java ed in particolare dello sviluppo di applicazioni web J2EE. Dopo diverse esperienze di disegno e sviluppo di applicazioni web per il mercato finanziario e industriale, si occupa ora in particolare di aspetti architetturali per progetti rivolti al mercato della pubblica amministrazione. È Sun Certified Enterprise Architect (SCEA) e ha inoltre conseguito le certificazioni SCJP, SCWCD 1.3, SCWCD 1.4, SCBCD.
Tutti gli articoli
Nello stesso numero
Loading...

MokaCMS – Open Source per il Web Content Management

Vparte: da XML ad HTML utilizzando XSLT

Oracle Java Stored Procedures

Scrivere stored procedures direttamente in Java

Individuare i Memory Leaks nelle applicazioni Java

Ottimizzare la gestione della memoria

La prorgammazione concorrente

IV parte: l‘uso dei lock

Web Services

I parte: il punto sulla standardizzazione

Multimedialità su J2ME

II parte: la gestione dell‘audio

Gli ascoltatori d‘evento

I molti modi per intercettare un evento swing

Identity Management

Gestire l‘identità per massimizzare i processi di business

Nella stessa serie
Loading...
Mokabyte

MokaByte è una rivista online nata nel 1996, dedicata alla comunità degli sviluppatori java.
La rivista tratta di vari argomenti, tra cui architetture enterprise e integrazione, metodologie di sviluppo lean/agile e aspetti sociali e culturali del web.

Imola Informatica

MokaByte è un marchio registrato da:
Imola Informatica S.P.A.
Via Selice 66/a 40026 Imola (BO)
C.F. e Iscriz. Registro imprese BO 03351570373
P.I. 00614381200
Cap. Soc. euro 100.000,00 i.v.

Privacy | Cookie Policy

Contatti

Contattaci tramite la nostra pagina contatti, oppure scrivendo a redazione@mokabyte.it

Seguici sui social

Facebook Linkedin Rss
Imola Informatica
Mokabyte