7. Esempio di applicazione-04: rdvmedecins-pf-spring
7.1. Porting
Ora porteremo l'applicazione precedente su un ambiente Spring/Tomcat:
![]() |
Ci baseremo su due applicazioni esistenti. Utilizzeremo:
- i livelli [DAO] e [JPA] della versione 02 di JSF / Spring,
- il livello [web] / Primefaces della versione 03 di PF / EJB,
- i file di configurazione Spring della versione 02
Qui stiamo eseguendo un'operazione simile a quella effettuata per il porting dell'applicazione JSF2 / EJB / Glassfish in un ambiente JSF2 / Spring Tomcat. Pertanto, forniremo meno spiegazioni. Se necessario, il lettore può fare riferimento a quel porting.
Stiamo inserendo tutti i progetti necessari per il porting in una nuova cartella [rdvmedecins-pf-spring] [1]:
![]() |
- [mv-rdvmedecins-spring-dao-jpa]: i livelli [DAO] e [JPA] della versione 02 di JSF/Spring,
- [mv-rdvmedecins-spring-metier]: il livello [business] della versione 02 JSF / Spring,
- [mv-rdvmedecins-pf]: il livello [web] della versione 03 di Primefaces / EJB,
- in [2], li carichiamo in NetBeans,
- in [3], le dipendenze del progetto web non sono più corrette:
- le dipendenze dei livelli [DAO], [JPA] e [business] devono essere modificate per puntare ora ai progetti Spring;
- Il server GlassFish forniva le librerie JSF. Questo non è più il caso con il server Tomcat. Devono quindi essere aggiunte alle dipendenze.
Il progetto [web] si evolve come segue:
![]() |
Il file [pom.xml] per il livello [web] presenta ora le seguenti dipendenze:
<dependencies>
<dependency>
<groupId>${project.groupId}</groupId>
<artifactId>mv-rdvmedecins-spring-metier</artifactId>
<version>${project.version}</version>
</dependency>
<dependency>
<groupId>com.sun.faces</groupId>
<artifactId>jsf-api</artifactId>
<version>2.1.7</version>
</dependency>
<dependency>
<groupId>com.sun.faces</groupId>
<artifactId>jsf-impl</artifactId>
<version>2.1.7</version>
</dependency>
<dependency>
<groupId>org.primefaces</groupId>
<artifactId>primefaces</artifactId>
<version>3.3</version>
</dependency>
</dependencies>
Vengono visualizzati degli errori. Sono causati dai riferimenti EJB nel livello [web]. Esaminiamo innanzitutto il bean [Application]:
![]() |
Rimuoviamo tutte le righe che causano errori dovuti a pacchetti mancanti, rinominiamo [IMetier] (il suo nome nel livello [business] di Spring) nell'interfaccia [IMetierLocal] e utilizziamo Spring per istanziarlo:
package beans;
import java.util.ArrayList;
import java.util.List;
import org.springframework.context.ApplicationContext;
import org.springframework.context.support.ClassPathXmlApplicationContext;
import rdvmedecins.metier.service.IMetier;
public class Application {
// business layer
private IMetier metier;
// errors
private List<Erreur> erreurs = new ArrayList<Erreur>();
private Boolean erreur = false;
public Application() {
try {
// instantiation layer [business]
ApplicationContext ctx = new ClassPathXmlApplicationContext("spring-config-metier-dao.xml");
metier = (IMetier) ctx.getBean("metier");
} catch (Throwable th) {
// we note the error
erreur = true;
erreurs.add(new Erreur(th.getClass().getName(), th.getMessage()));
while (th.getCause() != null) {
th = th.getCause();
erreurs.add(new Erreur(th.getClass().getName(), th.getMessage()));
}
return;
}
}
// getters
public Boolean getErreur() {
return erreur;
}
public List<Erreur> getErreurs() {
return erreurs;
}
public IMetier getMetier() {
return metier;
}
}
- righe 20-21: istanziazione del livello [business] dal file di configurazione Spring. Questo è il file utilizzato dal livello [business] [1]. Lo copiamo nel progetto web [2]:
![]() |
- righe 22-31: gestiamo eventuali eccezioni e salviamo la loro traccia dello stack.
Fatto ciò, il bean [Application] non presenta più alcun errore. Ora esaminiamo il bean [Form] [1], [2]:
![]() |
Rimuoviamo tutte le righe errate (importazioni e annotazioni) dovute alla mancanza di pacchetti. Questo è sufficiente per eliminare tutti gli errori [3].
![]() |
Inoltre, dobbiamo aggiungere il getter e il setter per il campo
// bean Application
private Application application;
Alcune delle annotazioni rimosse dai bean [Application] e [Form] dichiaravano le classi come bean con un ambito specifico. Ora, questa configurazione è impostata nel seguente file [faces-config.xml] [4]:
<?xml version='1.0' encoding='UTF-8'?>
<!-- =========== FULL CONFIGURATION FILE ================================== -->
<faces-config version="2.0"
xmlns="http://java.sun.com/xml/ns/javaee"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://java.sun.com/xml/ns/javaee http://java.sun.com/xml/ns/javaee/web-facesconfig_2_0.xsd">
<application>
<!-- message file -->
<resource-bundle>
<base-name>
messages
</base-name>
<var>msg</var>
</resource-bundle>
<message-bundle>messages</message-bundle>
</application>
<!-- the applicationBean bean -->
<managed-bean>
<managed-bean-name>applicationBean</managed-bean-name>
<managed-bean-class>beans.Application</managed-bean-class>
<managed-bean-scope>application</managed-bean-scope>
</managed-bean>
<!-- the bean form -->
<managed-bean>
<managed-bean-name>form</managed-bean-name>
<managed-bean-class>beans.Form</managed-bean-class>
<managed-bean-scope>session</managed-bean-scope>
<managed-property>
<property-name>application</property-name>
<value>#{applicationBean}</value>
</managed-property>
</managed-bean>
</faces-config>
Normalmente, il porting è completato. Tuttavia, ci sono ancora alcuni dettagli da sistemare. Possiamo provare a eseguire l'applicazione web.
![]() |
Lasciamo al lettore il compito di testare questa nuova applicazione. Possiamo migliorarla leggermente per gestire il caso in cui l'inizializzazione del bean [Application] abbia dato esito negativo. Sappiamo che in questo caso sono stati inizializzati i seguenti campi:
// erreurs
private List<Erreur> erreurs = new ArrayList<Erreur>();
private Boolean erreur = false;
Questo scenario può essere gestito nel metodo init del bean [Form]:
@PostConstruct
private void init() {
// was the initialization successful?
if (application.getErreur()) {
// retrieve the list of errors
erreurs = application.getErreurs();
// the error view is displayed
setForms(false, false, true);
}
// caching doctors and customers
...
}
- riga 5: se il bean [Application] non è stato inizializzato,
- riga 7: recuperare l'elenco degli errori,
- riga 9: e visualizza la pagina di errore.
Pertanto, se arrestiamo il DBMS MySQL e riavviamo l'applicazione, ora vediamo la seguente pagina:

7.2. Conclusione
Il porting dell'applicazione PrimeFaces/EJB/GlassFish in un ambiente PrimeFaces/Spring/Tomcat si è rivelato semplice. Il problema di perdita di memoria segnalato nello studio dell'applicazione JSF/Spring/Tomcat (Sezione 4.3.5) permane.
Verrà risolto allo stesso modo.
7.3. Test con Eclipse
![]() |
Importiamo i progetti Maven in Eclipse [1]:
Eseguiamo il progetto web [2].
![]() |
Selezioniamo il server Tomcat [3]. La pagina iniziale dell'applicazione viene quindi visualizzata nel browser interno di Eclipse [4].









