我从 java 套接字开始并且有奇怪的 [缺少] 输出。这是我的套接字方法的来源:
客户端源代码:
public void loginToServer(String host, String usnm ) {
try {
Socket testClient = new Socket(host,1042);
System.out.println ("Connected to host at " + host);
logString = ("CONNECTED: " + host);
outGoing = new PrintWriter(testClient.getOutputStream(), true);
outGoing.print("Hello from " + testClient.getLocalSocketAddress());
InputStream inFromServer = testClient.getInputStream();
DataInputStream in = new DataInputStream(inFromServer);
System.out.println("Server says " + in.readLine());
testClient.close();
}
catch (Exception e) {
System.err.println ("Error connecting to host at " + host + ":1042.\n Reason: " + e);
logString = ("CONNECT FAILED: " + host + ":1042: " + e);
}
printLog(logString);
// send server usnm and os.name [System.getProperty(os.name)] ?
}
和服务器代码:
public void runServer() {
try{
server = new ServerSocket(1042);
}
catch (IOException e) {
printLog("LISTEN FAIL on 1042: " + e);
System.err.println("Could not listen on port 1042.");
System.exit(-1);
}
try{
client = server.accept();
}
catch (IOException e) {
printLog("ACCEPT FAIL on 1042: " + e);
System.err.println("Accept failed: 1042");
System.exit(-1);
}
try{
inComing = new BufferedReader(new InputStreamReader(client.getInputStream()));
outGoing = new PrintWriter(client.getOutputStream(), true);
}
catch (IOException e) {
printLog("READ FAIL on 1042: " + e);
System.err.println("Read failed");
System.exit(-1);
}
while(true){
try{
clientData = inComing.readLine();
//processingUnit(clientData, client);
outGoing.print("Thank you for connecting to " + server.getLocalSocketAddress() + "\nGoodbye!");
}
catch (IOException e) {
printLog("READ FAIL on 1042: " + e);
System.out.println("Read failed");
System.exit(-1);
}
}
}
而客户给出的输出仅仅是Connected to host at localhost
.
这是怎么回事?