Visualizzazione dei risultati da 1 a 3 su 3
  1. #1

    JDBC+ MYSQL +SERVLET + TOMCAT = come convivere?

    Salve ragazzi,
    da una decina di giorni ho incominciato ad avvicinarmi a queste tecnologie web, ho creato una 2 classi, una di queste è un interfaccia per mysql, cioè effettua la connessione al database che gira in locale ed esegue varie operazioni e query, l'altra classe è una servlet. Usando jbulder ho creato una classe tester per la classe che si collega al database e non da problemi, ma se utilizzo la servlet (su tomcat) non riesce a collegarsi a mysql e non riesco proprio a capire perchè!!

  2. #2
    Moderatore di Programmazione L'avatar di LeleFT
    Registrato dal
    Jun 2003
    Messaggi
    17,320

    Moderazione

    E come facciamo a sapere noi il perchè?
    Non hai postato nessuna riga di codice, né della Servlet, né della classe che effettua la connessione col DB...
    Non hai indicato se Tomcat gira in locale rispetto al DB oppure no...


    Ciao.
    "Perchè spendere anche solo 5 dollari per un S.O., quando posso averne uno gratis e spendere quei 5 dollari per 5 bottiglie di birra?" [Jon "maddog" Hall]
    Fatti non foste a viver come bruti, ma per seguir virtute e canoscenza

  3. #3
    Si scusa hai ragione... allora la prima classe è questa:

    ************************************************** *********************

    package core;


    import java.sql.*;
    import java.util.Vector;

    public class Database {
    private String nomeDB;
    private String nomeUtente;
    private String pwdUtente;
    private String errore;
    private Connection db;
    private boolean connesso;

    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
    }

    ************************************************** ******************
    La seconda classe è questa:
    ************************************************** **************
    package core;

    import java.io.*;
    import javax.servlet.*;
    import javax.servlet.http.*;
    import java.sql.*;



    public class GestionForm extends javax.servlet.http.HttpServlet implements javax.servlet.Servlet {
    static final long serialVersionUID = 1L;


    public GestionForm() {
    super();
    }


    protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
    PrintWriter out = response.getWriter();

    String user = request.getParameter("user");
    String pass = request.getParameter("pass");

    Database mydata = new Database("mad", "root", "pwprova");
    mydata.connetti();
    if(mydata.isConnesso()){
    out.println("connesso");
    }else out.println("non connesso");






    }


    protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
    // TODO Auto-generated method stub
    }
    }
    ************************************************** ******************

    Il database è mysql 5 e sto usando tomcat 6 e girano entrambi in locale sul mio pc, da qualche parte ho letto che bisogna configurare il server.xml di tomcat e il web.xml, l'ho fatto ma non funziona comunque, non riesco a collegarmi al database tramite tomcat

Permessi di invio

  • Non puoi inserire discussioni
  • Non puoi inserire repliche
  • Non puoi inserire allegati
  • Non puoi modificare i tuoi messaggi
  •  
Powered by vBulletin® Version 4.2.1
Copyright © 2025 vBulletin Solutions, Inc. All rights reserved.