Him*_*waj 0 java sockets serversocket
您好我正在编写一个简单的java程序来从套接字读取数据,但遇到了一个问题,在每次输入后我都会有很多空格.
目的:编写一个简单的服务器套接字,它可以从客户端套接字读取CORRECT数据.
到目前为止:我已经能够编写从socket读取的代码,甚至能够读取数据,但事情是我最后得到了很多空格.
所以我不得不使用trim()来管理空间,但我仍然不知道这是对还是错.
会对这方面的意见表示赞赏.
注意:我使用windows7 telnet服务连接到套接字.
readSocket() {
System.out.println(client_socket);
try {
System.out.println("reading socket");
/*BufferedReader brIn = new BufferedReader(new InputStreamReader(client_socket.getInputStream()));
String inputLine = null;
while ((inputLine = brIn.readLine()) != null) {
System.out.println(inputLine);
}*/
InputStream is = client_socket.getInputStream();
byte[] byteArr = new byte[1024];
int inputsize = -1;
int currentPos = 0;
StringBuffer sb = new StringBuffer(11111);
/*while((inputsize = is.read(byteArr)) != -1) {
String processed = new String(byteArr);
sb.append(processed);
}*/
int BUFFER_SIZE = 1024;
int read;
byte[] buffer = new byte[BUFFER_SIZE];
String processed = "";
while ((read = is.read(byteArr, 0, BUFFER_SIZE)) != -1) {
String current = new String(byteArr);
//os.write(buffer, 0, read);
System.out.println("current Process "+current);
//processed +=current;
sb.append(current.toString().trim());
}
System.out.println("Socket input is : "+sb.toString());
System.out.println("Sending response to client "+processed.toString());
//client_socket.getOutputStream().write(sb.toString().getBytes());
//client_socket.getOutputStream().close();
FileOutputStream fos = new FileOutputStream(new File("C:\\Users\\himanshu2100\\eee.txt"));
fos.write(processed.getBytes());
fos.close();
is.close();
client_socket.close();
} catch (IOException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
Run Code Online (Sandbox Code Playgroud)
好吧,使用RogerLindsjö和mprivat的建议,我重新设计了我从流中读取的部分.
readSocket() {
System.out.println(client_socket);
try {
System.out.println("reading socket");
InputStream is = client_socket.getInputStream();
byte[] byteArr = new byte[1024];
int read;
int BUFFER_SIZE = 1024;
ByteArrayOutputStream baos = new ByteArrayOutputStream();
while ((read = is.read(byteArr, 0, BUFFER_SIZE)) != -1) {
baos.write(byteArr, 0, read); //This is an optimized design, instead of having so many strings
}
System.out.println("Output is :"+new String(baos.toByteArray()));
baos.close();
is.close();
client_socket.close();
} catch (IOException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
Run Code Online (Sandbox Code Playgroud)
我希望这个是一个更好的解决方案,所以发布它.建议欢迎.
在这一行: while ((read = is.read(byteArr, 0, BUFFER_SIZE)) != -1) {
read
将包含实际读取的字节数,因此如果您的服务器发送字符串"CORRECT"但您的字符BUFFER_SIZE
为1024,则会有很多额外空间,因此您无法执行此操作:String current = new String(byteArr);
.相反,您必须仅使用从流中读取的字节:
String current = new String(byteArr, 0, read);
Run Code Online (Sandbox Code Playgroud)
归档时间: |
|
查看次数: |
572 次 |
最近记录: |