java socket 读取文件_java中ServerSocket读取文件流不是分行读取

在学习socket的TCP通讯

在使用 TCP传一个文件时 遇到这样两个问题

1. 服务端流读取时一次性读了所有内容 而不是分行读取

2. 自动刷新不生效

代码如下

package com.fuge.TCP.demo2;

import java.io.*;

import java.net.Socket;

public class UploadClient {

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

//1. 建立tcp客户端socket

Socket socket = new Socket("127.0.0.1", 6060);

//2. 文件读取流

BufferedReader bufr = new BufferedReader(new FileReader("D://test.txt"));

//3. TCP文件输出流

// 设置了自动刷新 然没有生效

PrintWriter out = new PrintWriter(socket.getOutputStream(),true);

String line;

// 循环读文件然后通过TCP输出

while ((line = bufr.readLine()) != null) {

out.write(line);

/**

* 这里自动刷新不生效 需要手动刷新

*/

out.flush();

}

// 结束标志

socket.shutdownOutput();

// 读取服务端返回的内容

BufferedReader in = new BufferedReader(new InputStreamReader(socket.getInputStream()));

String returnMsg = in.readLine();

System.out.println(returnMsg);

//关闭流

bufr.close();

socket.close();

}

}

package com.fuge.TCP.demo2;

import java.io.*;

import java.net.ServerSocket;

import java.net.Socket;

public class UploadServer {

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

// 1. 建立服务端TCP服务

ServerSocket ss = new ServerSocket(6060);

// 获取连接的客户端的socket

Socket s = ss.accept();

System.out.println(s.getInetAddress().getHostAddress() + "............connection!!!");

// 建立文件读取流

BufferedReader in = new BufferedReader(new InputStreamReader(s.getInputStream()));

// 建立文件写出流 写到D盘中去

BufferedWriter bw = new BufferedWriter(new FileWriter("D://new.txt"));

String line;

while ((line = in.readLine()) != null) {

bw.write(line);

/**

* 这里换行不生效

* 因为debug时发现 这里的line是一次性读了所有的内容 而不是一段一段读取的

*/

bw.newLine();

bw.flush();

}

// 返回一个成功标志给客户端 设置了自动刷新

PrintWriter out = new PrintWriter(s.getOutputStream(),true);

out.write("上传成功");

out.flush(); // 这里自动刷新不生效 需要手动刷新

//关闭流

bw.close();

s.close();

ss.close();

}

}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Java Socket编程,可以使用select()方法实现多路复用的功能,以便同时处理多个Socket连接。select()方法会阻塞当前线程,直到其一个Socket连接上有事件发生,或者超时时间到了,或者被断。 以下是一个简单的使用select()方法的例子: ```java Selector selector = Selector.open(); ServerSocketChannel serverSocket = ServerSocketChannel.open(); serverSocket.bind(new InetSocketAddress(8080)); serverSocket.configureBlocking(false); serverSocket.register(selector, SelectionKey.OP_ACCEPT); while (true) { selector.select(); // 阻塞当前线程,直到有事件发生 Set<SelectionKey> selectedKeys = selector.selectedKeys(); Iterator<SelectionKey> keyIterator = selectedKeys.iterator(); while (keyIterator.hasNext()) { SelectionKey key = keyIterator.next(); if (key.isAcceptable()) { // 处理连接请求 SocketChannel client = serverSocket.accept(); client.configureBlocking(false); client.register(selector, SelectionKey.OP_READ); } else if (key.isReadable()) { // 处理读取数据 SocketChannel client = (SocketChannel) key.channel(); ByteBuffer buffer = ByteBuffer.allocate(1024); int bytesRead = client.read(buffer); // 处理读取到的数据 } keyIterator.remove(); } } ``` 在上述代码,首先创建一个Selector对象,并将ServerSocketChannel注册到Selector上,然后通过调用select()方法进行事件轮询,当有事件发生时,就可以通过SelectionKey来获取对应的Channel,并处理相应的事件。在处理完事件后不要忘记调用keyIterator.remove()方法将SelectionKey从selectedKeys集合移除,以便下次轮询时不会重复处理。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值