Java NIO框架Netty教程(十五)-利用Netty进行文件传输

全文详见个人独立博客:Java NIO框架Netty教程(十五)-利用Netty进行文件传输

Java NIO框架Netty教程(十五)-利用Netty进行文件传输如果您持续关注OneCoder,您可能会问,在《Java NIO框架Netty教程(十四)- Netty中OIO模型(对比NIO)》中不是说下节介绍的是,NIO和OIO中的worker处理方式吗。这个一定会有的,只是在研究的过程中,OneCoder发现了之前遗留的文件传输的代码,所以决定先完成它。 其实,Netty的样例代码中也提供了文件上传下载的代码样例,不过太过复杂,还包括了Http请求的解析等,对OneCoder来说,容易迷惑那些才是文件传输的关键部分。所以OneCoder决定根据自己去写一个样例,这个理解就是在最开始提到的,Netty的传输是基于流的,我们把文件流化应该就可以传递了。于是有了以下的代码: /** * 文件传输接收端,没有处理文件发送结束关闭流的情景 * * @author lihzh * @alia OneCoder * @blog http://www.coderli.com */ public class FileServerHandler extends SimpleChannelHandler { private File file = new File(&quot;F:/2.txt&quot;); private FileOutputStream fos; public FileServerHandler() { try { if (!file.exists()) { file.createNewFile(); } else { file.delete(); file.createNewFile(); } fos = new FileOutputStream(file); } catch (IOException e) { e.printStackTrace(); } } @Override public void messageReceived(ChannelHandlerContext ctx, MessageEvent e) throws Exception { ChannelBuffer buffer = (ChannelBuffer) e.getMessage(); int length = buffer.readableBytes(); buffer.readBytes(fos, length); fos.flush(); buffer.clear(); } } /** * 文件发送客户端,通过字节流来发送文件,仅实现文件传输部分,<br> * 没有对文件传输结束进行处理<br> * 应该发送文件发送结束标识,供接受端关闭流。 * * @author lihzh * @alia OneCoder * @blog http://www.coderli.com */ public class FileClientHandler extends SimpleChannelHandler { // 每次处理的字节数 private int readLength = 8; @Override public void channelConnected(ChannelHandlerContext ctx, ChannelStateEvent e) throws Exception { // 发送文件 sendFile(e.getChannel()); } private void sendFile(Channel channel) throws IOException { File file = new File(&quot;E:/1.txt&quot;); FileInputStream fis = new FileInputStream(file); int count = 0; BufferedInputStream bis = new BufferedInputStream(fis); for (;;) { byte[] bytes = new byte[readLength]; int readNum = bis.read(bytes, 0, readLength); if (readNum == -1) { return; } sendToServer(bytes, channel, readNum); System.out.println(&quot;Send count: &quot; + ++count); } } private void sendToServer(byte[] bytes, Channel channel, int length) throws IOException { ChannelBuffer buffer = ChannelBuffers.copiedBuffer(bytes, 0, length); channel.write(buffer); } } 待发送的文件1.txt内容如下: 运行上述代码,接受到的文件2.txt结果: 完全一模一样。成功! 这只是一个简单的文件传输的例子,可以做为样例借鉴。对于大文件传输的情景,本样例并不支持,会出现内存溢出的情景,OneCoder准备另外单独介绍一下。icon-default.png?t=N7T8https://www.coderli.com/netty-file-transfer/欢迎加入群聊,一起交流探讨【Java学习交流(982860385)】

如果您持续关注OneCoder,您可能会问,在《Java NIO框架Netty教程(十四)- Netty中OIO模型(对比NIO)》中不是说下节介绍的是,NIOOIO中的worker处理方式吗。这个一定会有的,只是在研究的过程中,OneCoder发现了之前遗留的文件传输的代码,所以决定先完成它。

其实,Netty的样例代码中也提供了文件上传下载的代码样例,不过太过复杂,还包括了Http请求的解析等,对OneCoder来说,容易迷惑那些才是文件传输的关键部分。所以OneCoder决定根据自己去写一个样例,这个理解就是在最开始提到的,Netty的传输是基于流的,我们把文件流化应该就可以传递了。于是有了以下的代码:

/**
 * 文件传输接收端,没有处理文件发送结束关闭流的情景
 * 
 * @author lihzh
 * @alia OneCoder
 * @blog http://www.coderli.com
 */
public class FileServerHandler extends SimpleChannelHandler {

	private File file = new File(&quot;F:/2.txt&quot;);
	private FileOutputStream fos;

	public FileServerHandler() {
		try {
			if (!file.exists()) {
				file.createNewFile();
			} else {
				file.delete();
				file.createNewFile();
			}
			fos = new FileOutputStream(file);
		} catch (IOException e) {
			e.printStackTrace();
		}
	}

	@Override
	public void messageReceived(ChannelHandlerContext ctx, MessageEvent e)
			throws Exception {
		ChannelBuffer buffer = (ChannelBuffer) e.getMessage();
		int length = buffer.readableBytes();
		buffer.readBytes(fos, length);
		fos.flush();
		buffer.clear();
	}

}
/**
 * 文件发送客户端,通过字节流来发送文件,仅实现文件传输部分,<br>
 * 没有对文件传输结束进行处理<br>
 * 应该发送文件发送结束标识,供接受端关闭流。
 * 
 * @author lihzh
 * @alia OneCoder
 * @blog http://www.coderli.com
 */
public class FileClientHandler extends SimpleChannelHandler {

        // 每次处理的字节数
	private int readLength = 8;

	@Override
	public void channelConnected(ChannelHandlerContext ctx, ChannelStateEvent e)
			throws Exception {
		// 发送文件
		sendFile(e.getChannel());
	}

	private void sendFile(Channel channel) throws IOException {
		File file = new File(&quot;E:/1.txt&quot;);
		FileInputStream fis = new FileInputStream(file);
		int count = 0;
                BufferedInputStream bis = new BufferedInputStream(fis);
		for (;;) {
			byte[] bytes = new byte[readLength];
			int readNum = bis.read(bytes, 0, readLength);
			if (readNum == -1) {
				return;
			}
			sendToServer(bytes, channel, readNum);
			System.out.println(&quot;Send count: &quot; + ++count);
		}

	}

	private void sendToServer(byte[] bytes, Channel channel, int length)
			throws IOException {
		ChannelBuffer buffer = ChannelBuffers.copiedBuffer(bytes, 0, length);
		channel.write(buffer);
	}

}

待发送的文件1.txt内容如下:

 全文详见个人独立博客:Java NIO框架Netty教程(十五)-利用Netty进行文件传输

 欢迎加入群聊,一起交流探讨【Java学习交流(982860385)】

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值