Bonjour,

Encore une fois je viens demander de l'aide. Je suis toujours sous Eclipse 3.5, GWT 2.20 et GXT 2.1.

Mon problème est que mon code qui marche en hosted mode plante lamentablement sous Tomcat 5.5 sans me donner la moindre explication (sinon c'est pas marrant...). J'ai crée un menu à onglet qui, lorsqu'on clique sur un onglet, charge la catégorie demandé (je me suis essayé au CodeSplitting) et m'affiche, entre autres, la liste des items. Ce que j'ai du mal à comprendre c'est que j'ai dans les logs de Tomcat les commentaires de sortie de mon service mais pas de ma classe Panel qui l'appelle. Je vous met mon code, merci d'avance à qui pourra m'aider.

Ma Vue

Code : Sélectionner tout - Visualiser dans une fenêtre à part
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
 
package com.a806278.MCO.client;
 
import java.util.ArrayList;
import java.util.Iterator;
import java.util.List;
 
import com.a806278.MCO.Entity.TypeAppareil;
import com.a806278.MCO.Resources.classes.WorkIcons;
import com.a806278.MCO.WebService.TypeAppareilService;
import com.a806278.MCO.WebService.TypeAppareilServiceAsync;
import com.extjs.gxt.ui.client.Style.HorizontalAlignment;
import com.extjs.gxt.ui.client.Style.Orientation;
import com.extjs.gxt.ui.client.Style.SelectionMode;
import com.extjs.gxt.ui.client.binding.FormBinding;
import com.extjs.gxt.ui.client.data.BaseListLoader;
import com.extjs.gxt.ui.client.data.BeanModel;
import com.extjs.gxt.ui.client.data.BeanModelLookup;
import com.extjs.gxt.ui.client.data.BeanModelReader;
import com.extjs.gxt.ui.client.data.ListLoader;
import com.extjs.gxt.ui.client.data.RpcProxy;
import com.extjs.gxt.ui.client.event.ButtonEvent;
import com.extjs.gxt.ui.client.event.Events;
import com.extjs.gxt.ui.client.event.Listener;
import com.extjs.gxt.ui.client.event.MenuEvent;
import com.extjs.gxt.ui.client.event.MessageBoxEvent;
import com.extjs.gxt.ui.client.event.SelectionChangedEvent;
import com.extjs.gxt.ui.client.event.SelectionListener;
import com.extjs.gxt.ui.client.store.ListStore;
import com.extjs.gxt.ui.client.store.Store;
import com.extjs.gxt.ui.client.widget.ContentPanel;
import com.extjs.gxt.ui.client.widget.MessageBox;
import com.extjs.gxt.ui.client.widget.button.Button;
import com.extjs.gxt.ui.client.widget.form.Field;
import com.extjs.gxt.ui.client.widget.form.FormPanel;
import com.extjs.gxt.ui.client.widget.form.TextField;
import com.extjs.gxt.ui.client.widget.grid.ColumnConfig;
import com.extjs.gxt.ui.client.widget.grid.ColumnModel;
import com.extjs.gxt.ui.client.widget.grid.Grid;
import com.extjs.gxt.ui.client.widget.grid.GridSelectionModel;
import com.extjs.gxt.ui.client.widget.layout.RowData;
import com.extjs.gxt.ui.client.widget.layout.RowLayout;
import com.extjs.gxt.ui.client.widget.menu.Menu;
import com.extjs.gxt.ui.client.widget.menu.MenuItem;
import com.google.gwt.core.client.GWT;
import com.google.gwt.user.client.rpc.AsyncCallback;
import com.google.gwt.user.client.rpc.ServiceDefTarget;
import com.google.gwt.user.client.ui.AbstractImagePrototype;
 
@SuppressWarnings("unchecked")
public class TypeAppareilPanel extends ContentPanel {
 
		private FormBinding formBindings;
		private TypeAppareilServiceAsync typeAppareilService;
		private Grid grid;
		private FormPanel panel;
 
		//constructeur de la liste
		public TypeAppareilPanel(){		
 
			try{
				System.out.println("debut de panel");
 
				//on parametre le panel
				this.setFrame(true); 
				this.setHeaderVisible(false);
				this.setSize(798,425);
				this.setLayout(new RowLayout(Orientation.HORIZONTAL));  
 
				// Creation et initialisation du proxy client permettant l’appel du service : TypeApp
				// 1) Creation du stub
				typeAppareilService = (TypeAppareilServiceAsync) GWT.create(TypeAppareilService.class);
 
				// 2) Definir l’URL : elle doit appartenir au meme domaine que la page
				ServiceDefTarget endpoint = (ServiceDefTarget) typeAppareilService;
				String moduleRelativeURL = GWT.getModuleBaseURL() + "TypeAppareil";
				endpoint.setServiceEntryPoint(moduleRelativeURL);
 
				//on instancie le grid
				grid = this.createGrid();
				GridSelectionModel gsm = grid.getSelectionModel();
				gsm.setSelectionMode(SelectionMode.SINGLE);
			    grid.getSelectionModel().addListener(Events.SelectionChange,  
			        new Listener<SelectionChangedEvent>() {
						public void handleEvent(SelectionChangedEvent be) {						 
					       if (be.getSelectedItem() != null) {				    	   
					    	   formBindings.bind(be.getSelectedItem());
					       }
					       else {  
					    	   formBindings.unbind();  
					       }  				         
						}		          
			        });		    
 
			   //on ajoute le grid au panel
				this.add(grid, new RowData(.6, 1));
 
				//on instancie le formulaire
				panel = createForm();  
			    formBindings = new FormBinding(panel, true);  
			    formBindings.setStore((Store) grid.getStore());  
 
			    //on ajoute les boutons de comit et reset
			    panel.setButtonAlign(HorizontalAlignment.LEFT);  
			    panel.addButton(new Button("Reset", new SelectionListener<ButtonEvent>() {  
			      @Override  
			      public void componentSelected(ButtonEvent ce) {  
			        grid.getStore().rejectChanges();  
			        grid.getSelectionModel().deselectAll();
			      }  
			    }));  
			    panel.addButton(new Button("Commit", new SelectionListener<ButtonEvent>() {  
			      @Override  
			      public void componentSelected(ButtonEvent ce) { 
 
			    	  //on recupere le contenu du textField
			    	  List<Field<?>> listFields = panel.getFields();
 
			    	  //on verifie que les champs nécessaires sont bien remplis
			    	  if(listFields.get(1).getRawValue().equals("")){
			    		  grid.getStore().rejectChanges();
			    		  MessageBox.alert("Erreur", "Veuillez remplir tous les champs.", null);		    		  
			    	  }  
			    	  else{
			    		  //on recupere le typeManuel
			    		  TypeAppareil newTypeAppareil = new TypeAppareil();
				    	  newTypeAppareil.setTypeApp(listFields.get(1).getRawValue());
			    		  String id = listFields.get(0).getRawValue();   		  
 
			    		  // cas d'un ajout
				    	  if(id.equals("")){			    		  
				    		  //on verifie que le type n'existe pas déja
				    		  boolean b = exist(grid.getStore().getModels(),newTypeAppareil);
 
				    		  if(b){
				    			  MessageBox.alert("Erreur", "Ce type existe deja.", null);
				    			  grid.getStore().rejectChanges();
				    		  }
				    		  else{	  
					    		  //on appelle la fonction d'ajout
					    		  insertLine(newTypeAppareil);		    		  
				    		  }
				    	  }
				    	  //cas d'une modif
				    	  else{
				    		//on recup l'id
				    		  newTypeAppareil.setIdTypeApp(Integer.valueOf(listFields.get(0).getRawValue()));
 
				    		  //on appelle la fonction de modif
				    		  updateLine(newTypeAppareil);		    		  
				    	  }
			    	  }
 
			      }  
			    })); 		
 
				//on ajoute le formulaire
			    this.add(panel, new RowData(.4, 1));  
 
			}
			catch(Exception ex){
				System.out.println("Erreur.");
				System.out.println(ex.getMessage());
			}
 
			System.out.println("Fin du panel");
		}
 
		private Grid createGrid(){
			System.out.println("debut de creation du grid");
			//on declare le grid
			//on commence par les colonnes		
			List<ColumnConfig> columns = new ArrayList<ColumnConfig>();  
			columns.add(new ColumnConfig("idTypeApp", "Id du type appareil", 150));  
			columns.add(new ColumnConfig("typeApp", "Type de l'appareil", 150));  
			ColumnModel cm = new ColumnModel(columns);  
 
			// 2) on definit le proxy
			// proxy and reader  
			RpcProxy proxy = new RpcProxy() {  
			  @Override  
			  public void load(Object loadConfig, AsyncCallback callback) {  
				  typeAppareilService.getListOfTypeAppareil(callback);			 
			  }  
			}; 	  	
 
			//on declare le reader et le loader
			BeanModelReader reader = new BeanModelReader();  
			ListLoader loader = new BaseListLoader(proxy, reader);  
			final ListStore<BeanModel> store = new ListStore<BeanModel>(loader);		
			store.setMonitorChanges(true);
 
			//on envoie la recuperation de la liste via RCP
			loader.load();  
 
			System.out.println("Le loader est rempli");
 
			//on declare le grid
			grid = new Grid(store, cm);  
			grid.setWidth(306);
			grid.setHeight(400);
			grid.setBorders(true);	
 
			//on declare le menu
			Menu contextMenu = new Menu();  
 
			//on declare les icones
			WorkIcons workIcon = (WorkIcons) GWT.create(WorkIcons.class);
			AbstractImagePrototype.create(workIcon.add());
 
			//on ajoute le menu contextuel au grid
			MenuItem insert = new MenuItem();  
		     insert.setText("Insert Item");
		     insert.setIcon(AbstractImagePrototype.create(workIcon.add()));
		     insert.addSelectionListener(new SelectionListener<MenuEvent>() {  
		         public void componentSelected(MenuEvent ce) {  
		        	 	//on enleve le binding
						formBindings.unbind();					
						//on vide le formulaire
						panel.clear();	 					
						//on sort du grid
						grid.getSelectionModel().deselectAll();
		           }    
		       });  
 
		      contextMenu.add(insert);   
 
		     MenuItem remove = new MenuItem();  
		     remove.setText("Remove Selected");
		     remove.setIcon(AbstractImagePrototype.create(workIcon.delete()));
		     remove.addSelectionListener(new SelectionListener<MenuEvent>() {
				public void componentSelected(MenuEvent ce) {
					//on affiche le message de confirmation
					MessageBox box = MessageBox.confirm("Confirmer la suppression", "Voulez vous supprimer cet enregistrement?",null);
					box.addCallback(new Listener<MessageBoxEvent>() {					
						public void handleEvent(MessageBoxEvent be) {
							//si la suppression est confirmé
							if(be.getButtonClicked().getText().equals("Yes")){
								//on demande la suppression
								deleteLine();				
							}
						}
					});
				}
			 });
 
		     contextMenu.add(remove);
 
		     //et on lie le menu au grid
		     grid.setContextMenu(contextMenu);
		     System.out.println("le grid est cree");
			return grid;
		}
 
		/**
                 * Methode qui créé le formulaire
                 * 
                 * @return
                 */
		private FormPanel createForm(){
			System.out.println("debut de la creation du formulaire");
			//on declare le formulaire
			 FormPanel panel = new FormPanel();  
			 panel.setHeaderVisible(false);
 
			 //champs id
			 TextField<String> idTypeApp = new TextField<String>();  
			 idTypeApp.setName("idTypeApp");  
			 idTypeApp.setFieldLabel("Id du Type Appareil");  
			 idTypeApp.setEnabled(false);
			 panel.add(idTypeApp);  
 
			 // champs type
			 TextField<String> typeApp = new TextField<String>();  
			 typeApp.setName("typeApp");  
			 typeApp.setFieldLabel("Type Appareil");  
			 panel.add(typeApp);
			 System.out.println("fin de la creation du formulaire");
			 return panel;
		}
 
		/**
                 * Methode qui va supprimer la ligne sélectionnée
                 */
		private void deleteLine(){
 
			//on appelle le service
			typeAppareilService.deleteTypeAppareil((Integer)grid.getSelectionModel().getSelectedItem().get("idTypeApp"), new AsyncCallback<Boolean>() {
				public void onFailure(Throwable caught) {
					//on affiche un message d'alerte
					MessageBox.alert("Erreur", "L'appel a echoue.", null);
				}
				public void onSuccess(Boolean result) {				
					if(result){
						//on supprime la ligne du grid
						grid.getStore().remove((BeanModel) grid.getSelectionModel().getSelectedItem());
					}
					else{
						//on affiche un message d'alerte
						MessageBox.alert("Erreur", "La suppression a echoue.", null);
					}
				}			
			});
		}
 
		/**
                 * Methode qui va ajouter une ligne
                 * 
                 * @param newTypeApp
                 */
		private void insertLine(TypeAppareil newTypeAppareil){		
			typeAppareilService.addTypeAppareil(newTypeAppareil, new AsyncCallback<TypeAppareil>() {
				public void onFailure(Throwable caught) {
					MessageBox.alert("Erreur", "L'appel a echoue.", null);
				}
				public void onSuccess(TypeAppareil result) {
					//si l'ajout a fonctionné
					if(result.getIdTypeApp() != null){
						//on ajoute la ligne du grid
						grid.getStore().add(createModel(result));
						int lastRow = grid.getStore().getCount() - 1;
						grid.getSelectionModel().select(lastRow, false);
						grid.getView().focusRow(lastRow);
 
					}
					else{
						//on affiche un message d'alerte
						grid.getStore().rejectChanges();
						MessageBox.alert("Erreur", "L'ajout a echoue.", null);
					}
				}
			});
 
		}
 
		/**
                 * Methode qui va modifier une ligne
                 * 
                 * @param newTypeAppareil
                 */
		private void updateLine(TypeAppareil newTypeAppareil){
			//on appelle le service
			typeAppareilService.updateTypeAppareil(newTypeAppareil, new AsyncCallback<Boolean>() {
				public void onFailure(Throwable caught) {
					//on affiche un message d'alerte
					MessageBox.alert("Erreur", "L'appel a echoue.", null);
				}
				public void onSuccess(Boolean result) {				
					if(result){
						//on supprime la ligne du grid
						grid.getStore().commitChanges();
 
					}
					else{
						//on affiche un message d'alerte
						grid.getStore().rejectChanges();
						MessageBox.alert("Erreur", "La modification a echoue.", null);
					}
				}			
			});
		}
 
		private boolean exist(List listeModels, TypeAppareil typeAppareil){
 
			boolean exist = false;
 
			//on boucle dans la liste
			Iterator it = listeModels.iterator();		
			while(it.hasNext()){
				//on le met dans un objet
				BeanModel bm = (BeanModel) it.next();			
				TypeAppareil leTypeToCompare = bm.getBean();
 
				//on compare les labels
				if(typeAppareil.equals(leTypeToCompare)){
					exist = true;
				}
			}
 
			return exist;
		}
 
		private BeanModel createModel(TypeAppareil leType){		
			return BeanModelLookup.get().getFactory(TypeAppareil.class).createModel(leType);
		}
 
	}
Mon DataAccess
Code : Sélectionner tout - Visualiser dans une fenêtre à part
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
 
/**
 * 
 */
package com.a806278.MCO.DataAccess;
 
import java.sql.ResultSet;
import java.sql.SQLException;
import java.sql.Statement;
import java.util.ArrayList;
import com.a806278.MCO.Entity.TypeAppareil;
 
 
 
/**
 * @author a806278
 *
 */
public class TypeAppareilDAO extends DataAccess{
 
	private ArrayList<TypeAppareil> listOfTypeAppareil;
    private TypeAppareil leTypeCourant;
 
 
    /**
     * Empty constructor
         * 
         */
	public TypeAppareilDAO(){			
		super();
	}
 
 
	/**
         * @return the listOfTypeApp
         */
	public ArrayList<TypeAppareil> getListOfTypeAppareil() {
		System.out.println("Debut du DAO");
		try {
			//on instancie l'arrayList
			listOfTypeAppareil = new ArrayList<TypeAppareil>();
 
			//on cree la requete
			Statement statement = laConnexion.createStatement();
 
			String query = "SELECT * FROM TYPE_APP";
 
			//si il y a qlq chose a lire
			if(statement.execute(query)){
 
				ResultSet resultats = statement.executeQuery(query);
 
				//on mappe les resultats
				while(resultats.next()){
					//on ajoute le nouveau type
					listOfTypeAppareil.add(new TypeAppareil(resultats.getInt("ID_TYPE_APP"), resultats.getString("TYPE_APP")));
				}
 
				//on ferme le resultset
				resultats.close();					
			}
 
			else{
				System.out.println("Aucun resultat a afficher.");
			}
 
			//on ferme le statement			
			statement.close();			
			laConnexion.close();
		} 
		catch (SQLException e) {
			System.out.println(e.getMessage());
			e.printStackTrace();
		}	
		finally{
			//on ferme la connexion
			try {
				System.out.println("Fin de la lecture.");
				laConnexion.close();
			} catch (SQLException e) {
				// TODO Auto-generated catch block
				e.printStackTrace();
			}
		}
		System.out.println("Fin du DAO");
		return listOfTypeAppareil;
	}
 
 
	/**
         * @param listOfTypeApp the listOfTypeApp to set
         */
	public void setListOfTypeAppareil(
		ArrayList<TypeAppareil> listOfTypeAppareil) {
		this.listOfTypeAppareil = listOfTypeAppareil;
	}
 
 
	/**
         * @return the leTypeCourant
         */
	public TypeAppareil getLeTypeCourant() {
		return leTypeCourant;
	}
 
 
	/**
         * @param leTypeCourant the leTypeCourant to set
         */
	public void setLeTypeCourant(TypeAppareil leTypeCourant) {
		this.leTypeCourant = leTypeCourant;
	}
 
 
	/**
         * Add object method.
         * 
         */
	public TypeAppareil addTypeApp(TypeAppareil newTypeApp) {
 
		try {			
			//on cree la requete
			Statement statement = laConnexion.createStatement();
 
			//on recupere le nouvel id de la sequence
			String seq_query = "SELECT seq_TYPE_APP.nextval FROM dual";			
			ResultSet rs = statement.executeQuery(seq_query);
			rs.next();			
			int newId = rs.getInt(1);
 
			//on cree la requete dajout avec le nouvel id
			String query = "INSERT INTO TYPE_APP (ID_TYPE_APP,TYPE_APP) VALUES ('"+ newId +"','"+ newTypeApp.getTypeApp() +"')";
 
			int i = statement.executeUpdate(query);
 
			if(i == 1){
				newTypeApp.setIdTypeApp(newId);
			}
 
			//on ferme le statement			
			statement.close();	
			laConnexion.close();
		}
		catch(SQLException ex){
			System.out.println(ex.getMessage());
		}		
 
		return newTypeApp;
 
 
	}
 
 
	/**
         * Delete object method.
         * 
         */
	public boolean deleteObject(int id) {
 
		boolean succeed = false;
 
		try {			
			//on cree la requete
			Statement statement = laConnexion.createStatement();		
			String query = "DELETE FROM TYPE_APP WHERE ID_TYPE_APP = '"+ id +"'";
 
			int i = statement.executeUpdate(query);
 
			if(i == 1){
				succeed = true;
			}
 
			//on ferme le statement			
			statement.close();	
			laConnexion.close();
		}
		catch(SQLException ex){
			System.out.println(ex.getMessage());
		}		
 
		return succeed;
	}
 
	/**
         * Update method.
         * 
         */
	public boolean updateTypeApp(TypeAppareil modifiedTypeApp) {
		boolean succeed = false;
 
		try {			
			//on cree la requete
			Statement statement = laConnexion.createStatement();		
			String query = "UPDATE TYPE_APP SET  TYPE_APP = '"+ modifiedTypeApp.getTypeApp() +"' WHERE " +
								"ID_TYPE_APP = '"+ modifiedTypeApp.getIdTypeApp() + "'";
 
			int i = statement.executeUpdate(query);
 
			if(i == 1){
				succeed = true;
			}
 
			//on ferme le statement			
			statement.close();	
			laConnexion.close();
		}
		catch(SQLException ex){
			System.out.println(ex.getMessage());
		}		
 
		return succeed;
	}	
 
}
Mon Entité
Code : Sélectionner tout - Visualiser dans une fenêtre à part
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
 
/**
 * 
 */
package com.a806278.MCO.Entity;
 
import java.io.Serializable;
import com.extjs.gxt.ui.client.data.BeanModelTag;
 
/**
 * @author a806278
 *
 */
 
@SuppressWarnings({"serial"})
public class TypeAppareil implements Serializable, BeanModelTag  {
 
 
	private Integer idTypeApp;
	private String typeApp;
 
 
	/**
         * Empty constructor
         * 
         */
	public TypeAppareil(){
		System.out.println("Constructeur vide");
	}
 
 
	/**
         * Full constructor
         * 
         * @param idTypeApp
         * @param typeApp
         */
	public TypeAppareil(Integer idTypeApp, String typeApp) {
		this.idTypeApp = idTypeApp;
		this.typeApp = typeApp;
		System.out.println("Constructeur avec parametres");
	}
 
 
	/* (non-Javadoc)
	 * @see java.lang.Object#hashCode()
	 */
	@Override
	public int hashCode() {
		final int prime = 31;
		int result = 1;
		result = prime * result + ((typeApp == null) ? 0 : typeApp.hashCode());
		return result;
	}
 
 
	/* (non-Javadoc)
	 * @see java.lang.Object#equals(java.lang.Object)
	 */
	@Override
	public boolean equals(Object obj) {
		if (this == obj) {
			return true;
		}
		if (obj == null) {
			return false;
		}
		if (!(obj instanceof TypeAppareil)) {
			return false;
		}
		TypeAppareil other = (TypeAppareil) obj;
		if (typeApp == null) {
			if (other.typeApp != null) {
				return false;
			}
		} else if (!typeApp.equals(other.typeApp)) {
			return false;
		}
		return true;
	}
 
 
	/**
         * @return the idTypeApp
         */
	public Integer getIdTypeApp() {
		return idTypeApp;
	}
 
 
	/**
         * @param idTypeApp the idTypeApp to set
         */
	public void setIdTypeApp(Integer idTypeApp) {
		this.idTypeApp = idTypeApp;
	}
 
 
	/**
         * @return the typeApp
         */
	public String getTypeApp() {
		return typeApp;
	}
 
 
	/**
         * @param typeApp the typeApp to set
         */
	public void setTypeApp(String typeApp) {
		this.typeApp = typeApp;
	}
 
 
}
Et pour finir mes Logs
Code : Sélectionner tout - Visualiser dans une fenêtre à part
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
 
1 mars 2010 16:18:30 org.apache.catalina.core.AprLifecycleListener lifecycleEven
t
INFO: The Apache Tomcat Native library which allows optimal performance in produ
ction environments was not found on the java.library.path: D:\Apache Software Fo
undation\Tomcat 5.5\bin;.;C:\windows\system32;C:\windows;C:\oracle\ora92\jre\1.4
.2\bin\client;C:\oracle\ora92\jre\1.4.2\bin;C:\oracle\ora92\bin;C:\Program Files
\Oracle\jre\1.3.1\bin;C:\Program Files\Oracle\jre\1.1.8\bin;C:\windows\system32;
C:\windows;C:\windows\System32\Wbem;C:\Program Files\Microsoft SQL Server\80\Too
ls\BINN
1 mars 2010 16:18:30 org.apache.coyote.http11.Http11BaseProtocol init
INFO: Initialisation de Coyote HTTP/1.1 sur http-8280
1 mars 2010 16:18:30 org.apache.catalina.startup.Catalina load
INFO: Initialization processed in 953 ms
1 mars 2010 16:18:30 org.apache.catalina.core.StandardService start
INFO: DÚmarrage du service Catalina
1 mars 2010 16:18:30 org.apache.catalina.core.StandardEngine start
INFO: Starting Servlet Engine: Apache Tomcat/5.5.28
1 mars 2010 16:18:30 org.apache.catalina.core.StandardHost start
INFO: XML validation disabled
1 mars 2010 16:18:32 org.apache.coyote.http11.Http11BaseProtocol start
INFO: DÚmarrage de Coyote HTTP/1.1 sur http-8280
1 mars 2010 16:18:32 org.apache.jk.common.ChannelSocket init
INFO: JK: ajp13 listening on /0.0.0.0:8009
1 mars 2010 16:18:32 org.apache.jk.server.JkMain start
INFO: Jk running ID=0 time=0/110  config=null
1 mars 2010 16:18:32 org.apache.catalina.storeconfig.StoreLoader load
INFO: Find registry server-registry.xml at classpath resource
1 mars 2010 16:18:32 org.apache.catalina.startup.Catalina start
INFO: Server startup in 1813 ms
debut du service
La connexion est etablie.
Debut du DAO
Constructeur avec parametres
Constructeur avec parametres
Constructeur avec parametres
Constructeur avec parametres
Constructeur avec parametres
Fin de la lecture.
Fin du DAO
Fin du service