|
|
|
|
Posté par
karine, le lundi 25 avril 2005 à 09:54:00Bonjour!
Pourrais tu mettre l'erreur en entier s'il te plait! Juste le nom de l'erreur ne suffit pas! ;) merci! Maily, Plus ça rate, et plus ça a de chance que ça marche. |
Ben justement elle est en entier, y a rien d'autre d'indiqué.
Je peux pas en dire plus... Tu as déjà vu ce genre d'erreur ? |
Oui, c'est tres courant, c'est une erreur de dépassement mémoire : ya qqchose dans ton code qui pointe en dehors de la zone de mémoire allouée, et donc pointe sur null. Tu traite des tableau, ou des Vector qqpart je pense, et tu as du mettre un indice de trop, mais nous ton code stp, et la ligne ou il te fait l'erreur (c'est marqué normalement quand tu as l'erreur).
~ iclic @ gauch,iclic, iclic @ droate, iclic, iclic
et ya pas de bôg môsieu ! ~ |
La ligne est pas marquée mais avec les traces je vois que ça bloque au niveau de la ligne stmt.executeUpdate(query);
J'utilise pas de tableau ou de vecteur, c'est ça le pire ! Je vous mets le code si ça peut aider.
public class PServer {
final static int localport = 8080;
public static int cle = 0;
public static Statement stmt;
// Variables pour accéder à la base de données :
public static String my_password;
public static String my_login;
public static String my_Base;
public static String my_Serveur;
public static void main(String[] args) throws IOException {
ServerSocket serveur = null;
try{
// Connection à la base de données pour sauvegarder les requetes des clients et les réponses du serveur Web
paramConnection();
newConnection();
serveur = new ServerSocket(localport);
System.out.println("Serveur proxy démarré sur le port " + localport + "\n");
// Ecoute infinie des requêtes des clients
while(true){
Socket client = serveur.accept();
cle = cle + 1;
Clients c = new Clients(client,cle);
System.out.println("Nouveau client\n");
}
}
catch (Exception e){System.err.println(e);}
finally{
try{
if (serveur != null) {
serveur.close();
System.out.println("serveur.close");
}
}
catch (Exception e){System.err.println(e);}
}
}
/**
* paramConnection()
* methode qui effectue le paramétrage des variable de connection
*/
public static void paramConnection() {
try {
String chemin = "../Connection.txt";
FileReader fr = new FileReader(chemin);
BufferedReader br = new BufferedReader(fr);
String texte;
for (int i=0; i<4; i++) {
texte = br.readLine();
if (i == 0) my_password = recupParam(texte);
//System.out.println(my_password);
if (i == 1) my_login = recupParam(texte);
//System.out.println(my_login);
if (i == 2) my_Base = recupParam(texte);
//System.out.println(my_Base);
if (i == 3) my_Serveur = recupParam(texte);
//System.out.println(my_Serveur);
} // Fin for.
br.close();
//readLine pour lire une ligne
//note: si il n y a rien, la fonction retournera la valeur null
} // Fin try.
catch(IOException ioe) {
System.out.println("erreur de lecture du fichier de connection reglage par defaut: " + ioe);
my_password = new String(""); //par defaut ""
my_login = new String("root"); //par defaut "root"
my_Base = new String("db1"); //nom de la base (par defaut "db1")
my_Serveur = new String("localhost"); //par defaut "localhost"
} // Fin catch.
} // Fin de paramConnection().
/**
* newConnection() :
* Méthode qui fait la connexion avec la base de données MySQL db1.
*/
public static void newConnection() {
try {
// Chargement du driver JDBC de MySQL.
Class.forName("com.mysql.jdbc.Driver").newInstance();
System.out.println(my_password);
System.out.println(my_Serveur);
System.out.println(my_Base);
System.out.println(my_login);
// Connection à la base de données db1.
java.sql.Connection connection = DriverManager.getConnection((String)("jdbc:mysql://"+my_Serveur+"/"+my_Base+"?user="+my_login+"&password="+my_password));
stmt = connection.createStatement();
} // Fin du Try.
catch (Exception e) {
System.out.println("error : in newConnection");
e.printStackTrace();
System.exit(-1);
} // Fin du Catch.
} // Fin de newConnection();
/**
* String recup_param(String texte)
* methode qui permet de recuperer les parametre entre "" dans le string
*/
private static String recupParam(String texte){
String formater;
char[] tab;
char[] result;
int i,j;
tab = texte.toCharArray();
i = 0;
while (tab[i] != '"')
i++;
i++;
formater = new String();
while (tab[i] != '"')
formater = formater + tab[i++];
return formater;
} // Fin de recupParam().
} // ! PServ class
class Clients extends Thread {
private Socket client;
private int cle;
private String url;
private InputStream sin;
private OutputStream sout;
public static int port = 80;
private String query;
public static Statement stmt;
public Clients(Socket client, int cle){
try{
this.client = client;
this.cle = cle;
start();
}
catch (Exception e){System.err.println(e);}
} // !constructeur
public void run(){
try{
sin = client.getInputStream();
BufferedReader from_client = new BufferedReader(new InputStreamReader(sin));
sout = client.getOutputStream();
/*byte [] buffer = new byte[4096];
int lus;*/
String tmp;
String requete = "";
String user_agent = "";
String host_client = "";
String referer = "";
Socket socket = new Socket();
int position;
boolean fini = false;
// Lecture de la requete du client
while (((tmp = from_client.readLine()) != null) && !fini){
System.out.println(tmp);
String regex0 = "^(GET|POST) +(http[^ ]+) +HTTP/(.\\..)$";
Pattern p0 = Pattern.compile(regex0);
Matcher m0 = p0.matcher(tmp);
while (m0.find()){
for (int i=0; i <= m0.groupCount(); i++){
System.out.println("Groupe " + i + " : " + m0.group(i));
}
query = "INSERT INTO traces_clients(chaine_entiere) VALUES ('GET')";
System.out.println("ça passe1");
stmt.executeUpdate(query);
System.out.println("ça passe2");
// insertion dans la base des données de l'utilisateur
//System.out.println("INSERT INTO traces_clients(chaine_entiere,methode,URL,norme_HTTP) VALUES ('" + m0.group(0) + "', '" + m0.group(1) + "', '" + m0.group(2) + "', '" + m0.group(3) + "')");
//query = "INSERT INTO traces_clients(chaine_entiere,methode,URL,norme_HTTP) VALUES ('" + m0.group(0) + "', '" + m0.group(1) + "', '" + m0.group(2) + "', '" + m0.group(3) + "')";
//stmt.executeUpdate(query);
}
if (tmp.trim().toUpperCase().startsWith("GET")) {
position = tmp.trim().toUpperCase().lastIndexOf("HTTP") > 0 ? tmp.toUpperCase().lastIndexOf("HTTP") : tmp.length();
url = tmp.trim().substring(11,position-2).trim();
requete = tmp;
} else if (tmp.trim().toUpperCase().startsWith("HEAD") || tmp.trim().toUpperCase().startsWith("POST")) {
position = tmp.trim().toUpperCase().lastIndexOf("HTTP") > 0 ? tmp.toUpperCase().lastIndexOf("HTTP") : tmp.length();
url = tmp.trim().substring(12,position-2).trim();
requete = tmp;
}
// il faut recuperer le User-Agent, le Host et le Referer
String regex = "^User-Agent: +(.*\\))$";
Pattern p = Pattern.compile(regex);
Matcher m = p.matcher(tmp);
while (m.find()){
user_agent = m.group(0);
}
String regex2 = "^Host: +(.*)";
Pattern p2 = Pattern.compile(regex2);
Matcher m2 = p2.matcher(tmp);
while (m2.find()){
host_client = m2.group(1);
}
String regex3 = "^Referer: +(.*)";
Pattern p3 = Pattern.compile(regex3);
Matcher m3 = p3.matcher(tmp);
while (m3.find()){
referer = m3.group(1);
}
// On arrete de lire quand il n'y a plus rien à lire
String regex4 = "^[a-zA-Z]";
Pattern p4 = Pattern.compile(regex4);
Matcher m4 = p4.matcher(tmp);
if (!m4.find()) {
fini = true;
System.out.println("fini " + fini);
break;
}
}
System.out.println("Url demandée : " + url + "\n");
//PARTIE CONNEXION AU SERVEUR WEB
if (host_client != "") {
socket = new Socket(InetAddress.getByName(host_client),port);
System.out.println("socket créé");
}
else if (referer != ""){
socket = new Socket(InetAddress.getByName(referer),port);
System.out.println("socket créé");
} else {
socket = new Socket(InetAddress.getByName(url),port);
System.out.println("socket créé");
}
PrintStream sortant = new PrintStream(socket.getOutputStream());
// On envoie au serveur Web la requete du client
if (host_client != "") {
sortant.println(requete + " \r\n" + user_agent + "\r\n" + "Host: " + host_client + "\r\n" );
} else {
sortant.println(requete + " \r\n" + user_agent + "\r\n" );
}
// Lecture de la réponse du serveur Web
PrintStream sout = new PrintStream(client.getOutputStream());
//BufferedReader entrant = new BufferedReader(new InputStreamReader(socket.getInputStream()));
InputStream entrant = socket.getInputStream();
System.out.println("Lecture de la réponse du serveur ...");
FileWriter sortie = new FileWriter("fichier.txt");
boolean html = false;
boolean pas_encore = false;
byte [] buffer = new byte[4096];
int lus;
while ((lus = entrant.read(buffer)) != -1) {
sout.write(buffer,0,lus);
System.out.write(buffer,0,lus);
}
socket.close();
System.out.println("socket.close();");
client.close();
System.out.println("client.close();");
}
catch (Exception e){System.err.println(e);}
} // ! run() method
} // ! Clients class
|
Moi, je dirais que le problème vient de la connexion. es tu sure que la connexion se fait bien?
Maily, Plus ça rate, et plus ça a de chance que ça marche. |
Dans la fonction NewConnection(), ça a l'air de bien se passer puisqu'il n'y a pas d'exception levée.
Les parametres de connection sont bons, j'ai vérifié. Là je comprends vraiment pas ce qui se passe. Quelqu'un a une idée ? |
Et si dans ta fonction paramConnexion, tu ote le fait qu'on puisse enter les paramètre et tu les mets d'office à la valeur par défaut (comme quand il y une erreur IO.
public static void paramConnection() {
my_password = new String("");
my_login = new String("root");
my_Base = new String("db1");
my_Serveur = new String("localhost");
}
/**
* newConnection() :
* Méthode qui fait la connexion avec la base de données MySQL db1.
*/
public static void newConnection() {
try {
// Chargement du driver JDBC de MySQL.
Class.forName("com.mysql.jdbc.Driver").newInstance();
System.out.println(my_password);
System.out.println(my_Serveur);
System.out.println(my_Base);
System.out.println(my_login);
// Connection à la base de données db1.
java.sql.Connection connection = DriverManager.getConnection((String)("jdbc:mysql://"+my_Serveur+"/"+my_Base+"?user="+my_login+"&password="+my_password));
stmt = connection.createStatement();
} // Fin du Try.
catch (Exception e) {
System.out.println("error : in newConnection");
e.printStackTrace();
System.exit(-1);
} // Fin du Catch.
} // Fin de newConnection();
Ca donne quoi en testant de cette manière ? ~ iclic @ gauch,iclic, iclic @ droate, iclic, iclic et ya pas de bôg môsieu ! ~ |
ah, dsl j'ai cru que c t dans la ofnction de connexion que ca n'allais pas ..
~ iclic @ gauch,iclic, iclic @ droate, iclic, iclic
et ya pas de bôg môsieu ! ~ |
C'est quoi le dernier "System.out.println" qui s'affiche avant ton erreur ?
~ iclic @ gauch,iclic, iclic @ droate, iclic, iclic
et ya pas de bôg môsieu ! ~ |
J'ai testé comme tu m'as dit, mais ça change rien, malheureusement. |
J'avais pas vu ta derniere question.
La derniere trace est ça passe1. |
Je commence à ma dire qu'il y un probleme avec la connection. Car meme avec une requete du type select *, j'ai une erreur.
Comment je peux tester que la connection est toujours là ? |
Ben c'est que ton objet stmt pointe sur null, il doit être mal initialisé. Maintenant, faut savoir ou tu l'initialise, et quand pa rapport au démarrage du thread
~ iclic @ gauch,iclic, iclic @ droate, iclic, iclic
et ya pas de bôg môsieu ! ~ |
Tu avais raison, le stmt était mal initialisé. Ca a l'air de marcher correctement maintenant.
Un grand MERCI à toi !! |
Bonjour,
J'ai un baladeur DJIX 315 et le soucis est qu'il est impossible d'accéder au logiciel pour synchroniser ou retirer des chansons. Il me marque une exception java. lang.NullPointerException: at bootloader.BootLoader.copyRecursiveDir(Unknown Source) at bootloader.BootLoader.updateSoftware(Unknown Source) at bootloader.BootLoader.initThread(Unknown Source) at bootloader.BootLoader.start(Unknown Source) at bootloader.CommandLineMain.main(Unknown Source) Je vous remercie d'avance Cordialement |
Rachète toi un baladeur ou emmène celui-ci en réparation logicielle.
~ N'oubliez pas la balise "Résolu" lorsque votre problème est... résolu :) ~ |
Merci pr le mail c vrément gentil
Cordialement |
| 21/07 11h53 | Comment débuter, quel langage? | Langages |
| 14/09 10h42 | [Programmation] Critères de choix d'un langage/framework | Programmation |
| 21/05 14h06 | Interfaces graphiques pour SQLite | Bases de données |
| 05/11 11h45 | [Javascript] Date de dernière modification | Javascript |
| 08/11 10h32 | [Javascript] Lien aléatoire / Choisir un lien au hasard | Javascript |
| 11/06 15h21 | Probleme de java.lang.NullPointerException | 2 |
| 14/01 14h51 | Java.lang.NullPointerException | 4 |
| 10/07 13h31 | Java.lang.nullpointerexception | 0 |
| 01/07 16h17 | Ex:java.lang.NullPointerException | 0 |
![]() | Java Runtime Environment - Java Runtime Environment (JRE) installe la machine virtuelle Java, permettant de jouer en ligne, de discuter avec des... | Catégorie: Java Licence: Open Source |
![]() | WAMP Server - WAMP5 (WAMP signifiant Windows Apache Mysql PHP) est une plateforme de développement Web sous Windows. Il vous permet de... | Catégorie: Serveurs Licence: Freeware/gratuit |
![]() | Visual Basic 6 Runtime (VB6 DLL) - Le Runtime Visual Basic 6 contient l'ensemble des librairies (DLL) nécessaires pour exécuter des programmes écrits en... | Catégorie: Librairies (DLL) Licence: Freeware/gratuit |
![]() | Firstpage - First Page 2006 est un éditeur html gratuit et excellent. Il permet de travailler un code HTML en couleur, ainsi que de... | Catégorie: Editeurs HTML Licence: Freeware/gratuit |
![]() | Cabasse JAVA MT4 Cherry | Catégorie: Enceintes | 1,475.00 € PriceMinister |
![]() | Cabasse JAVA MT4 Beige | Catégorie: Enceintes | 1,475.00 € PriceMinister |
![]() | Cabasse JAVA MT4 Black | Catégorie: Enceintes | 1,499.00 € Son-Vidéo |
![]() | sun Java W2100Z Dual | Catégorie: Ordinateur de bureau |