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

Servlets/JSP Java Discussion :

Base de données


Sujet :

Servlets/JSP Java

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre averti
    Inscrit en
    Avril 2005
    Messages
    20
    Détails du profil
    Informations forums :
    Inscription : Avril 2005
    Messages : 20
    Par défaut Base de données
    Bonjour,

    Je suis débutante en J2EE (1 semaine), et je cherche comment faire la connexion avec ma base de données mysql. J'utilise tomcat, mysql et comme logiciel de développement: eclipse.
    J'ai regardé pas mal de tuto, j'ai essayé de les suivre mais ma connexion ne marche pas et je ne comprend pas, j'ai toujours un message d'erreur: Accès refusé pour l'utilisateur: 'root'@'@localhost' (mot de passe: OUI).
    Pourtant ce sont bien les bons identifiants (par défaut de mysql, login:root et password:"").
    Voici mon 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
     
    import java.io.*;
    import javax.servlet.*;
    import javax.servlet.http.*;
    import java.sql.*;
    import java.util.*;
     
    public class gener3 extends HttpServlet{
    //declaration de mes variables
    ......
    //methode Get
    .....
    //methode Post qui renvoie a la methode get
    .....
    //initialisation de la servlet
    public void init(){
    Connection connexion=null;
    Statement st=null;
    ResultSet rs=null;
    try{
     //connexion à la base mysql
     Class.forName("org.gjt.mm.mysql.Driver");
     connexion=DriverManager.getConnection("jdbc:mysql://localhost/dbValeurs?user=root&password=''");
     //objet statement
     st=connexion.createStatement();
     //execution requete select pour recuperer valeurs
     rs=st.executeQuery("select valeur from Tvaleurs");
     //les valeurs sont récupérées et mises dans un tableau dynamique
     ArrayList lstValeurs=new ArrayList();
     while(rs.next()){
      //on enregistre la valeur dans la liste
      lstValeurs.add(rs.getString("valeur"));
     }//while
     //transformation liste -->tableau
     valeurs=new String[lstValeurs.size()];
     for(int i=0;i<lstValeurs.size();i++){
      valeurs[i]=(String)lstValeurs.get(i);
     }
    }catch(Exception ex){
     //probleme
     msgErreur=ex.getMessage();
    }finally{
     try{rs.close();}catch(Exception ex){}
     try{st.close();}catch(Exception ex){}
     try{connexion.close();}catch(Exception ex){}
    }//try
    }//init
    }//fin classe
    dbValeurs est le nom de ma base de données. Si quelqu'un de plus doué que moi dans ce langage peut m'aider à comprendre mon erreur.....
    Merci par avance.

  2. #2
    Membre averti
    Inscrit en
    Janvier 2006
    Messages
    49
    Détails du profil
    Informations forums :
    Inscription : Janvier 2006
    Messages : 49
    Par défaut
    J'ai pas le même driver que toi (j'ai Class.forName("com.mysql.jdbc.Driver"); ) et j'écrirais :
    connexion=DriverManager.getConnection("jdbc:mysql://localhost/dbValeurs, "root","tonPassword");
    plutôt que :
    connexion=DriverManager.getConnection("jdbc:mysql://localhost/dbValeurs?user=root&password=''");

    après, je sais pas si cela peut venir de là... sinon, met le message d'erreur généré.

    Est-ce que tu as essayé d'accéder à ta base de données autrement qu'avec eclipse ?

    A +
    Arnapou

  3. #3
    Membre averti
    Inscrit en
    Avril 2005
    Messages
    20
    Détails du profil
    Informations forums :
    Inscription : Avril 2005
    Messages : 20
    Par défaut
    Tout d'abord merci pour ta reponse.

    Je n'y comprend plus rien, j'avais déja essayé la méthode que tu m'as cité
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    DriverManager.getConnection("jdbc:mysql://localhost/dbValeurs","root","");
    et ça ne marchais pas. Mais suite à ton message j'ai rééssayé et là ça marche..... les joies de l'informatique!

    Encore merci!!!!!!!!

  4. #4
    Membre averti
    Profil pro
    Inscrit en
    Avril 2005
    Messages
    20
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Avril 2005
    Messages : 20
    Par défaut connection avec le serveur mysql
    Bonjour,
    j'utilise eclipse comme IDE et tomcat comme server d'application.
    J'ai la stdout suivant sur la console:

    ** BEGIN NESTED EXCEPTION **

    java.net.SocketException
    MESSAGE: java.security.AccessControlException: access denied (java.net.SocketPermission 192.168.2.2:3306 connect,resolve)

    STACKTRACE:

    java.net.SocketException: java.security.AccessControlException: access denied (java.net.SocketPermission 192.168.2.2:3306 connect,resolve)
    at com.mysql.jdbc.StandardSocketFactory.connect(StandardSocketFactory.java:156)
    at com.mysql.jdbc.MysqlIO.<init>(MysqlIO.java:284)
    at com.mysql.jdbc.Connection.createNewIO(Connection.java:2565)
    at com.mysql.jdbc.Connection.<init>(Connection.java:1485)
    at com.mysql.jdbc.NonRegisteringDriver.connect(NonRegisteringDriver.java:266)
    at java.sql.DriverManager.getConnection(Unknown Source)
    at java.sql.DriverManager.getConnection(Unknown Source)
    at section.authentification.CheckUser.init(CheckUser.java:25)
    at section.identification.login.LoginService.doPost(LoginService.java:71)
    at javax.servlet.http.HttpServlet.service(HttpServlet.java:709)
    at javax.servlet.http.HttpServlet.service(HttpServlet.java:802)
    at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
    at sun.reflect.NativeMethodAccessorImpl.invoke(Unknown Source)
    at sun.reflect.DelegatingMethodAccessorImpl.invoke(Unknown Source)
    at java.lang.reflect.Method.invoke(Unknown Source)
    at org.apache.catalina.security.SecurityUtil$1.run(SecurityUtil.java:243)
    at java.security.AccessController.doPrivileged(Native Method)
    at javax.security.auth.Subject.doAsPrivileged(Unknown Source)
    at org.apache.catalina.security.SecurityUtil.execute(SecurityUtil.java:275)
    at org.apache.catalina.security.SecurityUtil.doAsPrivilege(SecurityUtil.java:161)
    at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:245)
    at org.apache.catalina.core.ApplicationFilterChain.access$000(ApplicationFilterChain.java:50)
    at org.apache.catalina.core.ApplicationFilterChain$1.run(ApplicationFilterChain.java:156)
    at java.security.AccessController.doPrivileged(Native Method)
    at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:152)
    at org.apache.catalina.core.StandardWrapperValve.invoke(StandardWrapperValve.java:213)
    at org.apache.catalina.core.StandardContextValve.invoke(StandardContextValve.java:178)
    at org.apache.catalina.core.StandardHostValve.invoke(StandardHostValve.java:126)
    at org.apache.catalina.valves.ErrorReportValve.invoke(ErrorReportValve.java:105)
    at org.apache.catalina.core.StandardEngineValve.invoke(StandardEngineValve.java:107)
    at org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:148)
    at org.apache.coyote.http11.Http11Processor.process(Http11Processor.java:869)
    at org.apache.coyote.http11.Http11BaseProtocol$Http11ConnectionHandler.processConnection(Http11BaseProtocol.java:667)
    at org.apache.tomcat.util.net.PoolTcpEndpoint.processSocket(PoolTcpEndpoint.java:527)
    at org.apache.tomcat.util.net.LeaderFollowerWorkerThread.runIt(LeaderFollowerWorkerThread.java:80)
    at org.apache.tomcat.util.threads.ThreadPool$ControlRunnable.run(ThreadPool.java:684)
    at java.lang.Thread.run(Unknown Source)


    ** END NESTED EXCEPTION **



    Last packet sent to the server was 0 ms ago.

    J'ai essaye une connection avec le client mysql sous dos (ligne de commande) ca marche.
    et j'ai le code suivant:

    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
     
    import java.lang.Class.*;
    import java.net.URL;
    import java.sql.*;
    import java.io.*;
    import com.mysql.jdbc.Driver;
     
    import java.sql.Connection;
    import java.sql.DriverManager;
    import java.sql.SQLException;
     
     
    public class CheckUser {
     
    	private String login = null;
    	private String password = null;
     
    	public void init(){
    		//System.out.println("hello");
    		java.sql.Connection conn = null;
    		int i;
    		try{
    			Class.forName("com.mysql.jdbc.Driver").newInstance();
    			conn = java.sql.DriverManager.getConnection(
    				"jdbc:mysql://192.168.2.2:3306/xeni","root","root");
    			Statement stm = conn.createStatement();
    			ResultSet rs ;
    			rs = stm.executeQuery("show tables;");
    			for(i=0; i<rs.getConcurrency(); i++){
    				System.out.print(rs.toString());
    			}
     
    		} catch(Exception e){
    			System.out.println("Connection ratée: "+e);
    		}
     
    	}
     
    	public boolean checkAuthentification(String str_login , String str_password){
     
    		return true;
    	}
    }

  5. #5
    Membre averti
    Profil pro
    Inscrit en
    Avril 2005
    Messages
    20
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Avril 2005
    Messages : 20
    Par défaut Security Manager
    Bonjour,
    j'ai resolu le soucis en desactivant la security. Je m'en occuperais plus tard. J'ai desactive "security Manager".

    Cordialement.
    Karim

  6. #6
    Membre confirmé
    Inscrit en
    Juin 2007
    Messages
    151
    Détails du profil
    Informations forums :
    Inscription : Juin 2007
    Messages : 151
    Par défaut desactiver security manager
    Citation Envoyé par khamed Voir le message
    Bonjour,
    j'ai resolu le soucis en desactivant la security. Je m'en occuperais plus tard. J'ai desactive "security Manager".

    Cordialement.
    Karim
    J'ai le meme probleme.

    J'arrive pas à me connecter à ma base de données mysql à cause de la meme erreur.

    comment désactiver security manager??

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

Discussions similaires

  1. Problème Base de données et CRecordSet
    Par LE CHAKAL dans le forum MFC
    Réponses: 3
    Dernier message: 20/08/2002, 11h59
  2. connexion base de donné
    Par saidi dans le forum MFC
    Réponses: 3
    Dernier message: 07/08/2002, 22h22
  3. [Concept] Stabilité d'une base de donnée
    Par lassmust dans le forum Décisions SGBD
    Réponses: 3
    Dernier message: 03/07/2002, 16h16
  4. Bases de données
    Par dev dans le forum C++Builder
    Réponses: 4
    Dernier message: 01/07/2002, 22h55
  5. associer une base de données(access) a un dbgrid
    Par ange1708 dans le forum MFC
    Réponses: 3
    Dernier message: 11/06/2002, 12h18

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