Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Sony WF-1000X M6: le cuffie in-ear di riferimento migliorano ancora
Sony WF-1000X M6: le cuffie in-ear di riferimento migliorano ancora
WF-1000X M6 è la sesta generazione di auricolare in-ear sviluppata da Sony, un prodotto che punta a coniugare facilità di utilizzo con una elevata qualità di riproduzione dei contenuti audio e una cura nella riduzione del rumore ambientale che sia da riferimento
Snowflake porta l'IA dove sono i dati, anche grazie a un accordo con OpenAI
Snowflake porta l'IA dove sono i dati, anche grazie a un accordo con OpenAI
Snowflake ha presentato diverse novità per la sua piattaforma legate all'intelligenza artificiale. Quella forse più eclatante è una collaborazione con OpenAI, ma non mancano diverse nuove funzionalità che rendono la piattaforma più flessibile e in grado di rispondere meglio alle esigenze in continuo cambiamento delle aziende
Sistema Mesh Roamii BE Pro: il Wi-Fi 7 secondo MSI
Sistema Mesh Roamii BE Pro: il Wi-Fi 7 secondo MSI
Con velocità teoriche fino a 11 Gbps, gestione tramite app intelligente e protezione avanzata dei dispositivi, Roamii BE Pro porta il Wi‑Fi 7 tri‑band nelle abitazioni più esigenti. Un sistema Wi-Fi Mesh proposto da MSI allo scopo di garantire agli utenti una rete fluida e continua capace di sostenere streaming 8K, gaming competitivo e le applicazioni moderne più esigenti in termini di banda
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 15-12-2004, 23:13   #1
foxmolder5
Senior Member
 
Iscritto dal: Dec 2001
Messaggi: 2514
servlet : non funziona bene.

vi è una pagina web in cui sono presenti solo dei campi in cui inserire: user,password,nome,cognome,anni,(con relativo bottone per l'invio dei dati) ed inoltre vi è un servlet che gestisce la pagina e memorizza i dati in un db (gestito tramite mysql).se inserisco user+password mi viene detto nome cognome e anni.ed invece se inserisco tutti i campi vengo registrato. la gestione lato server viene fatta con tomcat (configurato e funzionannte).
la pagina web viene vista in locale e se inserisco user+password e sono presente nel db mi viene detto senza prob il nome,cognome e anni, ma se inserisco tutti i campi l'operazione va a buon fine (non viene dato nessun errore) ma i dati non vengono inseriti nel db.
sapete dirmi come mai?
la servlet non è fatta da me e quindi vorrei chiedervi cosa significa :

String action = (request.getParameter("a") != null) ?
request.getParameter("a") : "";

come mai quell' "a" passato nella funzione getParameter?che significa?
di seguito è presente la servlet. grazie


Codice:
package authentication;
import java.io.*;

import javax.servlet.ServletException;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import javax.servlet.ServletConfig;
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.Statement;
import java.sql.ResultSet;
import java.sql.*;

public class AuthenticationServlet extends HttpServlet {
  Connection con = null;
  public void init(ServletConfig config) throws ServletException {
    super.init(config);
    try {
      Class.forName("com.mysql.jdbc.Driver").newInstance();

        con = DriverManager.getConnection("jdbc:mysql://localhost:3306/prova_lab","root","giampiero");
	
    }
    catch (SQLException ex) {
      throw new ServletException(ex.getMessage());
    }
    catch (ClassNotFoundException ex) {
      throw new ServletException(ex.getMessage());
    }
    catch (IllegalAccessException ex) {
      throw new ServletException(ex.getMessage());
    }
    catch (InstantiationException ex) {
      throw new ServletException(ex.getMessage());
    }

  }

  public void service(HttpServletRequest request, HttpServletResponse response) throws
      ServletException, IOException {

    String user = request.getParameter("user");
    String pass = request.getParameter("password");
    String action = (request.getParameter("a") != null) ?
        request.getParameter("a") : "";
    PrintWriter out = response.getWriter();

    try {

      if (!action.equals("r")) {

        if (user == null || user.trim().equals("")) {
          throw new Exception(this.getLogHeader() +
                              "errore nome utente non specificato.");

        }
        if (pass == null || pass.trim().equals("")) {
          throw new Exception(this.getLogHeader() +
                              "errore password non specificata.");
        }

        Statement registra = con.createStatement();

        ResultSet res = registra.executeQuery(
            "Select * from utente where user='" + user + "' and password='" +
            pass + "'");

        res.beforeFirst();
        if (res.next()) {
          String nome = res.getString("nome");
          String cognome = res.getString("cognome");
          int anni = res.getInt("anni");
          out.println("<HTML>" +
                      "<body>" +
                      "<center>" +
                      "<table border=\"1\" bgcolor=\"red\"><tr><td>" +
                      "<table border=\"1\" bgcolor=\"white\" align=\"left\">" +
                      "<tr><td>nome</td><td> <input type=\"text\" name=\"nome\" value = \"" +
                      nome + "\"><br></td></tr>" +
                      "<tr><td>cognome</td><td> <input type=\"text\" name=\"cognome\" value = \"" +
                      cognome + "\"><br></td></tr>" +
                      "<tr><td>età</td><td> <input type=\"text\" name=\"anni\" value = \"" +
                      anni + "\"><br></td></tr>" +
                      "<tr><td colspan=\"2\" align=\"center\"></td></tr>" +
                      "</center> " +
                      "</FORM>" +
                      "</Table>" +
                      "</body> " +
                      "</HTML>"
                      );
          res.close();
          registra.close();


        }
        else {
          res.close();
          registra.close();
          response.sendRedirect("Registrazione.html");
        }

      }

      else {
        String nome = request.getParameter("nome");
        String cognome = request.getParameter("cognome");
        int anni = Integer.parseInt(request.getParameter("anni"));

        Statement registra = con.createStatement();
        try {
          registra.execute("Insert into utente values('" + user + "', '" + pass +
                           "', '" + nome + "', '" + cognome + "' ," + anni +
                           ")");
        }
        catch (Exception e) {
          response.sendRedirect("RegistrazioneErrore.html");
        }
        finally {
          registra.close();
        }

      }
    }
    catch (Exception e) {
      System.out.println(e.getMessage());
      out.println("c'è stato un problema");
      //response.sendRedirect("inserisci qui la pagina di errore");
    }
  }

  public void destroy() {
    super.destroy();
    try {
      con.close();
    }
    catch (SQLException ex) {
    }
  }

  private String getLogHeader() {
    return "AuthenticationServlet ";
  }
}
foxmolder5 è offline   Rispondi citando il messaggio o parte di esso
Old 16-12-2004, 09:47   #2
kingv
Senior Member
 
L'Avatar di kingv
 
Iscritto dal: Jan 2001
Città: Milano
Messaggi: 5707
quell'istruzione, se nella richiesta HTTP e' presente nella query string oppure nei dati postati da una form il campo "a" , valorizza la stringa "action" con il valore associato, altrimenti, nel caso non sia presente , con una stringa vuota.


cosa succede quando non funziona? vieni rimandato a RegistrazioneErrore.html?


aggiungi un printStackTrace() nel catch dell'eccezione.
kingv è offline   Rispondi citando il messaggio o parte di esso
Old 16-12-2004, 09:56   #3
foxmolder5
Senior Member
 
Iscritto dal: Dec 2001
Messaggi: 2514
il problema e che non mi da nessuna eccezione ma quando inserisco dati per una nuova registrazioni questi non mi vengono messi nel db.e non capisco perchè.
foxmolder5 è offline   Rispondi citando il messaggio o parte di esso
Old 16-12-2004, 10:51   #4
kingv
Senior Member
 
L'Avatar di kingv
 
Iscritto dal: Jan 2001
Città: Milano
Messaggi: 5707
Quote:
Originariamente inviato da foxmolder5
il problema e che non mi da nessuna eccezione ma quando inserisco dati per una nuova registrazioni questi non mi vengono messi nel db.e non capisco perchè.

il codice sembra corretto ma aggiungi qualche trace, non e' possibile che esegua quelle istruzioni e non inserisca su db
non e' che stai cercando di inserire lo stesso utente piu' volte e sul db e' definita una chiave univoca?
kingv è offline   Rispondi citando il messaggio o parte di esso
Old 16-12-2004, 10:55   #5
foxmolder5
Senior Member
 
Iscritto dal: Dec 2001
Messaggi: 2514
la chiave primaria c'è su user e password. quando provo ad inserire un "doppione" mi viene dato errore,giustamente. se invece cerco di inserire una nuova registrazione mi viene data di nuovo la pagina per l'inserimento (come se avesse fatto correttamente l'inserimento) ma poi vado a controllare il db e non viene inserito nulla.
dove devo inserire i trace?
foxmolder5 è offline   Rispondi citando il messaggio o parte di esso
Old 16-12-2004, 11:22   #6
foxmolder5
Senior Member
 
Iscritto dal: Dec 2001
Messaggi: 2514
ho inserito printStackTrace nel penultimo catch e su quello precedente, contando dalla fine fine del file, ma come pensavo non mi ha dato nulla.non riesco a capire perchè.
foxmolder5 è offline   Rispondi citando il messaggio o parte di esso
Old 16-12-2004, 12:36   #7
kingv
Senior Member
 
L'Avatar di kingv
 
Iscritto dal: Jan 2001
Città: Milano
Messaggi: 5707
Quote:
Originariamente inviato da foxmolder5
la chiave primaria c'è su user e password. quando provo ad inserire un "doppione" mi viene dato errore,giustamente. se invece cerco di inserire una nuova registrazione mi viene data di nuovo la pagina per l'inserimento (come se avesse fatto correttamente l'inserimento) ma poi vado a controllare il db e non viene inserito nulla.
dove devo inserire i trace?


mi dici che su db non viene inserito nulla ma se inserisci un doppione ti restituisce un errore, c'e' un controsenso!
se non inserisce nulla non puo' darti errore dopo, che metodo usi per dire non inserisce nulla?
kingv è offline   Rispondi citando il messaggio o parte di esso
Old 16-12-2004, 12:45   #8
foxmolder5
Senior Member
 
Iscritto dal: Dec 2001
Messaggi: 2514
tramite il form web inserisco user,password,nome,cognome,età (e l'operazione sembra andare a buon fine poichè non mi da nessun errore e vengo automaticamente riportato alla pagine x il nuovo inserimento). accedo tramite mysql al db e vedo che la tabella è vuota.
inserisco nella tabella la stessa registrazione, riapro il form, provo ad inserire di nuovo i dati e quando procedo mi viene detto che vi è un errore (errore mysql perchè il dato è già presente).
a parte questo particolare servlet, sto cercando di fare una pagina web con servlet.ti volevo chiedere se ci si poteva sentire in pvt o tramite email che forse si fa prima.
se ti va di farmi questo favore te ne sarei grato.
grazie ancora
foxmolder5 è offline   Rispondi citando il messaggio o parte di esso
Old 16-12-2004, 14:04   #9
kingv
Senior Member
 
L'Avatar di kingv
 
Iscritto dal: Jan 2001
Città: Milano
Messaggi: 5707
Quote:
Originariamente inviato da foxmolder5

se ti va di farmi questo favore te ne sarei grato.
grazie ancora

mail: alessio.p CHIOCCIOLA tiscali PUNTO it
msn: alessio_33_ CHIOCCIOLA hotmail PUNTO com


Ciao
kingv è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


Sony WF-1000X M6: le cuffie in-ear di riferimento migliorano ancora Sony WF-1000X M6: le cuffie in-ear di riferiment...
Snowflake porta l'IA dove sono i dati, anche grazie a un accordo con OpenAI Snowflake porta l'IA dove sono i dati, anche gra...
Sistema Mesh Roamii BE Pro: il Wi-Fi 7 secondo MSI Sistema Mesh Roamii BE Pro: il Wi-Fi 7 secondo M...
Recensione HUAWEI Mate X7: un foldable ottimo, ma restano i soliti problemi Recensione HUAWEI Mate X7: un foldable ottimo, m...
Nioh 3: souls-like punitivo e Action RPG Nioh 3: souls-like punitivo e Action RPG
OpenClaw sotto attacco: i malware infost...
Resident Evil Requiem: pre-load dal 25 f...
Vaticano, la Messa si traduce in 60 ling...
Kia prepara il facelift della Kia EV5: n...
La nuova Alpine A110 elettrica sfrutterà...
Il nuovo entry level della gamma MacBook...
Panasonic 55'' QLED con Dolby Vision e F...
TOP 250 PLUS e TOP 300 PLUS ritornano: v...
Incentivi auto elettriche, si va verso r...
Crimson Desert non è un Soulslike...
Sostituzione caldaia con nuovi sistemi, ...
La Germania verso il divieto e il ban de...
Questo super TV Samsung OLED da 65'' con...
Android Auto 16.3 svela due segreti di G...
Apple Podcasts introduce video con HLS e...
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:42.


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