Torna indietro   Hardware Upgrade Forum > Software > Programmazione

NZXT H9 Flow RGB+, Kraken Elite 420 e F140X: abbiamo provato il tris d'assi di NZXT
NZXT H9 Flow RGB+, Kraken Elite 420 e F140X: abbiamo provato il tris d'assi di NZXT
Nelle ultime settimane abbiamo provato tre delle proposte top di gamma di NZXT nelle categorie case, dissipatori e ventole. Rispettivamente, parliamo dell'H9 Flow RGB+, Kraken Elite 420 e F140X. Si tratta, chiaramente, di prodotti di fascia alta che si rivolgono agli utenti DIY che desiderano il massimo per la propria build. Tuttavia, mentre i primi due dispositivi mantengono questa direzione, le ventole purtroppo hanno mostrato qualche tallone d'Achille di troppo
ASUS ROG Swift OLED PG34WCDN recensione: il primo QD-OLED RGB da 360 Hz
ASUS ROG Swift OLED PG34WCDN recensione: il primo QD-OLED RGB da 360 Hz
ASUS ROG Swift OLED PG34WCDN è il primo monitor gaming con pannello QD-OLED Gen 5 a layout RGB Stripe Pixel e 360 Hz su 34 pollici: lo abbiamo misurato con sonde colorimetriche e NVIDIA LDAT. Ecco tutti i dati
Recensione Nothing Phone (4a) Pro: finalmente in alluminio, ma dal design sempre unico
Recensione Nothing Phone (4a) Pro: finalmente in alluminio, ma dal design sempre unico
Nothing Phone (4a) Pro cambia pelle: l'alluminio unibody sostituisce la trasparenza integrale, portando una solidità inedita. Sotto il cofano troviamo uno Snapdragon 7 Gen 4 che spinge forte, mentre il display è quasi da top dig amma. Con un teleobiettivo 3.5x e la Glyph Matrix evoluta, è la prova di maturità di Carl Pei. C'è qualche compromesso, ma a 499EUR la sostanza hardware e la sua unicità lo rendono un buon "flagship killer" in salsa 2026
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 15-12-2004, 22: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, 08: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, 08: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, 09: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, 09: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, 10: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, 11: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, 11: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, 13: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


NZXT H9 Flow RGB+, Kraken Elite 420 e F140X: abbiamo provato il tris d'assi di NZXT NZXT H9 Flow RGB+, Kraken Elite 420 e F140X: abb...
ASUS ROG Swift OLED PG34WCDN recensione: il primo QD-OLED RGB da 360 Hz ASUS ROG Swift OLED PG34WCDN recensione: il prim...
Recensione Nothing Phone (4a) Pro: finalmente in alluminio, ma dal design sempre unico Recensione Nothing Phone (4a) Pro: finalmente in...
WoW: Midnight, Blizzard mette il primo, storico mattone per l'housing e molto altro WoW: Midnight, Blizzard mette il primo, storico ...
Ecovacs Goat O1200 LiDAR Pro: la prova del robot tagliaerba con tagliabordi integrato Ecovacs Goat O1200 LiDAR Pro: la prova del robot...
Anthropic ha un'AI che trova falle in Wi...
I 10 migliori sconti Amazon del weekend:...
Con un coupon scendono ancora: le super ...
Minimo storico per Samsung Galaxy S26 Ul...
Si è conclusa la missione lunare ...
EK Waterblock si arrende agli aumenti, i...
Geekbench si aggiorna: tutti i test con ...
Per la prima volta un computer quantisti...
Telecamere Reolink 4K su Amazon: Wi-Fi 6...
Anthropic vuole farsi i chip da sola? Co...
Il fondatore di Framework: il personal c...
JBL Live Flex 3 a 129€ su Amazon: ANC ad...
Come un uomo ha costruito un'azienda da ...
Multe fino a 400 euro anche se hai pagat...
Tapo lancia una valanga di offerte su Am...
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: 04:06.


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