gaxy
07-01-2008, 12:34
Ciao a tutti!
Sono abbastanza distrutta da un errore che non riesco a risolvere nel semplice server http che sto sviluppando come progetto per un esame in università.
Il server è costituito da tre classi:
-HttpServer che contiene anche il main, ed è la classe che gestisce tutto il processo;
-Richiesta, la classe che fa il parsing dell'header che riceve dal client e riconosce la richiesta http fatta dal client (devo supportare richieste GET, HEAD e POST);
-Risposta, la classe che crea la risposta opportuna a inviare al client.
Il mio problema è nella classe Richiesta; quando gestisco la POST, infatti, voglio anche salvare il body della richiesta per non meglio specificati "usi futuri"; ho impostato questo codice:
public void servi() {
StringTokenizer s = null;
String temp = null;
String fileName = null;
String metodoDaServire = null;
try {
while(br.ready()) {
String headerLine = null;
try {
headerLine = br.readLine();
} catch (IOException e2) {
System.out.println("Problemi nella lettura dello stream dati in ingresso");
e2.printStackTrace();
}
//stampa a video dell'header ricevuto
System.out.println(headerLine);
//fine header se...
if(headerLine.equals(CRLF) || headerLine.equals("")) {
break;
}
//serve a riconoscere il tipo di richiesta
s = new StringTokenizer(headerLine);
temp = s.nextToken();
if ((temp.equals("GET"))||(temp.equals("POST"))||(temp.equals("HEAD"))) {
metodoDaServire = temp;
fileName = s.nextToken();
}
}
} catch (IOException e) {
System.out.println("Stream dati non pronto");
e.printStackTrace();
}
//salva il corpo della richiesta POST
if (metodoDaServire.equals("POST")) {
try {
String postLine = br.readLine();
System.out.println(postLine);
} catch (IOException e) {
System.out.println("L'errore è qui?");
e.printStackTrace();
}
}
//crea la risposta alla richiesta fatta dal client
rispostaLocale.creaRisposta(metodoDaServire, fileName);
try {
input.close();
br.close();
socket.close();
} catch (IOException e) {
System.out.println("Problemi nella chiusura degli stream dati in ingresso");
e.printStackTrace();
}
}
}
La gestione degli header funziona benissimo; se la richiesta è POSt entro però anche nella riga di lettura del body.
//salva il corpo della richiesta POST
if (metodoDaServire.equals("POST")) {
try {
String postLine = br.readLine();
System.out.println(postLine);
} catch (IOException e) {
System.out.println("L'errore è qui?");
e.printStackTrace();
}
E lì sono dolori... non so per quale motivo la br.readline() mi fa "saltare" il flusso di esecuzione. Per intenderci, se faccio debug mi "muore" lì. E da browser vedo un'attesa di caricamento infinita che non si risolverà mai. Se però annullo da browser la richiesta, in console posso vedere la mia riga di body correttamente letta... non ne esco più!! :cry:
Qualcuno ha un'idea del perché mi succede? (ho provato anche a leggerlo a caretteri come InputStreamReader ma si "blocca" lo stesso...) O mi sapete suggerire una strada più corretta e che funzioni per risolvere il problema??
Scusate il papiro ma è lunga da spiegare ed anche così non so se mi sono spiegata bene...
Grazie a chiunque per consigli e suggerimenti!!!!
Sono abbastanza distrutta da un errore che non riesco a risolvere nel semplice server http che sto sviluppando come progetto per un esame in università.
Il server è costituito da tre classi:
-HttpServer che contiene anche il main, ed è la classe che gestisce tutto il processo;
-Richiesta, la classe che fa il parsing dell'header che riceve dal client e riconosce la richiesta http fatta dal client (devo supportare richieste GET, HEAD e POST);
-Risposta, la classe che crea la risposta opportuna a inviare al client.
Il mio problema è nella classe Richiesta; quando gestisco la POST, infatti, voglio anche salvare il body della richiesta per non meglio specificati "usi futuri"; ho impostato questo codice:
public void servi() {
StringTokenizer s = null;
String temp = null;
String fileName = null;
String metodoDaServire = null;
try {
while(br.ready()) {
String headerLine = null;
try {
headerLine = br.readLine();
} catch (IOException e2) {
System.out.println("Problemi nella lettura dello stream dati in ingresso");
e2.printStackTrace();
}
//stampa a video dell'header ricevuto
System.out.println(headerLine);
//fine header se...
if(headerLine.equals(CRLF) || headerLine.equals("")) {
break;
}
//serve a riconoscere il tipo di richiesta
s = new StringTokenizer(headerLine);
temp = s.nextToken();
if ((temp.equals("GET"))||(temp.equals("POST"))||(temp.equals("HEAD"))) {
metodoDaServire = temp;
fileName = s.nextToken();
}
}
} catch (IOException e) {
System.out.println("Stream dati non pronto");
e.printStackTrace();
}
//salva il corpo della richiesta POST
if (metodoDaServire.equals("POST")) {
try {
String postLine = br.readLine();
System.out.println(postLine);
} catch (IOException e) {
System.out.println("L'errore è qui?");
e.printStackTrace();
}
}
//crea la risposta alla richiesta fatta dal client
rispostaLocale.creaRisposta(metodoDaServire, fileName);
try {
input.close();
br.close();
socket.close();
} catch (IOException e) {
System.out.println("Problemi nella chiusura degli stream dati in ingresso");
e.printStackTrace();
}
}
}
La gestione degli header funziona benissimo; se la richiesta è POSt entro però anche nella riga di lettura del body.
//salva il corpo della richiesta POST
if (metodoDaServire.equals("POST")) {
try {
String postLine = br.readLine();
System.out.println(postLine);
} catch (IOException e) {
System.out.println("L'errore è qui?");
e.printStackTrace();
}
E lì sono dolori... non so per quale motivo la br.readline() mi fa "saltare" il flusso di esecuzione. Per intenderci, se faccio debug mi "muore" lì. E da browser vedo un'attesa di caricamento infinita che non si risolverà mai. Se però annullo da browser la richiesta, in console posso vedere la mia riga di body correttamente letta... non ne esco più!! :cry:
Qualcuno ha un'idea del perché mi succede? (ho provato anche a leggerlo a caretteri come InputStreamReader ma si "blocca" lo stesso...) O mi sapete suggerire una strada più corretta e che funzioni per risolvere il problema??
Scusate il papiro ma è lunga da spiegare ed anche così non so se mi sono spiegata bene...
Grazie a chiunque per consigli e suggerimenti!!!!