Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Recensione vivo X300 Pro: è ancora lui il re della fotografia mobile, peccato per la batteria
Recensione vivo X300 Pro: è ancora lui il re della fotografia mobile, peccato per la batteria
vivo X300 Pro rappresenta un'evoluzione misurata della serie fotografica del produttore cinese, con un sistema di fotocamere migliorato, chipset Dimensity 9500 di ultima generazione e l'arrivo dell'interfaccia OriginOS 6 anche sui modelli internazionali. La scelta di limitare la batteria a 5.440mAh nel mercato europeo, rispetto ai 6.510mAh disponibili altrove, fa storcere un po' il naso
Lenovo Legion Go 2: Ryzen Z2 Extreme e OLED 8,8'' per spingere gli handheld gaming PC al massimo
Lenovo Legion Go 2: Ryzen Z2 Extreme e OLED 8,8'' per spingere gli handheld gaming PC al massimo
Lenovo Legion Go 2 è la nuova handheld PC gaming con processore AMD Ryzen Z2 Extreme (8 core Zen 5/5c, GPU RDNA 3.5 16 CU) e schermo OLED 8,8" 1920x1200 144Hz. È dotata anche di controller rimovibili TrueStrike con joystick Hall effect e una batteria da 74Wh. Rispetto al dispositivo che l'ha preceduta, migliora ergonomia e prestazioni a basse risoluzioni, ma pesa 920g e costa 1.299€ nella configurazione con 32GB RAM/1TB SSD e Z2 Extreme
AWS re:Invent 2025: inizia l'era dell'AI-as-a-Service con al centro gli agenti
AWS re:Invent 2025: inizia l'era dell'AI-as-a-Service con al centro gli agenti
A re:Invent 2025, AWS mostra un’evoluzione profonda della propria strategia: l’IA diventa una piattaforma di servizi sempre più pronta all’uso, con agenti e modelli preconfigurati che accelerano lo sviluppo, mentre il cloud resta la base imprescindibile per governare dati, complessità e lock-in in uno scenario sempre più orientato all’hybrid cloud
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 07-01-2010, 01:58   #1
postgres
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!
postgres è offline   Rispondi citando il messaggio o parte di esso
Old 07-01-2010, 11:37   #2
Ken1986
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");
Ken1986 è offline   Rispondi citando il messaggio o parte di esso
Old 07-01-2010, 20:39   #3
postgres
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";
mentre in Database io avevo messo questo:
Codice:
 db = DriverManager.getConnection("jdbc:mysql://localhost/" + nomeDB + "?user=" + nomeUtente + "&password=" + pwdUtente);
che ho sostituito come mi hai detto tu:
Codice:
db = DriverManager.getConnection("jdbc:mysql://localhost/nome_db","nome_utente","password");
ma quando mi da l'errore di access denied mi dice che "nomeut" (in Prova) è l'utente e non "nome_utente" (in Database)!!!

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?
postgres è offline   Rispondi citando il messaggio o parte di esso
Old 08-01-2010, 12:03   #4
ally
Bannato
 
L'Avatar di ally
 
Iscritto dal: Jan 2003
Città:
Messaggi: 4421
Quote:
Originariamente inviato da postgres Guarda i messaggi
Codice:
Database db = new Database("nome");
...questo costruttore passa nome utente e password alla classe database?...

...ciao Andrea...
ally è offline   Rispondi citando il messaggio o parte di esso
Old 08-01-2010, 12:43   #5
postgres
Member
 
Iscritto dal: Apr 2008
Messaggi: 120
si
postgres è offline   Rispondi citando il messaggio o parte di esso
Old 08-01-2010, 12:45   #6
ally
Bannato
 
L'Avatar di ally
 
Iscritto dal: Jan 2003
Città:
Messaggi: 4421
Quote:
Originariamente inviato da postgres Guarda i messaggi
si
...si ma vuoti pero'...

...ciao Andrea...
ally è offline   Rispondi citando il messaggio o parte di esso
Old 08-01-2010, 12:51   #7
postgres
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);
postgres è offline   Rispondi citando il messaggio o parte di esso
Old 08-01-2010, 18:07   #8
postgres
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!
postgres è offline   Rispondi citando il messaggio o parte di esso
Old 08-01-2010, 18:12   #9
postgres
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
postgres è offline   Rispondi citando il messaggio o parte di esso
Old 09-01-2010, 16:28   #10
Allure
Senior Member
 
L'Avatar di Allure
 
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 16:45.
Allure è offline   Rispondi citando il messaggio o parte di esso
Old 09-01-2010, 17:46   #11
postgres
Member
 
Iscritto dal: Apr 2008
Messaggi: 120
nel file Prova esatatmente qui:

String nomeDB = "nome";
String nomeUtente = "nomeut";
String pwd= "lamiapw";
postgres è offline   Rispondi citando il messaggio o parte di esso
Old 09-01-2010, 17:50   #12
Allure
Senior Member
 
L'Avatar di Allure
 
Iscritto dal: Nov 2002
Città: Roma
Messaggi: 1242
Quote:
Originariamente inviato da postgres Guarda i messaggi
nel file Prova esatatmente qui:

String nomeDB = "nome";
String nomeUtente = "nomeut";
String pwd= "lamiapw";
Spero che hai cambiato le stringhe con i tuoi dati... giusto?
__________________
Concertina: "I know the truth is in between the 1st and 40th drink"
Allure è offline   Rispondi citando il messaggio o parte di esso
Old 09-01-2010, 17:52   #13
postgres
Member
 
Iscritto dal: Apr 2008
Messaggi: 120
eh be certo!
postgres è offline   Rispondi citando il messaggio o parte di esso
Old 09-01-2010, 23:31   #14
Allure
Senior Member
 
L'Avatar di Allure
 
Iscritto dal: Nov 2002
Città: Roma
Messaggi: 1242
Quote:
Originariamente inviato da postgres Guarda i messaggi
eh be certo!
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"
Allure è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


Recensione vivo X300 Pro: è ancora lui il re della fotografia mobile, peccato per la batteria Recensione vivo X300 Pro: è ancora lui il...
Lenovo Legion Go 2: Ryzen Z2 Extreme e OLED 8,8'' per spingere gli handheld gaming PC al massimo Lenovo Legion Go 2: Ryzen Z2 Extreme e OLED 8,8'...
AWS re:Invent 2025: inizia l'era dell'AI-as-a-Service con al centro gli agenti AWS re:Invent 2025: inizia l'era dell'AI-as-a-Se...
Cos'è la bolla dell'IA e perché se ne parla Cos'è la bolla dell'IA e perché se...
BOOX Palma 2 Pro in prova: l'e-reader diventa a colori, e davvero tascabile BOOX Palma 2 Pro in prova: l'e-reader diventa a ...
Moore Threads: nuove GPU 15 volte pi&ugr...
Steam diventa esclusivamente 64-bit: Val...
La Corte Suprema restituisce a Elon Musk...
X lancia Creator Studio su mobile: nuovi...
Dieci anni fa SpaceX fece atterrare per ...
POCO M8 e M8 Pro arriveranno nel 2026: e...
Caos Formula 1: il motore Mercedes &egra...
Tariffe nazionali per le chiamate e gli ...
Tassa chilometrica non solo per elettric...
FSR 4 su Radeon RX 5000, 6000 e 7000? Li...
Quanti alberi ci sono in Skyrim? In The ...
Pocket Max, la nuova console Mangmi punt...
Pubblicato maxi backup di Spotify: 300 T...
GTA 6 potrebbe evolversi in un MMORPG, s...
Green Deal anche per i caldarrostai: a R...
Chromium
GPU-Z
OCCT
LibreOffice Portable
Opera One Portable
Opera One 106
CCleaner Portable
CCleaner Standard
Cpu-Z
Driver NVIDIA GeForce 546.65 WHQL
SmartFTP
Trillian
Google Chrome Portable
Google Chrome 120
VirtualBox
Tutti gli articoli Tutte le news Tutti i download

Strumenti

Regole
Non Puoi aprire nuove discussioni
Non Puoi rispondere ai messaggi
Non Puoi allegare file
Non Puoi modificare i tuoi messaggi

Il codice vB è On
Le Faccine sono On
Il codice [IMG] è On
Il codice HTML è Off
Vai al Forum


Tutti gli orari sono GMT +1. Ora sono le: 15:51.


Powered by vBulletin® Version 3.6.4
Copyright ©2000 - 2025, Jelsoft Enterprises Ltd.
Served by www3v