Java远程传输文件

本文介绍了一种使用Java实现的断点续传技术,该技术允许用户在下载过程中断后继续从断点处下载,避免了重新下载整个文件的过程。通过设置HTTP请求头中的Range属性来指定下载的起始位置。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >


package com.edsion.down;
import java.io.BufferedInputStream;
import java.io.DataOutputStream;
import java.io.File;
import java.io.FileOutputStream;

import java.io.IOException;

import java.io.RandomAccessFile;

import java.net.*;

/**
 * 文件传送客户端:获取远程文件
 */
public class download
{
  public void download() 
     
  {
  }

  private boolean FileExist(String pathAndFile)//确定文件是否已经下载,但没有下载完成
  {
    File file = new File(pathAndFile);
    if (file.exists())
      return true;
    else
      return false;
  }

  private long FileSize(String pathAndFile)//确定已经下载了的文件大小
  {
    File file = new File(pathAndFile);
    return file.length();
  }
  private void FileRename(String fName,String nName)//将下载完全的文件更名,去掉.tp名
  {
    File file = new File(fName);
    file.renameTo(new File(nName));
    file.delete();
  }
  public static void main(String[] args)
  {
    URL url = null;
    HttpURLConnection urlc = null;
    DataOutputStream dos = null;
    BufferedInputStream bis = null;
    FileOutputStream fos = null;
    
    ///------------------------------
    String localFile = "E:\\123\\Storm2012-3.10.02.05.exe";//文件保存的地方及文件名,具体情况可以改
    //------------------------------
    
    String localFile_bak = localFile + ".tp";//未下载完文件加.tp扩展名,以便于区别
    download gco = new download();
    long fileSize = 0;
    long start = System.currentTimeMillis();
    int len = 0;
    byte[] bt = new byte[1024];
    //byte[] buffer=new byte[50*1024];
    RandomAccessFile raFile=null;
    long TotalSize=0;//要下载的文件总大小
    try
    {
      //url = new URL("http://www.netbox.cn/download/nbsetup.EXE");
        //---------------------------
      url = new URL("http://192.168.1.186:8080/down/new/Storm2012-3.10.02.05.exe");
      //--------------------------------
      urlc = (HttpURLConnection) url.openConnection();
      TotalSize=Long.parseLong(urlc.getHeaderField("Content-Length"));
      System.out.println("下载文件大小为:"+TotalSize);
      urlc.disconnect();//先断开,下面再连接,否则下面会报已经连接的错误
      urlc = (HttpURLConnection) url.openConnection();
      //确定文件是否存在
      if (gco.FileExist(localFile_bak))//采用断点续传,这里的依据是看下载文件是否在本地有.tp有扩展名同名文件
      {
        System.out.println("文件续传中...");
        fileSize = gco.FileSize(localFile_bak); //取得文件在小,以便确定随机写入的位置
        System.out.println("fileSize:"+fileSize);
        //设置User-Agent
        //urlc.setRequestProperty("User-Agent","NetFox");
        //设置断点续传的开始位置
        urlc.setRequestProperty("RANGE", "bytes="+fileSize+"-");
        //urlc.setRequestProperty("RANGE", "bytes="+fileSize);//这样写不行,不能少了这个"-".
        //设置接受信息
        urlc.setRequestProperty("Accept","image/gif,image/x-xbitmap,application/msword,*/*");        
        raFile=new RandomAccessFile(localFile_bak,"rw");//随机方位读取
        raFile.seek(fileSize);//定位指针到fileSize位置
        bis = new BufferedInputStream(urlc.getInputStream());
        while ((len = bis.read(bt)) > 0)//循环获取文件
        {
          raFile.write(bt, 0, len);
          //buffer=buffer+bt;
          //System.
        }
        System.out.println("文件续传接收完毕!");        
      }
      else//采用原始下载
      {
        fos = new FileOutputStream(localFile_bak); //没有下载完毕就将文件的扩展名命名.bak
        dos = new DataOutputStream(fos);
        bis = new BufferedInputStream(urlc.getInputStream());        
        System.out.println("正在接收文件...");
        int test=0;
        while ((len = bis.read(bt)) > 0)//循环获取文件
        {
          dos.write(bt, 0, len);
          test++;
          if(test==50)//这里是测试,你可以删除这里,就可以正常下载了
            break;
        }        
        //System.out.println("文件正常接收完毕!");
      }      
      System.out.println("共用时:" + (System.currentTimeMillis() - start) / 1000);
      if(bis!=null)
        bis.close();
      if(dos!=null)
        dos.close();
      if(fos!=null)
        fos.close();
      if(raFile!=null)
        raFile.close();
      System.out.println("localFile_bak:"+gco.FileSize(localFile_bak));
      if(gco.FileSize(localFile_bak)==TotalSize)//下载完毕后,将文件重命名
      {
        gco.FileRename(localFile_bak,localFile);
      }
      System.exit(0);
    }
    catch (Exception e)
    {
      try
      {
        if(bis!=null)
          bis.close();
        if(dos!=null)
          dos.close();
        if(fos!=null)
          fos.close();
        if(raFile!=null)
          raFile.close();
      }
      catch (IOException f)
      {
        f.printStackTrace();
      }
      e.printStackTrace();
    }
    System.exit(0);
  }
}


Java文件夹复制(远程复制(网络传输),用于远程备份文件)(支持文件夹,嵌套子文件夹) import java.io.*; import java.util.*; public class FileSelection { private File rootDirectory;//根目录 private File[] fileList;//文件目录下面的文件列表(包括目录,用于多次判断) private ArrayList fileArrayList; // 用于存储文件(只是文件)列表 //初始化参数 public FileSelection() { fileArrayList=new ArrayList(); rootDirectory = new File("Test"); rootDirectory.mkdir(); } //获得文件(不包括目录)的列表 public void initFileArrayList() { if (rootDirectory.isDirectory()) { //遍历目录下面的文件和子目录 fileList = rootDirectory.listFiles(); for (int i = 0; i < fileList.length; i++) { //如果是文件,添加到文件列表中 if(fileList[i].isFile()){ fileArrayList.add(fileList[i]); } //否则递归遍历子目录 else if (fileList[i].isDirectory()) { fileList[i].mkdir(); rootDirectory=fileList[i]; initFileArrayList(); } } } } //将文件信息添加到列表中 public void addFiles(File f){ fileArrayList.add(f); } //访问器返回文件列表 public ArrayList getFileArrayList() { return fileArrayList; } } -------------------- BackupClient.java package com.xinxin.Client; import java.io.*; import java.net.*; /** * * @author Administrator *@version 1.0 *BackupClient类实现文件传输到服务器 */ public class BackupClient implements Runnable{ private int port;//服务器端口 private InetAddress ipAddress;//服务器IP地址 private Socket clientSocket;//客户端套接字 private InputStream inputStream;//网络输入流 private OutputStream outputStream;//网络输出流 private File file; //构造函数(获得服务器端IP地址和监听端口号) public BackupClient(InetAddress ipAddress,int port,File file){ this.ipAddress=ipAddress; this.port=port;
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值