急:java 两个客户端间实现文件传输功能,高手来帮帮忙

来源:百度知道 编辑:UC知道 时间:2024/05/23 12:25:31
就像那种简单的聊天一样,不过是换成了文件传输功能
一个client,一个server,通过流实现

为了提高效率,我的设想是将文件切成若干个小块,通过一个for循环,每次循环就新起一个线程,依次传输这些小块里的内容。

问题是client和server之间只是一个socket相连,client端可以在循环时将文件的小块依次写入到socket.getOutputStream()里,但是当另一方从socket.getInputStream()里接收字节流并写入本机的某个新建的文件时它接收到的就是一堆字节,是无法识别这些字节分别属于文件里的哪些块的,因此就不能把这些字节写入到新文件里正确的位置。这样的问题该怎么解决?

小弟我分不多,先给30,解决了再追加。很着急,希望大家帮个忙,先谢谢了

使用RandomAccessFile这个类,这个类有一个pointer的机制,类似于C的指针,允许你使用seek方法访问文件的指定位置,但是需要发送方在传输一块时同时告诉接收方这一块应该从文件的哪里开始写入。
比如:文件1000字节,你每次发送100字节,这样,在第一块发送后,应该告诉对方从0开始写入,在第二块发送后,告知从100开始写入。

不知道你用没用过文件分割器,就是先将大文件分割成很多小块来保存,等需要用的时候再将所有的小块合成为原来的软件。只不过文件分割器组合文件时是按照小块文件的名字来组合的(分割后的小块文件按照一定的规则自动命名,这样根据名字就可以知道哪个小块应该在原文件中的哪块),对于你的这个文件传输问题,也可以借鉴这种思想啊,你可以在客户端对每个小块作出某种可以表示顺序的标记,到服务端再把所有传过来的小块文件按照你作的顺序标记组合起来就可以了啊。原理就是这么简单。

呵呵 用字节流来传输 如果你没有涉及到断点续传 那就很简单啦

我觉得,你应该像一册书一样,书有页码,所以他不会乱,所以你可以使用索引,或者其它的标志,比如,你应该是先打断,打断的时候给一个索引,然后再把内容读出来发出去。接收方同理,先接收索引,然后再根据索引来写入

这个问题很简单啊,不用高手帮忙。你可以先研究一下读写文件。读写二进制文件,然后研究socket网络字节流。都看明白了问题就解决了,祝你工作愉快。

你想多线程同时传输的话就需要建立多个连接