1

myqslクエリを取得してに保存し、ArrayListそれを別のクラスにリンクしてからシリアル化し、http経由で送信する宿題があります。スキームでは次のようになります。

class Server{static class a   {try{try{  try{arraylist1}  }}}}

class b {var1,var2,link_to(arraylist1)}

次に、クラスbをシリアル化して送信します

私はSQLクエリを取得し、ArrayList内のオブジェクト(クラス「Personat」から作成されたオブジェクト)を介して保存することができました。

     if (rs != null) {
         List<Personat> perList = new ArrayList<Personat>();
         while (rs.next()) {
            Personat per = new Personat();      
            per.setID(rs.getInt("var1"));
            per.setName(rs.getString("var2"));  
            per.setAmount(rs.getInt("var3"));
            perList.add(per);
         }
     }
     Where rs=ResultSet object

ArrayListしかし、 fromクラスbにアクセスできないため、シリアル化できます。私はそれを静的にしようとしました(何も、それはリンクできません)私はゲッターを作ろうとしました(それでも私がそれらを自動的に生成するので日食は私に何もさせません)。

だから私は何をすべきかわからない!誰かが私を助けることができますか?または誰かが何か考えを持っていますか?私はこれをグーグルで検索しようとしましたが、ご覧のとおり、少し具体的すぎるため、今まで結果はありませんでした...。

これが私のServer.javaです

package server2;
import java.io.IOException;
import java.io.ObjectInputStream;
import java.io.OutputStream;
import java.io.Serializable;
import java.net.InetSocketAddress;
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.util.ArrayList;
import java.util.List;
import com.sun.net.httpserver.HttpExchange;
import com.sun.net.httpserver.HttpHandler;
import com.sun.net.httpserver.HttpServer;

 public class Server {
private static List<Personat> perList = new ArrayList<Personat>();
 //need to access this in the SendRes class 
public List<Personat> getPerList() {
    return perList;
}

public static void main(String[] args) throws Exception {

    HttpServer server = HttpServer.create(new InetSocketAddress(3333), 0);

    server.createContext("/", new MyHandler());
    server.setExecutor(null); 
    server.start();
}

static public class MyHandler implements HttpHandler {

    public void handle(HttpExchange t) throws IOException {

        ObjectInputStream ios = new ObjectInputStream(t.getRequestBody());
        //
        final String url = "jdbc:mysql://localhost/httpServer";

        final String user = "root";

        final String password = "";

        try {
            Send oin = (Send) ios.readObject();
            int id = oin.getId();
            String emri = oin.getName();
            int amount = oin.getAmount();
            int paid = oin.getPaid();
            try {
                Class.forName("com.mysql.jdbc.Driver");
                Connection con = DriverManager.getConnection(url, user,
                        password);

                try {
                    PreparedStatement s = con
                            .prepareStatement("INSERT INTO person(ID,Name,Amount,Paid) VALUES (?,?,?,?)");
                    s.setInt(1, id);
                    s.setString(2, emri);
                    s.setInt(3, amount);
                    s.setInt(4, paid);
                    s.executeUpdate();

                    ResultSet rs = s.executeQuery("SELECT * "
                            + "from personat ORDER BY EmpId");

                    if (rs != null) {

                        while (rs.next()) {
                            Personat per = new Personat();
                            per.setID(rs.getInt("ID"));
                            per.setName(rs.getString("Name"));
                              per.setAmount(rs.getInt("Amount"));

                            perList.add(per);
                        }
                    }

                    //here i need to send an SendRes object     with the ArrayList inside it 

                } catch (Exception e) {

                    e.printStackTrace();
                } finally {
                    if (con != null) {
                        con.close();
                    }
                }

            } catch (Exception e) {
                e.printStackTrace();
            }

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

    }
}
    }

    class SendResponse implements Serializable {
String gabim;
String gabimNr;
    //link the arraylist from class server here
    }

    class Personat {
int ID;

public int getID() {
    return ID;
}

public void setID(int iD) {
    ID = iD;
}

public String getName() {
    return Name;
}

public void setName(String name) {
    Name = name;
}

public int getAmount() {
    return Amount;
}
public void setAmount(int amount) {
    Amount = amount;
}
String Name;
int Amount;
   }
4

1 に答える 1

1

タイプのオブジェクトは、タイプBのパブリックメンバーにのみアクセスできますA。リストにアクセスするには、リストをのパブリックメンバーにする必要がありますA。これを行う一般的な方法は、プライベートフィールドとパブリックゲッターを使用することです。

class A
{
    private List<Personat> personList;

    public List<Personat> getPersonList() { return personList; }

    public void handle(HttpExchange t) throws IOException
    {
        // ...
        personList = ...;
        // ...
    }
}

リストへのパブリックアクセスを許可することにより、クライアントがリストの内容を変更することも許可されることに注意してください。これが望ましくない場合は、リストのコピーを提供することをお勧めします。


少し無関係なことに、1つのメソッドに3つのネストされたtryブロックがある場合、そのメソッドはおそらく複雑すぎるため、より小さなメソッドにリファクタリングする必要があります。

于 2012-11-01T11:44:56.083 に答える