PDA

View Full Version : [servlet-java] soluzione per organizzare classi


prazision
08-05-2005, 13:09
Dunque ho sviluppato un mini progettino in java per l'upload di alcuni file sul file-system e lo svolgimento di altre operazioni.
Da una pagina jsp viene richiamata una servlet a cui viene passato un parametro (lo chiamo param per comoditā); la servlet a seconda del parametro passato, utilizzando la classe Class , richiamerā la classe Java adatta alle operazioni indicate da param.

Ci sono dunque varie classi java(a seconda del tipo di operazioni da compiere) che hanno molti metodi in comune(o che cmq posso rendere tali tramite dei parametri passati) e un solo metodo diverso(almeno per ora) che non posso in alcuna maniera rendere dinamico e quindi comune a tutte; questi metodi in comune riguardano ad esempio operazioni sul db o controlli sul file system.

ho pensato di poter organizzare le varie classi java in 2 maniere:

1:
mi creo una classe astratta(diciamo Padre.java) che contiene tutti i metodi(giā implementati) che sono comuni alle varie classi figlie e delle classi figlie(FigliaA, FigliaB ecc., in futuro auemnteranno) che contengono quell'unico metodo che le differenzia; nella classe padre c'č anche un metodo(quello che viene usato dalla servlet) che esegue tutti i metodi in maniera sequenziale e il metodo astratto che le figlie implementano.
di volta in volta dalla servlet verrā chiamata la classe figlia giusta(tramite polimorfismo) la quale eredita tutti i metodi che le servono

2:
mi creo una classe astratta con un solo metodo astratto(Padre.java) che mi serve solo per usare il riferimento polimorfico(nella servlet) e varie classi figlie(FigliaA, FigliaB ecc.) che contengono quell'unico metodo che le differenzia.
le figlie contengono anche un'istanza di una classe(diciamo Esterna.java) che contiene tutti i metodi che sono comuni alle varie classi.
c'č poi da capire dove mettere il metodo che esegue tutti i metodi in maniera sequenziale(se in Padre o nelle singole figlie), ora ci penso

quale soluzione č da preferire??
qualcuno ha qualche altra idea??
grazie(per favore non esprimete concetti supercomplicati che vado in panico :-) )

grazie

theClimber
08-05-2005, 17:57
Entrambe le soluzioni vanno bene, la prima e' + semplice, la seconda e' forse + flessibile ed io personalmente nell'implementarla invertirei la dipendenza (Esterna.java conterrebbe un link ad un istanza di una sottoclasse Padre.java)

Le due soluzioni che proponi sono esempi abbastanza tipici dei pattern Template Method e Strategy; se ti interessa approfondire prova a dare un occhio a questi link:

http://www.cuj.com/documents/s=7992/cujcexp1908martin/
http://c2.com/cgi/wiki?CategoryBehavioralPatterns


... Da una pagina jsp viene richiamata una servlet .....

Come mai questa scelta? solitamente se si organizza la web application con pattern MVC si usa fare il contrario, ovvero usare le servlet per processare la richiesta e ridirigere verso un JSP (o un template XSL) per produrre l'output.

ciao

prazision
08-05-2005, 23:08
non so.
la pagina jsp di cui parlo contiene un form che permette di caricare il file e di inserire altri valori; il form punta poi alla servlet che chiama la classe adatta

c'č cmq anche una seconda jsp che come dici tu che visualizza l'output.
dici che dovevo trasformare la prima jsp in una servlet^?

domani(o quando posso )guardo quei link.

grazie

theClimber
09-05-2005, 09:50
Ah, avevo capito male io, pensavo che il collegamento JSP --> servlet fosse un operazione server side sulla stessa richiesta. La situazione che hai adesso va piu' che bene.

Unico consiglio aggiuntivo: dopo il post del form la servlet dovrebbe fare una redirect (con http 302) sulla JSP per i risultati dell'invio del form, in modo da evitare potenziali problemi di invii multipli.

Ciao

prazision
09-05-2005, 17:59
Unico consiglio aggiuntivo: dopo il post del form la servlet dovrebbe fare una redirect (con http 302) sulla JSP per i risultati dell'invio del form, in modo da evitare potenziali problemi di invii multipli.

mi spiegheresti (anche qualcunaltro eh :D )meglio questa ultima cosa

grazie

theClimber
09-05-2005, 19:31
Prova a dare un occhio a:

http://www.theserverside.com/articles/article.tss?l=RedirectAfterPost

ciao

prazision
09-05-2005, 21:32
ok provo a dare un occhio a
http://www.mokabyte.it/mbtss/2005/01/redirect-after-post.htm (la versione in italiano :D )

poi ti dico

grazie mille

prazision
09-05-2005, 23:01
un primo sguardo l'ho dato.
ti ho mandato 2 messaggi

grazie