最近老师给我们上了多线程和TCP和UDP协议,其中一个要求就是我们用JAVA协议一个基于TCP和UDP这两种协议的一对一文件上传和一对多文件上传。

然后我就开始分析TCP和UDP这两个协议的特点,发现TCP是流传输,抓住这一点就好实现了。

现在我们需要解决一下几个问题,

1.如何确定文件名称

2.如何完成数据传输,并复原成原来的文件。

解决方案就是,对象这是个好东西,因为TCP支持流传输的缘故,我们把每个文件对象化,这样我们就很容易实现基于TCP的多文件上传了。

下面是文件对象代码:

因为我考虑到了以后移植到web端也可以用,所以我添加了源地址这一栏。

其中需要注意的就是,我们需要对文件对象进行序列化。这是一种处理对象流的机制。原理的话网上很多。

下面是TCP的配置实体类

到时候如果要放在服务器上只需要修改conAddr既可。

下面是TCPSocket端的代码

单独剥离出来的原因,主要是我希望能尽可能不让开发人员介入底层配置只需要填空即可。后面我还会对这个再一次封装。

package com.org.gjt.WebSocket.work1;

import com.org.gjt.WebSocket.work1.entity.TCPsetting;

import java.io.IOException;
import java.net.Socket; /**
* @author gjt
* @version 1.0
* @Title: tcpSocketClient
* @date 2018/5/24/11:10
*/
public class TcpSocketClient {
/**
* 建立socket连接
* @return
*/
public Socket ConnectTcpClient(){
Socket clientSocket = null;
/**
* 建立socket连接
*/
try {
clientSocket = new Socket(TCPsetting.conAddr,TCPsetting.port);
} catch (Exception e) {
e.printStackTrace();
}
return clientSocket;
} /**
* 关闭连接
* @param socket
*/
public void Close(Socket socket){
try {
socket.close();
System.out.println("关闭成功!");
} catch (IOException e) {
e.printStackTrace();
}
}
}

下面是TCP协议的Client端

TCPserver端

package com.org.gjt.WebSocket.work1;

import com.org.gjt.WebSocket.utils.FileUtils;
import com.org.gjt.WebSocket.work1.entity.FileSetting;
import com.org.gjt.WebSocket.work1.entity.TCPsetting; import java.io.*;
import java.net.ServerSocket;
import java.net.Socket; /**
* @author gjt
* @version 1.0
* @Title: 一对一上次:服务端
* @date 2018/5/24/16:55
*/
public class TCPSingleServer { /**
* 启动文件工具类
*/
private static FileUtils fileUtils = new FileUtils();
/**
* 接受传输过来的对象
*/
private static FileSetting fileSetting = new FileSetting(); private static void StartService() throws Exception {
Object obj = null;
ServerSocket serverSocket = new ServerSocket(TCPsetting.port);
System.out.println("服务器启动,等待客户端的连接。。。");
Socket socket = serverSocket.accept();
OutputStream os = null;
PrintWriter pw = null;
InputStream is = socket.getInputStream();
ObjectInputStream ois=new ObjectInputStream(is);
obj = ois.readObject();
if (obj != null){
System.out.println("接收到来自["+socket.getInetAddress().getHostAddress()+"]的文件");
fileSetting = (FileSetting) obj;
/**
* 开始存储工作
*/
File dir = new File("E:\\"+socket.getInetAddress().getHostAddress());
if(!dir.exists()){
dir.mkdir();
}
File file = new File(dir, socket.getInetAddress().getHostAddress()+fileSetting.getFileName());
/**
* 获取base64流转为指定文件
*/
String stream = fileSetting.getStream();
fileUtils.decryptByBase64(stream,file.getPath());
System.out.println("保存成功");
}
os=socket.getOutputStream();
pw=new PrintWriter(os);
pw.println("传输完成!");
pw.flush();
socket.shutdownOutput();
if(pw!=null){
pw.close();
}
if(os!=null){
os.close();
}
if(socket!=null){
socket.close();
}
} public static void main(String[] args) {
try {
StartService();
} catch (Exception e) {
e.printStackTrace();
}
}
}

这是基本代码,实现基于TCP的文件上传。

修改成一对多也很简单,之后我会把两个版本的代码上传到我的github上去,有想法的大佬可以下载下来试试。

关于修改成多文件上传,只需要在原来传输对象基础上修改成对象列表即可。

git链接:点击打开代码

  这是我的微信公众号,会不定时分享学习知识。

JAVA 基于TCP协议的一对一,一对多文件传输实现的更多相关文章

  1. 基于Tcp协议的简单Socket通信实例(JAVA)

    好久没写博客了,前段时间忙于做项目,耽误了些时间,今天开始继续写起~ 今天来讲下关于Socket通信的简单应用,关于什么是Socket以及一些网络编程的基础,这里就不提了,只记录最简单易懂实用的东西. ...

  2. 网络编程——基于TCP协议的Socket编程,基于UDP协议的Socket编程

    Socket编程 目前较为流行的网络编程模型是客户机/服务器通信模式 客户进程向服务器进程发出要求某种服务的请求,服务器进程响应该请求.如图所示,通常,一个服务器进程会同时为多个客户端进程服务,图中服 ...

  3. 基于TCP协议的网络通信

    TCP/IP通信协议是一种可靠的网络协议,它在通信的两端各建立一个Socket,从而在通信的两端之间形成网络虚拟链路,一旦建立了虚拟的网络链路,两端的程序就可以通过虚拟链路进行通信.Java对基于TC ...

  4. 基于TCP协议的客户端

    基于TCP协议的客户端 此客户端能用于下一篇博客的单线程服务器和多线程服务器 import java.io.BufferedReader; import java.io.IOException; im ...

  5. 网络编程应用:基于TCP协议【实现对象传输】--练习

    要求: 基于TCP协议实现,客服端向服务器发送一个对象 服务器接受并显示用户信息 ,同时返回给客户端 "数据已收到" 建一个Student类,属性:name age Student ...

  6. 网络编程应用:基于TCP协议【实现文件上传】--练习

    要求: 基于TCP协议实现一个向服务器端上传文件的功能 客户端代码: package Homework2; import java.io.File; import java.io.FileInputS ...

  7. 网络编程应用:基于TCP协议【实现一个聊天程序】

    要求: 基于TCP协议实现一个聊天程序,客户端发送一条数据,服务器端发送一条数据 客户端代码: package Homework1; import java.io.IOException; impor ...

  8. 基于TCP 协议的RPC

    前言: 环境: windown 10 Eclipse JDK 1.8 RPC的概念: RPC 是远程过程调用,是分布式网站的基础. 实验 SayHelloService.java 接口类,用于规范 S ...

  9. (1)线程的同步机制 (2)网络编程的常识 (3)基于tcp协议的编程模型

    1.线程的同步机制(重点)1.1 基本概念 当多个线程同时访问同一种共享资源时可能会造成数据的覆盖和不一致等问题,此时就需要对线程之间进行协调和通信,该方式就叫线程的同步机制. 如: 2003年左右 ...

随机推荐

  1. MySQL批量更新一个字段的值为随机数

    $arr = []; $str = ''; for ($i=0; $i < 2660; ++$i) { $str .= " WHEN ".$i." THEN &qu ...

  2. asp.net core 系列之Startup

    这篇文章简单记录 ASP.NET Core中 ,startup类的一些使用. 一.前言 在 Startup类中,一般有两个方法: ConfigureServices 方法: 用来配置应用的 servi ...

  3. 给 Windows 的终端配置代理

    初衷 由于项目开发使用go,所以经常要用到go get,但是吧,terminal下根本没办法下载啊,经常下载三个小时包,写代码一个小时 迫于无奈,只好找个方式可以在terminal下使用ss cmd下 ...

  4. .NET开发框架(四)-服务器IIS安装教程

    Windows Server 2012 R2 配置篇,包括服务器IIS安装.网络负载均衡器安装.ASP.NET Core 安装. 前三篇教程中,我们分享了框架的功能与视频演示介绍(文尾扫码 加入 框架 ...

  5. 1.谈谈对Java平台的理解

    1.谈谈你对Java平台的理解 Java 本身是一种面向对象的语言,最显著的特性有两个方面,一是所谓的“一次编译,到处运行”(Compile once,run anywhere),能够非常容易地获取跨 ...

  6. 数据结构与算法---查找算法(Search Algorithm)

    查找算法介绍 在java中,我们常用的查找有四种: 顺序(线性)查找 二分查找/折半查找 插值查找 斐波那契查找 1)线性查找算法 示例: 有一个数列: {1,8, 10, 89, 1000, 123 ...

  7. white box白盒测试

    逻辑覆盖法:语句覆盖,判定覆盖,条件覆盖,判定/条件覆盖,组合覆盖,路径覆盖 基本路径测试法:Control Flow Graphs, CFG.带箭头的边 条件覆盖:使每个判定中每个条件的可能值至少满 ...

  8. MYSQL事务之Yii2.0商户提现

    我是一个半路出家的PHP程序员,到目前为止,不算在培训班学习的时间,已经写代码整整两年了.可能由于工作业务的原因,在这两年中我没有用到过MySQL事务.就在昨天有个关于支付宝转账的业务不得不使用MyS ...

  9. python工具函数

    1. translate translate要比replace要高效,translate支持替换多 使用translate之前必须要创建一个转换表.要创建转换表,可对字符串类型str调用方法maket ...

  10. Codeforces 778A:String Game(二分暴力)

    http://codeforces.com/problemset/problem/778/A 题意:给出字符串s和字符串p,还有n个位置,每一个位置代表删除s串中的第i个字符,问最多可以删除多少个字符 ...