|
|
|
![]() |
|
Strumenti |
![]() |
#1 |
Member
Iscritto dal: Apr 2008
Messaggi: 120
|
[JAVA][MYSQL] access denied for user @'localhost' using password yes
Non riesco a connettermi a una base di dati MySQL programmando in JAVA tramite JDBC.
Mi si presenta questo errore: access denied for user 'nomeutente' @'localhost' using password yes Ho trovato solo questa pagina: http://database.html.it/articoli/leg...-di-accesso/3/ e non mi è stata d'aiuto. Tramite pho uso le stesse password, nome utente, nome db e indirizzo del db e funziona tutto alla perfezione! Il mio codice è quello preso da quessto sito http://forum.html.it/forum/showthrea...hreadid=801696 la classe Database: Codice:
/* * Classe dedicata alla gestione del Database. * Gestisce l'apertura e la chiusura della connessione col Database * Fornisce i metodi per l'esecuzione delle query sul Database */ import java.sql.*; import java.util.Vector; public class Database { private String nomeDB; // Nome del Database a cui connettersi private String nomeUtente; // Nome utente utilizzato per la connessione al Database private String pwdUtente; // Password usata per la connessione al Database private String errore; // Raccoglie informazioni riguardo l'ultima eccezione sollevata private Connection db; // La connessione col Database private boolean connesso; // Flag che indica se la connessione è attiva o meno public Database(String nomeDB) { this(nomeDB, "", ""); } public Database(String nomeDB, String nomeUtente, String pwdUtente) { this.nomeDB = nomeDB; this.nomeUtente = nomeUtente; this.pwdUtente = pwdUtente; connesso = false; errore = ""; } // Apre la connessione con il Database public boolean connetti() { connesso = false; try { // Carico il driver JDBC per la connessione con il database MySQL Class.forName("com.mysql.jdbc.Driver"); // Controllo che il nome del Database non sia nulla if (!nomeDB.equals("")) { // Controllo se il nome utente va usato o meno per la connessione if (nomeUtente.equals("")) { // La connessione non richiede nome utente e password db = DriverManager.getConnection("jdbc:mysql://localhost/" + nomeDB); } else { // La connessione richiede nome utente, controllo se necessita anche della password if (pwdUtente.equals("")) { // La connessione non necessita di password db = DriverManager.getConnection("jdbc:mysql://localhost/" + nomeDB + "?user=" + nomeUtente); } else { // La connessione necessita della password db = DriverManager.getConnection("jdbc:mysql://localhost/" + nomeDB + "?user=" + nomeUtente + "&password=" + pwdUtente); } } // La connessione è avvenuta con successo connesso = true; } else { System.out.println("Manca il nome del database!!"); System.out.println("Scrivere il nome del database da utilizzare all'interno del file \"config.xml\""); System.exit(0); } } catch (Exception e) { errore = e.getMessage(); } return connesso; } // Esegue una query di selezione dati sul Database // query: una stringa che rappresenta un'istruzione SQL di tipo SELECT da eseguire // colonne: il numero di colonne di cui sarà composta la tupla del risultato // ritorna un Vector contenente tutte le tuple del risultato public Vector eseguiQuery(String query) { Vector v = null; String [] record; int colonne = 0; try { Statement stmt = db.createStatement(); // Creo lo Statement per l'esecuzione della query ResultSet rs = stmt.executeQuery(query); // Ottengo il ResultSet dell'esecuzione della query v = new Vector(); ResultSetMetaData rsmd = rs.getMetaData(); colonne = rsmd.getColumnCount(); while(rs.next()) { // Creo il vettore risultato scorrendo tutto il ResultSet record = new String[colonne]; for (int i=0; i<colonne; i++) record[i] = rs.getString(i+1); v.add( (String[]) record.clone() ); } rs.close(); // Chiudo il ResultSet stmt.close(); // Chiudo lo Statement } catch (Exception e) { e.printStackTrace(); errore = e.getMessage(); } return v; } // Esegue una query di aggiornamento sul Database // query: una stringa che rappresenta un'istuzione SQL di tipo UPDATE da eseguire // ritorna TRUE se l'esecuzione è adata a buon fine, FALSE se c'è stata un'eccezione public boolean eseguiAggiornamento(String query) { int numero = 0; boolean risultato = false; try { Statement stmt = db.createStatement(); numero = stmt.executeUpdate(query); risultato = true; stmt.close(); } catch (Exception e) { e.printStackTrace(); errore = e.getMessage(); risultato = false; } return risultato; } // Chiude la connessione con il Database public void disconnetti() { try { db.close(); connesso = false; } catch (Exception e) { e.printStackTrace(); } } public boolean isConnesso() { return connesso; } // Ritorna TRUE se la connessione con il Database è attiva public String getErrore() { return errore; } // Ritorna il messaggio d'errore dell'ultima eccezione sollevata } e la classe Prova con dentro il main Codice:
import prog.io.*; import database.*; import java.sql.*; import java.util.Vector; import java.lang.String; //import remote.database.*; class Prova{ public static void main(String [] args) { /* ConsoleInputManager in = new ConsoleInputManager(); ConsoleOutputManager out = new ConsoleOutputManager(); */ String nomeDB = "nome"; String nomeUtente = "nomeut"; String pwd= "lamiapw"; Database db = new Database("nome"); if ( !db.connetti() ) { System.out.println("Errore durante la connessione."); System.out.println( db.getErrore() ); System.exit(0); } Io mi sono arreso non capisco perchè non debba accedere! |
![]() |
![]() |
![]() |
#2 |
Member
Iscritto dal: Nov 2007
Messaggi: 122
|
Con nome utente e pw usa questa stringa:
conn = DriverManager.getConnection("jdbc:mysql://localhost/nome_db","nome_utente","password"); |
![]() |
![]() |
![]() |
#3 |
Member
Iscritto dal: Apr 2008
Messaggi: 120
|
Ho fatto come hai detto tu e ho modificato quella stringa nel file Database.
Però ho notato che lui non considera per nIENTE le modifiche che faccio li! considera solo quello che c'è in Prova, infatti nonostante che abbia modificato come tu mi hai detto e mettendo però nome utente diverso nel flile Prova lui considera solo ciò che c'è in prova. Esempio: in prova c'è questo: Codice:
String nomeDB = "nome"; String nomeUtente = "nomeut"; String pwd= "lamiapw"; Codice:
db = DriverManager.getConnection("jdbc:mysql://localhost/" + nomeDB + "?user=" + nomeUtente + "&password=" + pwdUtente); Codice:
db = DriverManager.getConnection("jdbc:mysql://localhost/nome_db","nome_utente","password"); Cioè penso che anche se in Prova gli do dei valori se io in Database poi non li considero questi valori che ne metto altri (in questo caso la tua stringa), perchè invece sembra ignorare qualsiasi cambiamento faccio in Database? |
![]() |
![]() |
![]() |
#4 |
Bannato
Iscritto dal: Jan 2003
Città:
Messaggi: 4421
|
|
![]() |
![]() |
![]() |
#5 |
Member
Iscritto dal: Apr 2008
Messaggi: 120
|
si
|
![]() |
![]() |
![]() |
#6 |
Bannato
Iscritto dal: Jan 2003
Città:
Messaggi: 4421
|
|
![]() |
![]() |
![]() |
#7 |
Member
Iscritto dal: Apr 2008
Messaggi: 120
|
no è che ho copiato la versione sbagliata in realtà li c'è
Codice:
database db = new database(nomeDB, nomeUtente, pwd); |
![]() |
![]() |
![]() |
#8 |
Member
Iscritto dal: Apr 2008
Messaggi: 120
|
si, se non avessi incluso i driver mi avrebbe mostrato un altro messaggio di errore ( non mi ricordo quale) e infatti dopo che li ho messi mi ha dato questo mesaggio di errore di access denied!
|
![]() |
![]() |
![]() |
#9 |
Member
Iscritto dal: Apr 2008
Messaggi: 120
|
ora me lo ricordo diceva tipo
che il server non inviava niente al driver, accesso con 0 millisecondi una cosa del genere. poi ho messo i driver e ha iniziato a mostrare access denied ecc |
![]() |
![]() |
![]() |
#10 |
Senior Member
Iscritto dal: Nov 2002
Città: Roma
Messaggi: 1242
|
Ho fatto una veloce prova con qualche piccola modifica e mi ha funzionato senza problemi. Anche la query...
Posso sapere dove è che inserisci nome database, nome utente e password?
__________________
Concertina: "I know the truth is in between the 1st and 40th drink" Ultima modifica di Allure : 09-01-2010 alle 15:45. |
![]() |
![]() |
![]() |
#11 |
Member
Iscritto dal: Apr 2008
Messaggi: 120
|
nel file Prova esatatmente qui:
String nomeDB = "nome"; String nomeUtente = "nomeut"; String pwd= "lamiapw"; |
![]() |
![]() |
![]() |
#12 |
Senior Member
Iscritto dal: Nov 2002
Città: Roma
Messaggi: 1242
|
Spero che hai cambiato le stringhe con i tuoi dati... giusto?
__________________
Concertina: "I know the truth is in between the 1st and 40th drink" |
![]() |
![]() |
![]() |
#13 |
Member
Iscritto dal: Apr 2008
Messaggi: 120
|
eh be certo!
|
![]() |
![]() |
![]() |
#14 |
Senior Member
Iscritto dal: Nov 2002
Città: Roma
Messaggi: 1242
|
Scusa puoi farci un copia incolla dei codici precisi di quando mandi in run?
__________________
Concertina: "I know the truth is in between the 1st and 40th drink" |
![]() |
![]() |
![]() |
Strumenti | |
|
|
Tutti gli orari sono GMT +1. Ora sono le: 17:48.