Я пытаюсь реализовать такой протокол:
Client side:
1) client sends command (String)
2) client sends object
3) client receives object or data [depends on command]
Server side:
1) server reads command (String)
2) server receives object [type depends on command]
3) server sends object or data [depends on command]
На стороне клиента я делаю что-то вроде этого (программные блоки в строке помечены "!!!"):
/** Retrieves required wrapper streams */
private void getSocketStreams() {
try {
inputStream = new DataInputStream(
connection.getInputStream());
/* !!! here is a problem: can I do next line's stuff? */
inputObjectStream = new ObjectInputStream(
connection.getInputStream());
outputWriter = new BufferedWriter(
new OutputStreamWriter(
connection.getOutputStream()));
outputObjectStream = new ObjectOutputStream(
connection.getOutputStream());
} catch (IOException e) {
e.printStackTrace();
}
}
/** "put" command processor */
private int processCmdPut(OrderInfo orderInfo) {
/* Send command to peer */
try {
outputWriter.write("put");
outputWriter.newLine();
outputWriter.flush();
} catch (IOException e) {
e.printStackTrace();
}
/* Send inserted object to peer */
sendObject(orderInfo);
/* Get from peer inserted info id */
int id = -1;
try {
id = inputStream.readInt();
} catch (IOException e) {
e.printStackTrace();
}
return id;
}
/**
* Sends object to peer.
* @param obj object to send.
*/
public void sendObject(Object obj){
try {
outputObjectStream.writeObject(obj);
outputObjectStream.flush();
} catch (IOException e) {
e.printStackTrace();
}
}
Действия сервера на стороне зеркального клиента.
Вопрос о строке, отмеченной "!!!": возможно ли обернуть поток байтов сокета?
с двумя разными высокоуровневыми потоками и читай / пиши в них по очереди (один за другим)?
Я ошибся? Есть моя ошибка или недоразумение?