热门标签 | HotTags
当前位置:  开发笔记 > 运维 > 正文

Java基于Socket的文件传输实现方法

这篇文章主要介绍了Java基于Socket的文件传输实现方法,结合实例分析了Java使用Socket实现文件传输的建立连接、发送与接收消息、文件传输等相关技巧,需要的朋友可以参考下

本文实例讲述了Java基于Socket的文件传输实现方法。分享给大家供大家参考,具体如下:

1. Java代码如下:

package sterning;
import java.io.BufferedInputStream;
import java.io.DataInputStream;
import java.io.DataOutputStream;
import java.io.File;
import java.io.FileInputStream;
import java.net.ServerSocket;
import java.net.Socket;
public class ServerTest {
 int port = 8821;
 void start() {
  Socket s = null;
  try {
   ServerSocket ss = new ServerSocket(port);
   while (true) {
    // 选择进行传输的文件
    String filePath = "D:\\lib.rar";
    File fi = new File(filePath);
    System.out.println("文件长度:" + (int) fi.length());
    // public Socket accept() throws
    // IOException侦听并接受到此套接字的连接。此方法在进行连接之前一直阻塞。
    s = ss.accept();
    System.out.println("建立socket链接");
    DataInputStream dis = new DataInputStream(new BufferedInputStream(s.getInputStream()));
    dis.readByte();
    DataInputStream fis = new DataInputStream(new BufferedInputStream(new FileInputStream(filePath)));
    DataOutputStream ps = new DataOutputStream(s.getOutputStream());
    //将文件名及长度传给客户端。这里要真正适用所有平台,例如中文名的处理,还需要加工,具体可以参见Think In Java 4th里有现成的代码。
    ps.writeUTF(fi.getName());
    ps.flush();
    ps.writeLong((long) fi.length());
    ps.flush();
    int bufferSize = 8192;
    byte[] buf = new byte[bufferSize];
    while (true) {
     int read = 0;
     if (fis != null) {
      read = fis.read(buf);
     }
     if (read == -1) {
      break;
     }
     ps.write(buf, 0, read);
    }
    ps.flush();
    // 注意关闭socket链接哦,不然客户端会等待server的数据过来,
    // 直到socket超时,导致数据不完整。    
    fis.close();
    s.close();    
    System.out.println("文件传输完成");
   }
  } catch (Exception e) {
   e.printStackTrace();
  }
 }
 public static void main(String arg[]) {
  new ServerTest().start();
 }
}

2.socket的Util辅助类

package sterning;
import java.net.*;
import java.io.*;
public class ClientSocket {
 private String ip;
 private int port;
 private Socket socket = null;
 DataOutputStream out = null;
 DataInputStream getMessageStream = null;
 public ClientSocket(String ip, int port) {
  this.ip = ip;
  this.port = port;
 }
 /** *//**
  * 创建socket连接
  * 
  * @throws Exception
  *    exception
  */
 public void CreateConnection() throws Exception {
  try {
   socket = new Socket(ip, port);
  } catch (Exception e) {
   e.printStackTrace();
   if (socket != null)
    socket.close();
   throw e;
  } finally {
  }
 }
 public void sendMessage(String sendMessage) throws Exception {
  try {
   out = new DataOutputStream(socket.getOutputStream());
   if (sendMessage.equals("Windows")) {
    out.writeByte(0x1);
    out.flush();
    return;
   }
   if (sendMessage.equals("Unix")) {
    out.writeByte(0x2);
    out.flush();
    return;
   }
   if (sendMessage.equals("Linux")) {
    out.writeByte(0x3);
    out.flush();
   } else {
    out.writeUTF(sendMessage);
    out.flush();
   }
  } catch (Exception e) {
   e.printStackTrace();
   if (out != null)
    out.close();
   throw e;
  } finally {
  }
 }
 public DataInputStream getMessageStream() throws Exception {
  try {
   getMessageStream = new DataInputStream(new BufferedInputStream(socket.getInputStream()));
   return getMessageStream;
  } catch (Exception e) {
   e.printStackTrace();
   if (getMessageStream != null)
    getMessageStream.close();
   throw e;
  } finally {
  }
 }
 public void shutDownConnection() {
  try {
   if (out != null)
    out.close();
   if (getMessageStream != null)
    getMessageStream.close();
   if (socket != null)
    socket.close();
  } catch (Exception e) {
  }
 }
}

3.客户端

package sterning;
import java.io.BufferedOutputStream;
import java.io.DataInputStream;
import java.io.DataOutputStream;
import java.io.FileOutputStream;
public class ClientTest {
 private ClientSocket cs = null;
 private String ip = "localhost";// 设置成服务器IP
 private int port = 8821;
 private String sendMessage = "Windwos";
 public ClientTest() {
  try {
   if (createConnection()) {
    sendMessage();
    getMessage();
   }
  } catch (Exception ex) {
   ex.printStackTrace();
  }
 }
 private boolean createConnection() {
  cs = new ClientSocket(ip, port);
  try {
   cs.CreateConnection();
   System.out.print("连接服务器成功!" + "\n");
   return true;
  } catch (Exception e) {
   System.out.print("连接服务器失败!" + "\n");
   return false;
  }
 }
 private void sendMessage() {
  if (cs == null)
   return;
  try {
   cs.sendMessage(sendMessage);
  } catch (Exception e) {
   System.out.print("发送消息失败!" + "\n");
  }
 }
 private void getMessage() {
  if (cs == null)
   return;
  DataInputStream inputStream = null;
  try {
   inputStream = cs.getMessageStream();
  } catch (Exception e) {
   System.out.print("接收消息缓存错误\n");
   return;
  }
  try {
   //本地保存路径,文件名会自动从服务器端继承而来。
   String savePath = "E:\\";
   int bufferSize = 8192;
   byte[] buf = new byte[bufferSize];
   int passedlen = 0;
   long len=0;
   savePath += inputStream.readUTF();
   DataOutputStream fileOut = new DataOutputStream(new BufferedOutputStream(new BufferedOutputStream(new FileOutputStream(savePath))));
   len = inputStream.readLong();
   System.out.println("文件的长度为:" + len + "\n");
   System.out.println("开始接收文件!" + "\n");
   while (true) {
    int read = 0;
    if (inputStream != null) {
     read = inputStream.read(buf);
    }
    passedlen += read;
    if (read == -1) {
     break;
    }
    //下面进度条本为图形界面的prograssBar做的,这里如果是打文件,可能会重复打印出一些相同的百分比
    System.out.println("文件接收了" + (passedlen * 100/ len) + "%\n");
    fileOut.write(buf, 0, read);
   }
   System.out.println("接收完成,文件存为" + savePath + "\n");
   fileOut.close();
  } catch (Exception e) {
   System.out.println("接收消息错误" + "\n");
   return;
  }
 }
 public static void main(String arg[]) {
  new ClientTest();
 }
}

希望本文所述对大家Java程序设计有所帮助。


推荐阅读
  • 优化联通光猫DNS服务器设置
    本文详细介绍了如何为联通光猫配置DNS服务器地址,以提高网络解析效率和访问体验。通过智能线路解析功能,域名解析可以根据访问者的IP来源和类型进行差异化处理,从而实现更优的网络性能。 ... [详细]
  • 1:有如下一段程序:packagea.b.c;publicclassTest{privatestaticinti0;publicintgetNext(){return ... [详细]
  • 如何配置Unturned服务器及其消息设置
    本文详细介绍了Unturned服务器的配置方法和消息设置技巧,帮助用户了解并优化服务器管理。同时,提供了关于云服务资源操作记录、远程登录设置以及文件传输的相关补充信息。 ... [详细]
  • 本文详细分析了Hive在启动过程中遇到的权限拒绝错误,并提供了多种解决方案,包括调整文件权限、用户组设置以及环境变量配置等。 ... [详细]
  • CentOS 7 磁盘与文件系统管理指南
    本文详细介绍了磁盘的基本结构、接口类型、分区管理以及文件系统格式化等内容,并提供了实际操作步骤,帮助读者更好地理解和掌握 CentOS 7 中的磁盘与文件系统管理。 ... [详细]
  • 本文详细介绍如何使用Python进行配置文件的读写操作,涵盖常见的配置文件格式(如INI、JSON、TOML和YAML),并提供具体的代码示例。 ... [详细]
  • 本周信息安全小组主要进行了CTF竞赛相关技能的学习,包括HTML和CSS的基础知识、逆向工程的初步探索以及整数溢出漏洞的学习。此外,还掌握了Linux命令行操作及互联网工作原理的基本概念。 ... [详细]
  • 解决Linux系统中pygraphviz安装问题
    本文探讨了在Linux环境下安装pygraphviz时遇到的常见问题,并提供了详细的解决方案和最佳实践。 ... [详细]
  • 本文介绍了一款用于自动化部署 Linux 服务的 Bash 脚本。该脚本不仅涵盖了基本的文件复制和目录创建,还处理了系统服务的配置和启动,确保在多种 Linux 发行版上都能顺利运行。 ... [详细]
  • CMake跨平台开发实践
    本文介绍如何使用CMake支持不同平台的代码编译。通过一个简单的示例,我们将展示如何编写CMakeLists.txt以适应Linux和Windows平台,并实现跨平台的函数调用。 ... [详细]
  • 在Linux系统中配置并启动ActiveMQ
    本文详细介绍了如何在Linux环境中安装和配置ActiveMQ,包括端口开放及防火墙设置。通过本文,您可以掌握完整的ActiveMQ部署流程,确保其在网络环境中正常运行。 ... [详细]
  • 本文深入探讨了Linux系统中网卡绑定(bonding)的七种工作模式。网卡绑定技术通过将多个物理网卡组合成一个逻辑网卡,实现网络冗余、带宽聚合和负载均衡,在生产环境中广泛应用。文章详细介绍了每种模式的特点、适用场景及配置方法。 ... [详细]
  • 本文详细介绍了如何在 Linux 平台上安装和配置 PostgreSQL 数据库。通过访问官方资源并遵循特定的操作步骤,用户可以在不同发行版(如 Ubuntu 和 Red Hat)上顺利完成 PostgreSQL 的安装。 ... [详细]
  • 掌握远程执行Linux脚本和命令的技巧
    本文将详细介绍如何利用Python的Paramiko库实现远程执行Linux脚本和命令,帮助读者快速掌握这一实用技能。通过具体的示例和详尽的解释,让初学者也能轻松上手。 ... [详细]
  • 本文探讨了如何优化和正确配置Kafka Streams应用程序以确保准确的状态存储查询。通过调整配置参数和代码逻辑,可以有效解决数据不一致的问题。 ... [详细]
author-avatar
犹豫的海波V5_697
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有