Java |络文g传输
读者范?/span>:
本文是一简短入门文?/span>.本文假设读者对Java?/span>IOpȝ?/span>Java的网l系l有所了解.
正文:
关于文g传输的问?/span>,实际也是一U?/span>IOd的基本问?/span>.对于|络而言也是一U?/span>IOd问题.因此所谓网l的文g传输实际是两U?/span>IO问题的综合讨?/span>.q里我们首先分析一个图C?/span>.然后围绕q个囄来讨?/span>:
?/span>1:
分析?/span>1我们基本可以知道从服务器文gpȝ中通过把文g中的数据写入到服务器的进E中,然后把进E中的数据通过|络IOpȝ传递到客户?/span>,q个阶段,|络中的数据以字节流的Ş式保?/span>.当该字节被客户q程接受?/span>,客户q程通过客户本地文g写入客h地的文gpȝ?/span>.
Ҏ以上分析,我们基本可以定我所需要处理的问题?/span>.首先我们需要可以对本地文gpȝIO操作的操作接?/span>,然后是一个可以对|络IOpȝq行操作的操作接?/span>,已经一个可以把数据包装成字节流的操作接?/span>,他们分别可以提供客户和服务器两个q程q行d的操?/span>.如下图所C?/span>:
?/span>2:
Ҏ以上分析,我们可以把问题归l到对以下编E接口的需求上:
1. 字节包装器和字节解包?/span>,
2. |络传输器和|络接收?/span>
3. 本地文g?/span>/写器
而这?/span>Java本n?/span>API已l提?/span>.他们都被包装?/span>java.io?/span>java.netq两个包?/span>,q里我提供一个基?/span>TCP/IP的实现版?/span>,使用Zq接的方式来完成工作.我们首先介绍几个相关?/span>JDK中的cL完成以上d,
1. DataOutputStream?/span>DataInputStream实现cL供了上面的字节包装和解包器的实现
2. ServerSocket?/span>Socekt提供了基于连接的|络传输和接受接?/span>
3. File,FileInputStream?/span>FileOutputStream提供了基本的本地文g输入输出接口.
服务器端实现代码:
import java.io.*;
import java.net.*;
public class FileServer{
public static void main(String[] args)throws Exception{
//创徏文g用来读取文件中的数?/span>
File file=new File("lishengjie.jpg");
FileInputStream fos=new FileInputStream(file);
//创徏|络服务器接受客戯?/span>
ServerSocket ss=new ServerSocket(3108);
Socket client=ss.accept();
//创徏|络输出ƈ提供数据包装?/span>
OutputStream netOut=client.getOutputStream();
OutputStream doc=new DataOutputStream(new BufferedOutputStream(netOut));
//创徏文gd~冲?/span>
byte[] buf=new byte[2048];
int num=fos.read(buf);
while(num!=(-1)){//是否d文g
doc.write(buf,0,num);//把文件数据写出网l缓冲区
doc.flush();//h~冲区把数据写往客户?/span>
num=fos.read(buf);//l箋从文件中d数据
}
fos.close();
doc.close();
}
}
客户方实C?/span>:
import java.io.*;
import java.net.*;
public class FileClient{
public static void main(String[] args)throws Exception{
//使用本地文gpȝ接受|络数据q存为新文g
File file=new File("newFile.jpg");
file.createNewFile();
RandomAccessFile raf=new RandomAccessFile(file,"rw");
// 通过Socketq接文g服务?/span>
Socket server=new Socket(InetAddress.getLocalHost(),3108);
//创徏|络接受接受服务器文g数据
InputStream netIn=server.getInputStream();
InputStream in=new DataInputStream(new BufferedInputStream(netIn));
//创徏~冲区缓冲网l数?/span>
byte[] buf=new byte[2048];
int num=in.read(buf);
while(num!=(-1)){//是否d所有数?/span>
raf.write(buf,0,num);//数据写往文g
raf.skipBytes(num);//序写文件字?/span>
num=in.read(buf);//l箋从网l中d文g
}
in.close();
raf.close();
}
}
归结以上代码:
服务?/span> | 客户?/span> |
1. 服务器从本地文gpȝd文g 2. 服务器创建网l服务连?/span> 3. 服务器提供数据包装器 4. 服务器将本地文g写入数据包装?/span> 5. 服务器通过包装器写入到|络 | 1. 客户端徏立新文g准备存储来自|络的数?/span> 2. 客户端连接服务器 3. 客户端通过|络接受服务器数据ƈq行数据解包 4. 客户端将数据写入~冲?/span> 5. 客户端从~冲区把数据写入客户本地文g |
ȝ:
事实?/span>java的开发环境ؓ我们提供大多数的~程接口,为我们简化了开发工作量.我们通过java?/span>IO接口所提供的文?/span>,数据包装器等接口非常方便的解决了我们上面的开发工作量.同时?/span>java?/span>net接口所提供的套接字也得基于连接的数据接受和发送成为非常容易的工作.
Trackback: http://tb.blog.csdn.net/TrackBack.aspx?PostId=283322