一种简易文件同步系统技术方案

技术编号:37588664 阅读:15 留言:0更新日期:2023-05-18 11:10
本申请涉及一种简易文件同步系统,所述简易文件同步系统包括桌面客户端和服务端,其中桌面客户端由MFC技术实现交互显示界面,由libcurl库提供发送和接收数据功能,服务端基于springboot和mybatis技术构建Java http服务器提供接收和发送数据字节流技术。用户可通过桌面客户端上传数据至服务端,且所有用户均可下载服务端数据,达到协同合作和文件同享的目的。本实施例所述的简易文件同步系统部署简单,适合在企业内部建立使用。适合在企业内部建立使用。适合在企业内部建立使用。

【技术实现步骤摘要】
一种简易文件同步系统


[0001]本申请涉及数据共享
,特别是涉及一种简易文件同步系统。

技术介绍

[0002]目前为解决多人协作和文件同步等问题,许多企业推出基于云端的商业解决方案,如坚果云、商业云同步等产品。但对于一些保密性要求高的企业或单位则无法使用该类商业产品进行数据同步。

技术实现思路

[0003]基于此,本申请的目的在于,提供一种简易文件同步系统,部署简单,适合在企业内部建立,可实现文件同步、协同工作。
[0004]本申请实施例公开了一种简易文件同步系统,包括:
[0005]桌面客户端,用于接收用户的上传操作并将用户选中的本地数据通过断点续传的方式上传至服务端,以及响应于用户的下载操作向所述服务端发送下载请求并接收所述服务端响应于所述下载请求而发送的共享数据;
[0006]服务端,用于接收所述桌面客户端上传的数据并保存进共享数据库,以及响应于所述桌面客户端发送的所述下载请求,获取所述共享数据库中的共享数据通过断点续传的方式发送至所述桌面客户端。
[0007]在一个实施例中,所述服务端基于springboot和mybatis技术构建,包括:用户注册接口、登陆服务端接口、查询文件层次信息接口、文件断点下载接口、文件断点上传接口;
[0008]所述桌面客户端基于libcurl库构建,包括:
[0009]登录模块,用于向所述服务端的用户注册接口发送用户的注册信息并接收所述服务端在注册成功时返回的提示信息,以及向所述服务端的登陆服务端接口发送登录信息,并接收所述服务端在连接成功时返回的token信息;
[0010]显示模块,用于访问所述服务端的查询文件层次信息接口,并接收所述服务端返回的所述共享数据库中所有用户的共享文件信息;将所有用户的文件信息基于MFC实现的目录树结构进行显示;
[0011]上传模块,用于向所述服务端的文件断点上传接口发送上传请求,所述上传请求包括所述token信息,并获取用户选定的本地文件通过断点续传的方式上传至所述服务端的文件断点上传接口;
[0012]下载模块,用于根据用户选中的所述显示模块显示的共享文件信息,向所述服务端的文件断点下载接口发送下载请求,所述下载请求包括所述token信息,并接收所述服务端响应于所述下载请求通过断点续传的方式返回的所述共享文件数据。
[0013]在一个实施例中,所述服务端还包括查询文件接口、子文件检索上传接口;
[0014]所述上传模块通过所述服务端的查询文件接口获取用户的上传文件在所述服务端中存储的相对位置rpath;获取用户选定的进行上传的本地文件的大小和文件名
filename,对所述本地文件通过断点续传的方式上传:
[0015]将所述本地文件以10M为一个子文件,划分为若干个子文件;
[0016]获取第N子文件进行上传,其中N=1,2,3...;
[0017]当发生网络中断时,向所述服务端的子文件检索上传接口发送网络中断检查指令,所述网络中断检查指令包括所述服务端存储的相对位置rpath、所述本地文件的文件名filename、上传文件状态和已上传子文件数量;其中所述服务端响应于所述网络中断检查指令,检查已接收的子文件大小是否为10M,若不为10M,则返回重传指令;
[0018]响应于所述服务端发送的重传指令,将近一次上传的子文件重新上传至所述服务端。
[0019]在一个实施例中,所述服务端还包括子文件合并接口;
[0020]所述服务端接收所述桌面客户端的上传模块上传的若干个子文件并保存在暂存区;接收所述上传模块发送的网络中断检查指令,当判断所述上传文件状态为已完成状态时,调用所述子文件合并接口合并所述桌面客户端上传的若干个子文件为一个文件,合并成功后删去所述暂存区的所述若干个子文件。
[0021]在一个实施例中,所述服务端还包括获取下载文件字节大小接口;
[0022]所述下载模块通过所述获取下载文件字节大小接口查询所述服务端中存储的所述用户选中的共享文件的大小remotefilesize,并获取本地文件大小localfilesize,通过所述文件断点下载接口接收所述服务端从range=localfilesize

remotefilesize

1范围进行字节传输的数据。
[0023]本申请实施例所述的简易文件同步系统包括桌面客户端和服务端,其中桌面客户端由MFC技术实现交互显示界面,显示存储在服务端中的共享数据的信息,由libcurl库提供发送和接收数据功能,将用户的本地数据进行上传以及接收服务端的共享数据;服务端基于springboot和mybatis技术构建Java http服务器提供接收和发送数据字节流技术。用户可通过桌面客户端上传数据至服务端,且所有用户均可下载服务端数据,达到协同合作和文件同享的目的。本实施例所述的简易文件同步系统部署简单,适合在企业内部建立使用。
[0024]为了更好地理解和实施,下面结合附图详细说明本申请。
附图说明
[0025]图1为本申请实施例的简易文件同步系统的示意图;
[0026]图2为本申请实施例的简易文件同步系统的应用场景图。
具体实施方式
[0027]请参考图1和图2,本申请实施例公开了一种简易文件同步系统,包括:
[0028]桌面客户端101,用于接收用户的上传操作并将用户选中的本地数据通过断点续传的方式上传至服务端102,以及响应于用户的下载操作向所述服务端102发送下载请求并接收所述服务端102响应于所述下载请求而发送的共享数据;
[0029]服务端102,用于接收所述桌面客户端101上传的数据并保存进共享数据库,以及响应于所述桌面客户端101发送的所述下载请求,获取所述共享数据库中的共享数据通过
断点续传的方式发送至所述桌面客户端101。
[0030]在一个实施例中,所述服务端102基于springboot和mybatis技术构建,包括:用户注册接口、登陆服务端接口、查询文件层次信息接口、文件断点下载接口、文件断点上传接口;
[0031]所述桌面客户端101基于libcurl库构建,包括:
[0032]登录模块,用于向所述服务端102的用户注册接口发送用户的注册信息并接收所述服务端102在注册成功时返回的提示信息,以及向所述服务端102的登陆服务端接口发送登录信息,并接收所述服务端102在连接成功时返回的token信息;
[0033]显示模块,用于访问所述服务端102的查询文件层次信息接口,并接收所述服务端102返回的所述共享数据库中所有用户的共享文件信息;将所有用户的文件信息基于MFC实现的目录树结构进行显示;
[0034]上传模块,用于向所述服务端102的文件断点上传接口发送上传请求,所述上传请求包括所述token信息,并获取用户选定的本地文件通过断点续传的方式上传至所述服务端102的文件断点本文档来自技高网
...

【技术保护点】

【技术特征摘要】
1.一种简易文件同步系统,其特征在于,包括:桌面客户端,用于接收用户的上传操作并将用户选中的本地数据通过断点续传的方式上传至服务端,以及响应于用户的下载操作向所述服务端发送下载请求并接收所述服务端响应于所述下载请求而发送的共享数据;服务端,用于接收所述桌面客户端上传的数据并保存进共享数据库,以及响应于所述桌面客户端发送的所述下载请求,获取所述共享数据库中的共享数据通过断点续传的方式发送至所述桌面客户端。2.根据权利要求1所述的简易文件同步系统,其特征在于,所述服务端基于springboot和mybatis技术构建,包括:用户注册接口、登陆服务端接口、查询文件层次信息接口、文件断点下载接口、文件断点上传接口;所述桌面客户端基于libcurl库构建,包括:登录模块,用于向所述服务端的用户注册接口发送用户的注册信息并接收所述服务端在注册成功时返回的提示信息,以及向所述服务端的登陆服务端接口发送登录信息,并接收所述服务端在连接成功时返回的token信息;显示模块,用于访问所述服务端的查询文件层次信息接口,并接收所述服务端返回的所述共享数据库中所有用户的共享文件信息;将所有用户的共享文件信息基于MFC实现的目录树结构进行显示;上传模块,用于向所述服务端的文件断点上传接口发送上传请求,所述上传请求包括所述token信息,并获取用户选定的本地文件通过断点续传的方式上传至所述服务端的文件断点上传接口;下载模块,用于根据用户选中的所述显示模块显示的共享文件信息,向所述服务端的文件断点下载接口发送下载请求,所述下载请求包括所述token信息,并接收所述服务端响应于所述下载请求通过断点续传的方式返回的所述共享文件数据。3.根据权利要求2所述的简易文件同步系统,其特征在于,所述服务端还包括查询文件接口、子文件检索上传接口;...

【专利技术属性】
技术研发人员:李勇潘屹峰黄吴蒙赵晓丹林良培
申请(专利权)人:佛山中科云图智能科技有限公司
类型:发明
国别省市:

网友询问留言 已有0条评论
  • 还没有人留言评论。发表了对其他浏览者有用的留言会获得科技券。

1