PDA

View Full Version : aiuto problema in java


peppepayens
14-06-2010, 18:28
Prima di tutto buona sera a tutti
allora io devo fare un progetto che può inserire ricercare e cancellare oggetti in un database...
nello specifico il mio database deve essere formato di oggetti di una classe creata da me di nome CD un'altra DVD e poi un altra Libro...
è un progetto client server multithread con interfaccia grafica e database mysql...
allora mi sono bloccato in un punto, praticamente ho creato manualmente il database in mysql ed ho aggiunto la tabella inserisciCD dove poi posso inserire oggetti di tipo CD stessa cosa per DVD e per Libro(mi manca ora solo la parte di ricerca nel database e di cancellazioni di oggeti nel database).
ho collegato il mio bottone salva ad un action listener che manda attraverso il metodo Client.inserisciCD(parametri da inserire) l'oggetto che il client vuole caricare nel database.
questo è il server ora metto il client e poi il pannello che gestisce l'aciotn listener

package Progetto;
import java.io.*;
import java.net.*;
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.SQLException;
import java.sql.Statement;
import java.util.*;
import java.sql.*;
public class MultiThreadServer {

private static ServerSocket serverSocket;
private static final int PORT = 9878;
private static Connection con;
public static void main(String[] args) {

try{
Class.forName("com.mysql.jdbc.Driver");
String nomeDB = "ArchivioDB";
String nomeUtente = "root";
String pwdUtente = "root";
con = DriverManager.getConnection("jdbc:mysql://localhost/" + nomeDB + "?user=" + nomeUtente + "&password=" + pwdUtente);
// boolean ris = con.createStatement().execute(Query.CreaArchivioCD);
// if (ris){
// System.out.println("Archivio CD");
// }


}catch(SQLException e) {
System.out.println("errore ");
e.printStackTrace();
}
catch (ClassNotFoundException e) {
e.printStackTrace();
}

try {
serverSocket = new ServerSocket(PORT);
System.out.println("Server in attesa...");
while(true) {
//Wait for client...
Socket client = serverSocket.accept();
System.out.println("\nNuovo client accettato.\n");
ServerThread thread = new ServerThread(client,con);
thread.start();
// Esecuzione dei thread in base alla richiesta dei client

}
}catch (IOException ioEx) {
System.out.println("\nUnable to set up port!");
ioEx.printStackTrace();
System.exit(1);
}
}

}

class ServerThread extends Thread {
Socket client;
ObjectInputStream input;
ObjectOutputStream output;
Connection con;

public ServerThread(Socket socket,Connection con ) {
//Set up reference to associated socket...
client = socket;
this.con=con;

try {
// input = new ObjectInputStream(client.getInputStream());
// output = new PrintWriter(client.getOutputStream(),true);
output = new ObjectOutputStream( socket.getOutputStream() );
input = new ObjectInputStream( socket.getInputStream() );


}
catch(IOException ioEx) {
ioEx.printStackTrace();
}
}

public void run() {
try {
Object obj=input.readObject();
// if(obj instanceof CD)
if(obj.getClass().getName().equals("CD")){
CD cd = (CD)obj;
PreparedStatement ps = con.prepareStatement(Query.InsertCD);
ps.setString(1,cd.getTitolo());
ps.setString(2,cd.getAutore());
ps.setInt(3,cd.getNumeroTracce());
ps.setDouble(4,cd.getTempoEsecuzione());
ps.setBoolean(5,cd.getPrestito());
ps.setString(6,cd.getCommento());
int res = ps.executeUpdate();
if(res>0){
output.writeObject( true );
output.flush();
;
} else
output.writeObject( true );
output.flush();
ps.close();
}
} catch (IOException e) {
e.printStackTrace();
} catch (ClassNotFoundException e) {
e.printStackTrace();
} catch (SQLException e) {
e.printStackTrace();
}
}
}

peppepayens
14-06-2010, 18:30
CLIENT:


package Progetto;
import java.io.*;
import java.net.*;
import java.util.*;
public class Client {
static ObjectInputStream ois;
static ObjectOutputStream oos;
private static InetAddress host;
private static final int PORT = 9878;

public static void main(String atgs[]) {
try
{
host = InetAddress.getLocalHost();
}
catch(UnknownHostException uhEx)
{
System.out.println("\nHost ID not found!\n");
System.exit(1);
}
GUIManager gui = new GUIManager();

}

public static boolean inserisciCD(CD inserireCD) {
Socket socket = null;
boolean res=false;
try
{
socket = new Socket(host,PORT);
ois = new ObjectInputStream(socket.getInputStream());
oos = new ObjectOutputStream(socket.getOutputStream());
oos.writeObject(inserireCD);
oos.flush();

Object dati = (CD)ois.readObject();

// Scanner in =new Scanner(socket.getInputStream());
// ObjectOutputStream ps = new ObjectOutputStream (socket.getOutputStream());
// ps.writeObject(inserireCD);
// if(in.nextBoolean())
// res= true;
// ois.close();
// oos.close();

}catch(IOException ioEx)
{
ioEx.printStackTrace();
} catch (ClassNotFoundException e) {

e.printStackTrace();
}

return res;

}
public static boolean inserisciDVD(DVD inserireDVD) {
Socket socket = null;
boolean res=false;
try
{
socket = new Socket(host,PORT);
Scanner in =new Scanner(socket.getInputStream());
PrintStream ps = new PrintStream (socket.getOutputStream());
ps.print(inserireDVD);
if(in.nextBoolean())
res= true;


}catch(IOException ioEx)
{
ioEx.printStackTrace();
}
return res;
}
public static boolean inserisciLibro(Libro inserireLibro) {
Socket socket = null;
boolean res=false;
try
{
socket = new Socket(host,PORT);
Scanner in =new Scanner(socket.getInputStream());
PrintStream ps = new PrintStream (socket.getOutputStream());
ps.print(inserireLibro);
if(in.nextBoolean()) {
res= true;
}

}catch(IOException ioEx){
ioEx.printStackTrace();
}
return res;
}
}

peppepayens
14-06-2010, 18:31
vi scongiuro è tutto il giornao che cerco di risolvere il problema
c'è un errore che non riesco a risolvere diciamo pure più di uno


java.io.WriteAbortedException: writing aborted; java.io.NotSerializableException: Progetto.CD
at java.io.ObjectInputStream.readObject0(Unknown Source)
at java.io.ObjectInputStream.readObject(Unknown Source)
at Progetto.ServerThread.run(MultiThreadServer.java:84)
Caused by: java.io.NotSerializableException: Progetto.CD
at java.io.ObjectOutputStream.writeObject0(Unknown Source)
at java.io.ObjectOutputStream.writeObject(Unknown Source)
at Progetto.Client.inserisciCD(Client.java:33)
at Progetto.PannelloInserimentoCD.actionPerformed(PannelloInserimentoCD.java:203)
at javax.swing.AbstractButton.fireActionPerformed(Unknown Source)
at javax.swing.AbstractButton$Handler.actionPerformed(Unknown Source)
at javax.swing.DefaultButtonModel.fireActionPerformed(Unknown Source)
at javax.swing.DefaultButtonModel.setPressed(Unknown Source)
at javax.swing.plaf.basic.BasicButtonListener.mouseReleased(Unknown Source)
at java.awt.Component.processMouseEvent(Unknown Source)
at javax.swing.JComponent.processMouseEvent(Unknown Source)
at java.awt.Component.processEvent(Unknown Source)
at java.awt.Container.processEvent(Unknown Source)
at java.awt.Component.dispatchEventImpl(Unknown Source)
at java.awt.Container.dispatchEventImpl(Unknown Source)
at java.awt.Component.dispatchEvent(Unknown Source)
at java.awt.LightweightDispatcher.retargetMouseEvent(Unknown Source)
at java.awt.LightweightDispatcher.processMouseEvent(Unknown Source)
at java.awt.LightweightDispatcher.dispatchEvent(Unknown Source)
at java.awt.Container.dispatchEventImpl(Unknown Source)
at java.awt.Window.dispatchEventImpl(Unknown Source)
at java.awt.Component.dispatchEvent(Unknown Source)
at java.awt.EventQueue.dispatchEvent(Unknown Source)
at java.awt.EventDispatchThread.pumpOneEventForFilters(Unknown Source)
at java.awt.EventDispatchThread.pumpEventsForFilter(Unknown Source)
at java.awt.EventDispatchThread.pumpEventsForHierarchy(Unknown Source)
at java.awt.EventDispatchThread.pumpEvents(Unknown Source)
at java.awt.EventDispatchThread.pumpEvents(Unknown Source)
at java.awt.EventDispatchThread.run(Unknown Source)

ndakota
14-06-2010, 18:41
La butto lì: CD implementa l'interfaccia Serializable?

peppepayens
14-06-2010, 19:46
giusto aahah ho dimenticato quello
però ho un altro problema col database mysql


java.sql.SQLException: Parameter index out of range (1 > number of parameters, which is 0).
at com.mysql.jdbc.SQLError.createSQLException(SQLError.java:910)
at com.mysql.jdbc.PreparedStatement.setInternal(PreparedStatement.java:2569)
at com.mysql.jdbc.PreparedStatement.setString(PreparedStatement.java:3397)
at Progetto.ServerThread.run(MultiThreadServer.java:97)

questa è la classe col codice mysql:
package Progetto;

public class Query {
static String CreaArchivioCD = "CREATE TABLE archivio_CD ("+
"titolo varchar(50) PRIMARY KEY,"+
"autore varchar(50) NOT NULL,"+
"n_tracceCD int NOT NULL,"+
"tempo_esec decimal(4,2) NOT NULL,"+
"possesso boolean NOT NULL,"+
"commento varchar(255) NOT NULL )";


static String CreaArchivioDVD = "CREATE TABLE archvio_dvd("+
"titolo varchar(50) PRIMARY KEY,"+
"regista varchar(50) NOT NULL,"+
"tempo_esec int NOT NULL,"+
"possesso boolean NOT NULL,"+
"commento varchar(255) NOT NULL,";

static String CreaArchivioLibro = "CREATE TABLE archivio_libro("+
"titolo varchar(50) PRIMARY KEY,"+
"autore varchar(50) NOT NULL,"+
"casa_editrice varchar(50) NOT NULL,"+
"anno_pub int NOT NULL,"+
"n_pagine int NOT NULL,"+
"possesso boolean NOT NULL,"+
"commento varchar(255) NOT NULL)";

static String InsertCD = "INSERT INTO Archivio_Cd (titolo,autore,n_tracce,tempo_esec,possesso,commento)"+
"VALUES('?','?','?','?','?','?')";

static String InsertDVD = "INSERT INTO ArchivioDvd (titolo,regista,tempo_esec,possesso,commento)"+
"VALUES('?','?','?','?','?')";

static String InsertLibro = "INSERT INTO ArchivioDvd (titolo,autore,casa_editrice,anno_pub,n_pagine,possesso,commento)"+
"VALUES('?','?','?','?','?','?','?')";
}