JSP Tag Library

Post on 18-Jun-2015

2.196 views 3 download

description

Librerie di tag per JSP

Transcript of JSP Tag Library

Jacopo Giudicijacopo@ubitek.org

Scopo della presentazioneIntrodurre il concetto di tag personalizzato;Creare una prima serie di tag in Tomcat;Utilizzare Eclipse per fare il debug

dell’applicazione;Creare tag personalizzati connessi con un

database tramite JNDI.

Tag personalizzatoUn tag personalizzato è un sistema formato da1. Una classe java che estenda una tra le seguenti classi:

javax.servlet.jsp.tagext.TagSupport;javax.servlet.jsp.tagext.BodyTagSupport;

o che implementi l’interfaccia javax.servlet.jsp.tagext.Tag;

2. Un file XML descrittore dell’utilizzo di questa classe Java;3. Una pagina Jsp che contenga un riferimento alla classe.

VantaggiPermettono di semplificare la scrittura del

codice JSPVengono inserite nelle pagine JSP con una

sintassi simile all’HTMLForniscono un metodo per costruire del

codice riutilizzabile (anche tra più progetti)Ne esistono svariate librerie free in rete

SvantaggiE’ NECESSARIO stabilire a priori di quali tag

necessita un progetto (pena la troppa astrazione dello stesso)

Sono difficili da scrivere perchè:Un programmatore sarà sempre portato a

scrivere “un po’ di codice per migliorare la classe”

Un NON programmatore non vorrà mai utilizzare “qualcosa che non sa da dove arrivi”

La classe del Tag personalizzatoE’ un frammento di codice Java inseribile in una pagina Jsp tramite del codice pseudo-HTML;

Deve contenere alcuni metodi particolari che ne controllino il flusso di esecuzione,

Ci sono due tipi di classi di tag: i gestori di tag con corpo e i gestori di tag senza corpo

Sono conformi allo standars JavaBean POJO (Plain Old Java Object):

Dati privati Metodi set e get pubblici per l’accesso ai dati

Tag senza corpo (I) Sono tag HTML paragonabili ai tag HTML:

<img />, <br />, <hr />che non contengono testo apertura e chiusura. Possono gestire attributi dichiarativi, ad es:

<colore:sfondo colore=“RED” />

Nome del tag

Attributo dichiarativo

Tag senza corpo (II)Estendono la classe TagSupport, che contiene i seguenti metodi principali (dalle specifiche J2EE):int doAfterBody()           Default processing for a body  int doEndTag()           Default processing of the end tag returning EVAL_PAGE.  int doStartTag()           Default processing of the start tag, returning SKIP_BODY. java.lang.Object getValue(java.lang.String k)           Get a the value associated with a key.  java.util.Enumeration getValues()           Enumerate the values kept by this tag handler.  void setValue(java.lang.String k, java.lang.Object o)           Associate a value with a String key.

Metodi da implementarePer personalizzare la nostra classe è possibile implementare uno dei metodi visti, sapendo che:int doAfterBody()

È il metodo eseguito dopo la lettura del corpo del tag (tutto deriva comunque dall’interfaccia

Tag !!!). int doEndTag()

È il metodo eseguito al termine degli altri metodi e, generalmente, ritorna il valore int EVAL_PAGE. int doStartTag()

È il metodo eseguito prima degli altri metodi e ritorna il valore int SKIP_BODY.

In caso di tag senza corpo questo è, generalmente, il metodo principale da implementare.

Esempio di classe per tag senza corpoEsempio di classe TagSupport:package taglib;

import javax.servlet.jsp.JspException;import javax.servlet.jsp.JspTagException;import javax.servlet.jsp.tagext.TagSupport;

public class DateTag extends TagSupport {public int doStartTag() throws JspException {

try {pageContext.getOut().print(new java.util.Date());

} catch (Exception ex) {throw new JspTagException("DateTag: " +

ex.getMessage());}return SKIP_BODY;

}public int doEndTag() {

return EVAL_PAGE;}

}

Attributi dichiarativiGli attributi vengono gestiti tramite i metodi setValue e getValue della classe Tag di implementazione tramite i metodi visti in precedenza:

java.lang.Object getValue(java.lang.String k)           Get a the value associated with a key.   void setValue(java.lang.String k, java.lang.Object o)           Associate a value with a String key.java.util.Enumeration getValues()           Enumerate the values kept by this tag handler.

Attributi dichiarativiPer ogni attributo, così come per le specifiche di JavaBean, devono esistere un metodo set per recuperare il valore del tag dalla pagina JSP e un metodo get se necessario.I metodi get e set devono seguire il seguente formato di esempio:T attr;T getAttr();void setAttr (T attr);

Esempio di recupero attributipackage taglib;

import java.text.SimpleDateFormat;

import javax.servlet.jsp.JspException;import javax.servlet.jsp.JspTagException;import javax.servlet.jsp.tagext.TagSupport;

public class DataFormattataTag extends TagSupport {private String formato;public String getFormato() {

return formato;}

Esempio di recupero attributipublic void setFormato(String formato) {

this.formato = formato;}public int doStartTag() throws JspException {

try {SimpleDateFormat formatter = new

SimpleDateFormat(formato);pageContext.getOut().print(formatter.format(new

java.util.Date()));} catch (Exception ex) {

throw new JspTagException("DateTag: " + ex.getMessage());}return SKIP_BODY;

}public int doEndTag() {

return EVAL_PAGE;}}

Taglib descriptorE’ un file xml contenente la descrizione di

utilizzo della classe tag avente estensione .tld;

Segue le regole del DTD:http://

java.sun.com/dtd/web-jsptaglibrary_1_2.dtd Si trova nella cartella WEB-INF

dell’applicazione Web;Definisce il comportamento di più tag, per

questo di chiama descrittore di libreria.

Principali tag XML nel file taglib: root<taglib>: è la root del documento<tlib-version>: la versione delle specifiche

taglib utilizzata<jsp-version>: la versione delle specifiche

jsp utilizzata<short-name>: un nome descrittivo della

libreria<tag>: inizia la descrizione del

comportamento di una classe di tag personalizzata

Principali tag XML nel file taglib: <tag><name>: il nome del tag da utilizzare nella jsp

<tag-class>: la classe che implementa questo tag

<attribute>: descrizione di un attributo del tag che potrebbe essere presente nella dichiarazione nella pagina jsp

Principali tag XML nel file taglib: <attribute><name>: il nome dell’attributo. Deve

essere uguale nella dichiarazione in JSP e nella classe implementativa.

<required>: specifica se l’attributo è obbligatorio o meno

<rtexprvalue>: specifica se l’attributo può derivare da un’espressione. In caso questo dato fosse true, l’espressione verrebbe calcolata prima di passarne il valore al metodo set della classe.

Descrittore di tag: esempio<?xml version="1.0" encoding="ISO-8859-1" ?><!DOCTYPE taglib PUBLIC "-//Sun Microsystems, Inc.//DTD JSP Tag Library 1.2//EN" "http://java.sun.com/dtd/web-jsptaglibrary_1_2.dtd"><taglib> <tlib-version>1.0</tlib-version> <jsp-version>1.2</jsp-version> <short-name>TagLib001</short-name> <tag> <name>data</name> <tag-class>taglib.DateTag</tag-class> </tag> <tag> <name>dataFormattata</name> <tag-class>taglib.DataFormattataTag</tag-class> <attribute> <name>formato</name> <required>true</required> <rtexprvalue>true</rtexprvalue> </attribute> </tag> </taglib>

Utilizzo dei tag nelle JSP

Esempio di JSP con tag personalizzati (I)

<%@ taglib uri="/WEB-INF/taglib001.tld" prefix="t1" %>

<html>

<head><title>Prima Taglib</title></head>

<body>

<t1:data />

</body>

</html>

Esempio di JSP con tag personalizzati (II)<%@ taglib uri="/WEB-INF/taglib001.tld" prefix="t1" %><html><head><title>Prima Taglib</title></head><body><% if(request.getParameter("formato")==null) { %><form action="<%= request.getRequestURI() %>" method="POST">

Formato: <input type="text" name="formato" /><br /><input type="submit" value="Vedi" /></form><% } else { %><t1:dataFormattata formato="dd/MM/yyyy“ />

<% } %></body></html>

Tag con corpo

Rispetto ai tag senza corpo, hanno la possibilità di gestire il testo tra l’apertura e la chiusura del tag

Estendono la classe BodyTagSupport, che a sua volta estende TagSupport

Possono anch’essi gestire attributi dichiarativi nella stessa identica maniera dei tag senza corpo

Poichè le specifiche XHTML limitano il numero di caratteri inseribili in un attributo, è necessario ricorrere a questi tipi di tag per gestire alcuni processi

Altri metodi da implementareLa classe BodyTagSupport possiede questi particolari metodi, oltre a quelli della classe TagSupport che estende:void doInitBody()

Prepare for evaluation before the first body evaluation.BodyContent getBodyContent()

Get current bodyContent.  JspWriter getPreviousOut() Get surrounding out JspWriter.  void setBodyContent(BodyContent b)

Prepare for evaluation of the body.

Esempio di tag con corpopackage taglib;

import java.io.IOException;

import javax.servlet.jsp.JspTagException;import javax.servlet.jsp.tagext.BodyContent;import javax.servlet.jsp.tagext.BodyTagSupport;

public class BodyTag extends BodyTagSupport {public int doAfterBody() throws JspTagException {

BodyContent bc = getBodyContent();String text = bc.getString();try {

bodyContent.clearBody();bodyContent.println("Corpo: " + text);bodyContent.writeOut(bodyContent.getEnclosingWriter());

} catch (IOException e) {// TODO Auto-generated catch blocke.printStackTrace();

}return SKIP_BODY;

}}

Descrittore del tag con corpo