用Java实现HTTP断点续传功能Word文档格式.docx

上传人:b****3 文档编号:7965442 上传时间:2023-05-09 格式:DOCX 页数:16 大小:18.86KB
下载 相关 举报
用Java实现HTTP断点续传功能Word文档格式.docx_第1页
第1页 / 共16页
用Java实现HTTP断点续传功能Word文档格式.docx_第2页
第2页 / 共16页
用Java实现HTTP断点续传功能Word文档格式.docx_第3页
第3页 / 共16页
用Java实现HTTP断点续传功能Word文档格式.docx_第4页
第4页 / 共16页
用Java实现HTTP断点续传功能Word文档格式.docx_第5页
第5页 / 共16页
用Java实现HTTP断点续传功能Word文档格式.docx_第6页
第6页 / 共16页
用Java实现HTTP断点续传功能Word文档格式.docx_第7页
第7页 / 共16页
用Java实现HTTP断点续传功能Word文档格式.docx_第8页
第8页 / 共16页
用Java实现HTTP断点续传功能Word文档格式.docx_第9页
第9页 / 共16页
用Java实现HTTP断点续传功能Word文档格式.docx_第10页
第10页 / 共16页
用Java实现HTTP断点续传功能Word文档格式.docx_第11页
第11页 / 共16页
用Java实现HTTP断点续传功能Word文档格式.docx_第12页
第12页 / 共16页
用Java实现HTTP断点续传功能Word文档格式.docx_第13页
第13页 / 共16页
用Java实现HTTP断点续传功能Word文档格式.docx_第14页
第14页 / 共16页
用Java实现HTTP断点续传功能Word文档格式.docx_第15页
第15页 / 共16页
用Java实现HTTP断点续传功能Word文档格式.docx_第16页
第16页 / 共16页
亲,该文档总共16页,全部预览完了,如果喜欢就下载吧!
下载资源
资源描述

用Java实现HTTP断点续传功能Word文档格式.docx

《用Java实现HTTP断点续传功能Word文档格式.docx》由会员分享,可在线阅读,更多相关《用Java实现HTTP断点续传功能Word文档格式.docx(16页珍藏版)》请在冰点文库上搜索。

用Java实现HTTP断点续传功能Word文档格式.docx

Last-Modified=Mon,30Apr200112:

所谓断点续传,也就是要从文件已经下载的地方开始继续下载。

所以在客户端浏览器传给

Web服务器的时候要多加一条信息--从哪里开始。

下面是用自己编的一个"

浏览器"

来传递请求信息给Web服务器,要求从2000070字节开始。

GET/down.zipHTTP/1.0

NetFox

RANGE:

bytes=2000070-

text/html,image/gif,image/jpeg,*;

q=.2,*/*;

q=.2

仔细看一下就会发现多了一行RANGE:

这一行的意思就是告诉服务器down.zip这个文件从2000070字节开始传,前面的字节不用传了。

服务器收到这个请求以后,返回的信息如下:

206

Content-Range=bytes2000070-106786027/106786028

55:

20GMT

和前面服务器返回的信息比较一下,就会发现增加了一行:

返回的代码也改为206了,而不再是200了。

知道了以上原理,就可以进行断点续传的编程了。

(二)Java实现断点续传的关键几点

(1)用什么方法实现提交RANGE:

bytes=2000070-。

当然用最原始的Socket是肯定能完成的,不过那样太费事了,其实Java的net包中提供了这种功能。

代码如下:

URLurl=newURL("

HttpURLConnectionhttpConnection=(HttpURLConnection)url.openConnection

();

//设置User-Agent

httpConnection.setRequestProperty("

User-Agent"

"

NetFox"

);

//设置断点续传的开始位置

RANGE"

bytes=2000070"

//获得输入流

InputStreaminput=httpConnection.getInputStream();

从输入流中取出的字节流就是down.zip文件从2000070开始的字节流。

大家看,其实断点续传用Java实现起来还是很简单的吧。

接下来要做的事就是怎么保存获得的流到文件中去了。

保存文件采用的方法。

我采用的是IO包中的RandAccessFile类。

操作相当简单,假设从2000070处开始保存文件,代码如下:

RandomAccessoSavedFile=newRandomAccessFile("

down.zip"

rw"

longnPos=2000070;

//定位文件指针到nPos位置

oSavedFile.seek(nPos);

byte[]b=newbyte[1024];

intnRead;

//从输入流中读入字节流,然后写到文件中

while((nRead=input.read(b,0,1024))&

gt;

0)

{

oSavedFile.write(b,0,nRead);

}

怎么样,也很简单吧。

接下来要做的就是整合成一个完整的程序了。

包括一系列的线程控制等等。

(三)断点续传内核的实现

主要用了6个类,包括一个测试类。

SiteFileFetch.java负责整个文件的抓取,控制内部线程(FileSplitterFetch类)。

FileSplitterFetch.java负责部分文件的抓取。

FileAccess.java负责文件的存储。

SiteInfoBean.java要抓取的文件的信息,如文件保存的目录,名字,抓取文件的URL等。

Utility.java工具类,放一些简单的方法。

TestMethod.java测试类。

下面是源程序:

/*

**SiteFileFetch.java

*/

packageNetFox;

importjava.io.*;

import.*;

publicclassSiteFileFetchextendsThread{

SiteInfoBeansiteInfoBean=null;

//文件信息Bean

long[]nStartPos;

//开始位置

long[]nEndPos;

//结束位置

FileSplitterFetch[]fileSplitterFetch;

//子线程对象

longnFileLength;

//文件长度

booleanbFirst=true;

//是否第一次取文件

booleanbStop=false;

//停止标志

FiletmpFile;

//文件下载的临时信息

DataOutputStreamoutput;

//输出到文件的输出流

publicSiteFileFetch(SiteInfoBeanbean)throwsIOException

siteInfoBean=bean;

//tmpFile=File.createTempFile("

zhong"

1111"

newFile(bean.getSFilePath()));

tmpFile=newFile(bean.getSFilePath()+File.separator+bean.getSFileName()+"

.info"

if(tmpFile.exists())

bFirst=false;

read_nPos();

else

nStartPos=newlong[bean.getNSplitter()];

nEndPos=newlong[bean.getNSplitter()];

publicvoidrun()

//获得文件长度

//分割文件

//实例FileSplitterFetch

//启动FileSplitterFetch线程

//等待子线程返回

try{

if(bFirst)

nFileLength=getFileSize();

if(nFileLength==-1)

System.err.println("

FileLengthisnotknown!

"

elseif(nFileLength==-2)

Fileisnotaccess!

for(inti=0;

i&

lt;

nStartPos.length;

i++)

nStartPos[i]=(long)(i*(nFileLength/nStartPos.length));

nEndPos.length-1;

nEndPos[i]=nStartPos[i+1];

nEndPos[nEndPos.length-1]=nFileLength;

//启动子线程

fileSplitterFetch=newFileSplitterFetch[nStartPos.length];

fileSplitterFetch[i]=newFileSplitterFetch(siteInfoBean.getSSiteURL(),

siteInfoBean.getSFilePath()+File.separator+siteInfoBean.getSFileName(),

nStartPos[i],nEndPos[i],i);

Utility.log("

Thread"

+i+"

nStartPos="

+nStartPos[i]+"

nEndPos="

+nEndPos[i]);

fileSplitterFetch[i].start();

//fileSplitterFetch[nPos.length-1]=newFileSplitterFetch(siteInfoBean.getSSiteURL(),

siteInfoBean.getSFilePath()+File.separator+siteInfoBean.getSFileName(),nPos[nPos.length-1],nFileLength,nPos.length-1);

//Utility.log("

+(nPos.length-1)+"

+nPos[nPos.length-1]+"

nEndPos="

+nFileLength);

//fileSplitterFetch[nPos.length-1].start();

//等待子线程结束

//intcount=0;

//是否结束while循环

booleanbreakWhile=false;

while(!

bStop)

write_nPos();

Utility.sleep(500);

breakWhile=true;

if(!

fileSplitterFetch[i].bDownOver)

breakWhile=false;

break;

if(breakWhile)

//count++;

//if(count&

4)

//siteStop();

文件下载结束!

catch(Exceptione){e.printStackTrace();

publiclonggetFileSize()

intnFileLength=-1;

URLurl=newURL(siteInfoBean.getSSiteURL());

HttpURLConnectionhttpConnection=(HttpURLConnection)url.openConnection();

intresponseCode=httpConnection.getResponseCode();

if(responseCode&

=400)

processErrorCode(responseCode);

return-2;

//-2representaccessiserror

StringsHeader;

for(inti=1;

;

//DataInputStreamin=newDataInputStream(httpConnection.getInputStream());

//Utility.log(in.readLine());

sHeader=httpConnection.getHeaderFieldKey(i);

if(sHeader!

=null)

if(sHeader.equals("

Content-Length"

))

nFileLength=Integer.parseInt(httpConnection.getHeaderField(sHeader));

catch(IOExceptione){e.printStackTrace();

Utility.log(nFileLength);

returnnFileLength;

//保存下载信息(文件指针位置)

privatevoidwrite_nPos()

output=newDataOutputStream(newFileOutputStream(tmpFile));

output.writeInt(nStartPos.length);

//output.writeLong(nPos[i]);

output.writeLong(fileSplitterFetch[i].nStartPos);

output.writeLong(fileSplitterFetch[i].nEndPos);

output.close();

//读取保存的下载信息(文件指针位置)

privatevoidread_nPos()

DataInputStreaminput=newDataInputStream(newFileInputStream(tmpFile));

intnCount=input.readInt();

nStartPos=newlong[nCount];

nEndPos=newlong[nCount];

nStartPos[i]=input.readLong();

nEndPos[i]=input.readLong();

input.close();

privatevoidprocessErrorCode(intnErrorCode)

ErrorCode:

"

+nErrorCode);

//停止文件下载

publicvoidsiteStop()

bStop=true;

fileSplitterFetch[i].splitterStop();

**FileSplitterFetch.java

publicclassFileSplitterFetchextendsThread{

StringsURL;

//FileURL

longnStartPos;

//FileSnippetStartPosition

longnEndPos;

//FileSnippetEndPosition

intnThreadID;

//Thread'

sID

booleanbDownOver=false;

//Downingisover

//Stopidentical

FileAccessIfileAccessI=null;

//FileAccessinterface

publicFileSplitterFetch(StringsURL,StringsName,longnStart,longnEnd,intid)throwsIOException

this.sURL=sURL;

this.nStartPos=nStart;

this.nEndPos=nEnd;

nThreadID=id;

fileAccessI=newFileAccessI(sName,nStartPos);

while(nStartPos&

nEndPos&

&

!

URLurl=newURL(sURL);

StringsProperty="

bytes="

+nStartPos+"

-"

sProperty);

Utility.log(sProperty);

//logResponseHead(httpConnection);

0&

nStartPos&

nStartPos+=fileAccessI.write(b,0,nRead);

//if(nThreadID==1)

nStartPos="

+nStartPos+"

+nEndPos);

+nThreadID+"

isover!

bDownOver=true;

//nPos=fileAccessI.write(b,0,nRead);

//打印回应的头信息

publicvoidlogResponseHead(HttpURLConnectioncon)

Stringheader=con.getHeaderFieldKey(i);

if(header!

//responseHeaders.put(header,httpConnection.getHeaderField(header));

Utility.log(header+"

:

+con.getHeaderField(header));

publicvoidsplitterStop()

**FileAccess.java

publicclassFileAccessIimplementsSerializable{

RandomAccessFileoSavedFile;

longnPos;

publicFileAccessI()throwsIOException

this("

0);

publicFileAccessI(StringsName,longnPos)throwsIOException

oSavedFile=newRandomAccessFile(sName,"

this.nPos=nPos;

publicsynchronizedintwrite(byte[]b,intnStart,intnLen)

intn=-1;

oSavedFile.write(b,nStart,nLen);

n=nLen;

catch(IOExceptione)

e.printStackTrace();

returnn;

**SiteInfoBean.java

publicclassSiteInfoBean{

privateStringsSiteURL;

//Site'

sURL

privateStringsFilePath;

//SavedFile'

sPath

privateStringsFi

展开阅读全文
相关资源
猜你喜欢
相关搜索
资源标签

当前位置:首页 > 小学教育 > 语文

copyright@ 2008-2023 冰点文库 网站版权所有

经营许可证编号:鄂ICP备19020893号-2