IdentifiantMot de passe
Loading...
Mot de passe oublié ?Je m'inscris ! (gratuit)
Navigation

Inscrivez-vous gratuitement
pour pouvoir participer, suivre les réponses en temps réel, voter pour les messages, poser vos propres questions et recevoir la newsletter

Struts 1 Java Discussion :

problème getDataSource


Sujet :

Struts 1 Java

  1. #1
    Membre à l'essai
    Inscrit en
    Janvier 2007
    Messages
    33
    Détails du profil
    Informations forums :
    Inscription : Janvier 2007
    Messages : 33
    Points : 24
    Points
    24
    Par défaut problème getDataSource
    Bonjour,

    Je fais actuellement le tutorial réalisé par Serge Tahé sur Struts afin de comprendre comment ca fonctionne et je rencontre un problème sur la fin de ce tutorial.
    En effet, il propose d'effectuer un acces à une base de données. Cependant, j'ai un problème sur une des fonctions : getDataSource() qui n'est pas reconnu.
    Eclipse ne trouve pas cette méthode qui est pourtant défini dans org.apache.struts.action.Action
    Lorsque je regarde la doc je suis ok avec le code.
    Je pense que Eclipse ne doit pas trouver le bon jar peut etre. Je ne sais pas trop et je ne trouve pas ou localiser le problème et comment le corriger. Quelqu'un peut m'aider?

    Voici le code:
    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
     
    package bdd;
     
    import java.io.IOException;
    import java.sql.Connection;
    import java.sql.ResultSet;
    import java.sql.Statement;
    import java.util.ArrayList;
    import javax.servlet.ServletException;
    import javax.servlet.http.HttpServletRequest;
    import javax.servlet.http.HttpServletResponse;
    import javax.sql.DataSource;
    import org.apache.struts.action.*;
     
     
     
    public class ConnectionDB extends Action{
     
    	@SuppressWarnings("unchecked")
    	public ActionForward execute(ActionMapping mapping, ActionForm form,
    			HttpServletRequest request, HttpServletResponse response)
    			throws IOException, ServletException {
     
    			// lit le contenu de la table articles d'une connexion
    			// réalisée à l'init du contexte
    			// on récupère a source de données dbarticles
    			DataSource dataSource = this.getDataSource(request, "nomBDD");
    			if (dataSource == null) {
    				// la source de données n'a pas pu être créée
    				ActionErrors erreurs = new ActionErrors();
    				erreurs.add("dbarticles", new ActionMessage("erreur.dbarticles",
    				"La source de données n'a pu être créée"));
    				this.saveErrors(request, erreurs);
    				return mapping.findForward("afficherErreurs");
    			}
    			// ici la source de données existe - on l'exploite
    			Connection connexion = null;
    			Statement st = null;
    			ResultSet rs = null;
    			String requête = null;
    			ArrayList alArticles = new ArrayList();
    			// on gère les erreurs
    			try {
    				// obtenir une connexion
    				connexion = dataSource.getConnection();
    				// préparer la requête SQL
    				requête = "select code, nom, prix, stockActuel, stockMinimum from articles order by nom";
    				// l'exécuter
    				st = connexion.createStatement();
    				rs = st.executeQuery(requête);
    				// exploiter les résultats
    				while (rs.next()) {
    					// enregistrer la ligne courante
    					alArticles.add(new String[] { rs.getString("code"),
    					rs.getString("nom"), rs.getString("prix"),
    					rs.getString("stockactuel"), rs.getString("stockMinimum") });
    					// ligne suivante
    				} //while
    				// libérer les ressources
    				rs.close();
    				st.close();
    			} catch (Exception ex) {
    				// des erreurs se sont produites
    				ActionErrors erreurs = new ActionErrors();
    				erreurs.add("dbarticles", new ActionMessage("erreur.dbarticles"));
    				this.saveErrors(request, erreurs);
    				return mapping.findForward("afficherErreurs");
    			} finally {
    				// on libère la connexion
    				try {
    					connexion.close();
    				} catch (Exception ignored) {
    				}
    			}
    			// c'est bon
    			request.setAttribute("listArticles", alArticles);
    			return mapping.findForward("afficherListeArticles");
    	} //fin fonction execute	
    }

    Merci d'avance

  2. #2
    Membre à l'essai
    Inscrit en
    Janvier 2007
    Messages
    33
    Détails du profil
    Informations forums :
    Inscription : Janvier 2007
    Messages : 33
    Points : 24
    Points
    24
    Par défaut
    Quelqu'un connaitrait une facon de procéder pour changer le getDataSource qui m'est source de problème?

    Merci

  3. #3
    Membre à l'essai
    Inscrit en
    Janvier 2007
    Messages
    33
    Détails du profil
    Informations forums :
    Inscription : Janvier 2007
    Messages : 33
    Points : 24
    Points
    24
    Par défaut
    J'ai essayé de rusé en modifiant le getDataSource() par le code suivant :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
     
    try {
    	//récupération de la source de donnée
    	Context initCtx = new InitialContext();
    	dataSource = (DataSource) initCtx.lookup("jdbc/mabd");
    } catch (Exception e) {
    	throw new UnavailableException(e.getMessage());
    }
    Cependant j'avoue que je ne comprend pas trop l'histoire du context et ne sait pas trop quoi mettre en parametre du lookup()

    Voici le message du navigateur :
    javax.servlet.ServletException: Le Nom jdbc n'est pas lié à ce Contexte

    Voici la declaration de mon data-source dans le struts-config.xml

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
     
    <data-sources>
    		<data-source key="mabd" type="org.apache.commons.dbcp.BasicDataSource">
    			<set-property property="description" value="Configuration de connection pour MySQL" />
    			<set-property property="driverClassName" value="com.mysql.jdbc.Driver" />
    			<set-property property="url" value="jdbc:mysql://localhost/mabd" />
    			<set-property property="username" value="root" />
    			<set-property property="password" value="" />
    			<set-property property="maxActive" value="10" />
    			<set-property property="maxWait" value="5000" />
    			<set-property property="defaultAutoCommit" value="false" />
    			<set-property property="defaultReadOnly" value="false" />
    		</data-source>
    </data-sources>

    J'avoue que depuis hier je n'obtient pas de solution concluante et je ne vois pas comment débloquer la situation. Si quelqu'un peut m'aider car je suis bloqué ...

  4. #4
    Expert éminent

    Femme Profil pro
    Inscrit en
    Juillet 2005
    Messages
    5 793
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Localisation : France

    Informations forums :
    Inscription : Juillet 2005
    Messages : 5 793
    Points : 7 778
    Points
    7 778
    Par défaut
    Je ne suis pas spécialiste mais tu dois pouvoir faire une connexion classique sans passer par datasource :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    Class.forName("com.mysql.jdbc.Driver");
    Connection connection = DriverManager.getConnection("jdbc:mysql:///mabd","root","");

  5. #5
    Membre du Club
    Profil pro
    Inscrit en
    Avril 2007
    Messages
    36
    Détails du profil
    Informations personnelles :
    Âge : 40
    Localisation : France, Finistère (Bretagne)

    Informations forums :
    Inscription : Avril 2007
    Messages : 36
    Points : 43
    Points
    43
    Par défaut
    Va faire un tour sur ce post...

  6. #6
    Membre à l'essai
    Inscrit en
    Janvier 2007
    Messages
    33
    Détails du profil
    Informations forums :
    Inscription : Janvier 2007
    Messages : 33
    Points : 24
    Points
    24
    Par défaut
    Merci sebarbraz je vois que tu as eut le même problème.
    J'ai bein vu que la methode getDataSource et déprécié depuis la nouvelle version de struts. Je suis passé par une connection à la base de données traditionnel pour le moment. Cependant la gestion du pool de connection via struts me semblait assez classe (bien que tu peut le faire direct par tomcat de ce que j'ai vu). As tu trouvé une solution pour struts ou pas?
    Merci.

+ Répondre à la discussion
Cette discussion est résolue.

Discussions similaires

  1. Problème d'installation oracle 8.1.7 sous NT
    Par Anonymous dans le forum Installation
    Réponses: 7
    Dernier message: 02/08/2002, 14h18
  2. Problème d'impression
    Par IngBen dans le forum C++Builder
    Réponses: 7
    Dernier message: 22/05/2002, 11h37
  3. Problème avec la mémoire virtuelle
    Par Anonymous dans le forum CORBA
    Réponses: 13
    Dernier message: 16/04/2002, 16h10
  4. Réponses: 6
    Dernier message: 25/03/2002, 21h11

Partager

Partager
  • Envoyer la discussion sur Viadeo
  • Envoyer la discussion sur Twitter
  • Envoyer la discussion sur Google
  • Envoyer la discussion sur Facebook
  • Envoyer la discussion sur Digg
  • Envoyer la discussion sur Delicious
  • Envoyer la discussion sur MySpace
  • Envoyer la discussion sur Yahoo