Je suis en train de mettre en œuvre un tel protocole:Le flux d'octets d'entrée de socket est-il enveloppé dans deux types de flux différents?
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]
côté client, je fais quelque chose comme ça (blocs de programme en ligne, marquée par « !!! »):
/** 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();
}
}
Le côté serveur agit sur un client en miroir.
La question à propos de la ligne, marquée par "!!!": est-il possible d'encapsuler le flux d'octets du socket avec deux flux différents à haut levier et de les lire/écrire tour à tour (un par un)? Ai-je tort? Il y a mon erreur ou mon malentendu?
Merci, j'ai réfléchi et je pense que je le ferai. – Milkywayfarer