CN102231742B - 基于sftp协议的文件上传与下载方法、系统及相关设备 - Google Patents

基于sftp协议的文件上传与下载方法、系统及相关设备 Download PDF

Info

Publication number
CN102231742B
CN102231742B CN201110180715.6A CN201110180715A CN102231742B CN 102231742 B CN102231742 B CN 102231742B CN 201110180715 A CN201110180715 A CN 201110180715A CN 102231742 B CN102231742 B CN 102231742B
Authority
CN
China
Prior art keywords
file
server
client
threshold value
flow control
Prior art date
Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
Active
Application number
CN201110180715.6A
Other languages
English (en)
Other versions
CN102231742A (zh
Inventor
毛霁旻
周子坚
胡宏
杜永健
杨志勇
Current Assignee (The listed assignees may be inaccurate. Google has not performed a legal analysis and makes no representation or warranty as to the accuracy of the list.)
China Construction Bank Corp
Original Assignee
China Construction Bank Corp
Priority date (The priority date is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the date listed.)
Filing date
Publication date
Application filed by China Construction Bank Corp filed Critical China Construction Bank Corp
Priority to CN201110180715.6A priority Critical patent/CN102231742B/zh
Publication of CN102231742A publication Critical patent/CN102231742A/zh
Application granted granted Critical
Publication of CN102231742B publication Critical patent/CN102231742B/zh
Active legal-status Critical Current
Anticipated expiration legal-status Critical

Links

Landscapes

  • Information Transfer Between Computers (AREA)

Abstract

本发明公开一种基于SFTP协议的文件上传与下载方法,其中,文件上传方法包括客户端从服务器中读取预置参数,所述预置参数包括上传路径、服务器IP、端口、用户名和密码;客户端根据待上传文件的文件名和所述预置参数,按照SFTP协议将所述待上传文件发送至所述服务器。文件下载方法包括客户端从服务器中读取预置参数,所述预置参数包括下载路径、服务器IP、端口、用户名和密码;客户端根据服务器的待下载文件的文件名和所述预置参数,按照SFTP协议从所述服务器接收所述待下载文件。相应地,本发明还公开一种客户端和服务器。本发明通过预先存储预置参数,然后根据该预置参数进行文件传输,无需手动操作本地磁盘目录,提高客户端与服务器的安全性和稳定性。

Description

基于SFTP协议的文件上传与下载方法、系统及相关设备
技术领域
本发明涉及通信技术领域,尤其涉及一种基于SFTP协议(Secure FileTransfer Protocol,安全文件传输协议)的文件上传与下载方法、系统及相关设备。
背景技术
目前,银行的业务人员在处理各项业务的过程中,通常会在银行的客户端产生与这些业务相应的文件,并且,这些文件需要上传到银行的服务器进一步处理。相应地,由于业务上的需要,业务人员有时也会从服务器下载一些文件到客户端上。因此,需要在银行的服务器与客户端之间实现文件传输的功能。
但是,在现有的技术中,银行的服务器与客户端之间通常都是基于WEB的方式来实现文件传输。客户端上传文件至服务器通常是通过HTML自带的<FILE/>标签来完成,而客户端从服务器下载文件通常是通过“文件另存为”的方式来实现。上述这种实现文件传输的方式具有如下缺点:
1、上传或下载文件时,需要用户手动指定上传文件路径或下载目录,额外增加操作工序,降低处理速度。
2、上传或下载文件时,手动指定上传文件路径或下载目录,可能会暴露更多的本地磁盘信息,或者可能会由于误操作而破坏了客户端或服务器的运行环境,为系统的安全和稳定带来隐患。
发明内容
本发明的目的在于:提供一种基于SFTP协议的文件上传与下载方法、系统及相关设备,用于按照预设的路径自动上传或下载文件。
一方面,本发明提供了一种基于SFTP协议的文件上传方法,所述文件上传方法包括:
客户端从服务器中读取预置参数,所述预置参数包括上传路径、服务器IP、端口、用户名和密码;
客户端根据待上传文件的文件名和所述预置参数,按照SFTP协议将所述待上传文件发送至所述服务器。
另一方面,本发明还提供了一种基于SFTP协议的文件下载方法,所述文件下载方法包括:
客户端从服务器中读取预置参数,所述预置参数包括下载路径、服务器IP、端口、用户名和密码;
客户端根据服务器的待下载文件的文件名和所述预置参数,按照SFTP协议从所述服务器接收所述待下载文件。
相应地,本发明还提供了一种基于SFTP协议的文件传输系统,所述文件传输系统包括客户端和服务器,其中,
所述客户端包括:
预置参数读取模块,用于从服务器中读取预置参数,所述预置参数包括上传路径、下载路径、服务器IP、端口、用户名和密码;
客户端文件传输模块,用于根据待上传文件的文件名和所述预置参数,按照SFTP协议将所述待上传文件发送至所述服务器,或者根据服务器的待下载文件的文件名和所述预置参数,按照SFTP协议从所述服务器接收所述待下载文件。
所述服务器包括:
预置参数存储模块,用于预先存储预置参数,所述预置参数包括上传路径、下载路径、服务器IP、端口、用户名和密码;
服务器文件传输模块,用于从客户端接收待上传文件,或者用于向客户端发送待下载文件。
实施本发明的一种基于SFTP协议的文件上传与下载方法、系统及相关设备具有如下有益效果:通过读取预先存储的包括上传和下载路径的预置参数,然后根据该预置参数与服务器进行文件传输,可以实现文件传输路径的自动识别,消除因手动操作本地磁盘目录带来的安全隐患。
附图说明
图1示出本发明的基于SFTP协议的文件上传方法的实施例1;
图2示出本发明的基于SFTP协议的文件上传方法的实施例2;
图3示出本发明的基于SFTP协议的文件下载方法的实施例1;
图4示出本发明的基于SFTP协议的文件下载方法的实施例2;
图5是本发明的一种基于SFTP协议的文件传输系统的结构示意图;
图6是本发明的文件传输系统中客户端1的结构示意图;
图7是客户端1中客户端文件校验模块14的结构示意图;
图8是本发明的文件传输系统中服务器2的结构示意图;
图9是服务器2中服务器文件校验模块23的结构示意图。
具体实施方式
为使本发明的实施例的目的、技术方案和优点更加清楚,下面进一步结合附图对本发明作详细描述。
图1示出本发明的基于SFTP协议的文件上传方法的实施例1。如图1所示,在实施例1中,所述文件上传方法包括:
S101,客户端从服务器中读取预置参数,所述预置参数包括上传路径、服务器IP、端口、用户名和密码。其中,所述预置参数是由技术人员预先存储在所述服务器中,在本发明实施例中,技术人员也可以在需要时对服务器中的预置参数进行修改。
S102,客户端根据待上传文件的文件名和所述预置参数,按照SFTP协议将所述待上传文件发送至所述服务器。此处,因为SFTP协议的有关内容为本领域技术人员所熟知,所以,关于按照SFTP协议将待上传文件发送至服务器的详细内容不再赘述,下文中如若遇到相同的技术内容,同样不再赘述。
可见,实施例1通过读取预置参数,并根据该预置参数上传文件,可以避免在上传文件时手动选择上传文件路径,既能减少操作工序,也能避免因手动操作而带来的各种隐患。
图2示出本发明的基于SFTP协议的文件上传方法的实施例2。在实施例2中,所述文件上传方法包括:
S201,客户端从服务器中读取预置参数,所述预置参数包括上传路径、服务器IP、端口、用户名和密码。其中,所述预置参数是由技术人员预先存储在服务器中,在本发明实施例中,技术人员也可以在需要时对服务器中的预置参数进行修改。
S202,客户端根据待上传文件的文件名和所述预置参数,按照SFTP协议将待上传文件发送至服务器。
S203,服务器读取所述客户端对应的用户流控阈值和IP流控阈值。其中,所述用户流控阈值是由技术人员预先存储在服务器中,IP流控阈值是由技术人员根据实际情况设置。在现有技术中,仅使用用户流控的方式往往会给操作带来不便,例如,当用户数量庞大且用户种类繁多时,很难实现为每一个用户都分配流量。而采用本发明的将用户流控和IP流控相结合的方式,可以在不同的情况下更加灵活地实现流控。例如在本发明实施例中,可以通过用户流控阈值为客户端设置流量上限,然后再根据实际情况通过IP流控阈值为客户端设置实际流量,从而更好地实现流控。
S204,服务器判断所述IP流控阈值是否大于用户流控阈值,当判断出IP流控阈值小于用户流控阈值时,则执行S205,当判断出IP流控阈值大于用户流控阈值时,则执行S206。
S205,服务器按照所述IP流控阈值接收待上传文件,然后执行S207。例如,所述客户端的用户流控阈值为100kb/s,设置的IP流控阈值为200kb/s,则服务器按照阈值小的用户流控阈值来接收文件,从而实现更好的流量控制。
S206,服务器按照所述用户流控阈值接收待上传文件,然后执行S207。
S207,服务器根据接收到的上传文件生成服务器MD5(Message DigestAlgorithm 5,消息摘要算法第5版)文件,并向客户端发送返回消息,所述返回消息表示服务器MD5文件已生成。MD5文件是指通过MD5算法生成的文件。
S208,客户端根据所述返回消息,向服务器发送下载服务器MD5文件的请求消息。
S209,服务器根据所述请求消息将所述服务器MD5文件发送至客户端。此处需要说明的是,服务器发送MD5文件之后,不会再生成相应的MD5文件。
S210,客户端接收所述服务器MD5文件之后,比较服务器MD5文件和客户端MD5文件是否相等,当服务器MD5文件与客户端MD5文件相等时,则执行S211,当服务器MD5文件与客户端MD5文件不相等时,则执行S212。
S211,指示用户文件上传成功。
S212,指示用户文件上传失败,此时,由用户决定是否重新上传。
可见,生成MD5文件可以用于校验数据的完整性,具体而言,如果在上传的过程中出现错误,导致服务器接收到的文件与客户端发送的文件不一致,则服务器生成的MD5文件与客户端生成的MD5文件也不一致,此时文件上传失败,由用户决定是否重传。
在另一种实施方式中,在客户端读取预置参数之后并且在将待上传文件发送至服务器之前,所述文件上传方法还可包括客户端根据待上传文件的文件名对待上传文件打包,例如,TAR打包。通过文件打包,可以提高文件的上传速度。此外,如果上传多个文件,用户手动选择文件依次上传会耗费不必要的时间,而通过文件打包,则可以一次性上传多个文件,提高效率。
以上是对本发明的文件上传方法的描述,接下来结合图3和图4详细描述本发明的一种基于SFTP协议的文件下载方法。
下载文件与上传文件是两个相对的文件传输过程。具体而言,如图3所示,基于SFTP协议的文件下载方法包括:
S301,客户端从服务器中读取预置参数,所述预置参数包括下载路径、服务器IP、端口、用户名和密码。其中,所述预置参数是由技术人员预先存储在服务器中,在本发明实施例中,技术人员也可以在需要时对服务器中的预置参数进行修改。
S302,客户端根据服务器的待下载文件的文件名和所述预置参数,按照SFTP协议从服务器接收待下载文件。
可见,实施例3通过读取预置参数,并根据该预置参数下载文件,可以避免在下载文件时手动选择下载目录,既能减少操作工序,也能避免因手动操作而带来的各种隐患。
图4示出本发明的基于SFTP协议的文件下载方法的实施例2。在该实施例2中,所述文件下载方法包括:
S401,服务器读取客户端对应的用户流控阈值和IP流控阈值。其中,所述用户流控阈值是由技术人员预先存储在服务器中,IP流控阈值是由技术人员根据实际情况设置。
S402,服务器判断所述IP流控阈值是否大于用户流控阈值,当判断出IP流控阈值小于用户流控阈值时,则执行S403,当判断出IP流控阈值大于用户流控阈值时,则执行S404。
S403,服务器按照所述IP流控阈值将所述待下载文件发送至客户端,然后执行S405。例如,所述客户端对应的用户流控阈值为100kb/s,设置的IP流控阈值为200kb/s,则服务器按照阈值小的用户流控阈值来发送文件,从而实现更好的流量控制。
S404,服务器按照所述用户流控阈值将所述待下载文件发送至客户端,然后执行S405。
S405,客户端从服务器中读取预置参数,所述预置参数包括下载路径、服务器IP、端口、用户名和密码。其中,所述预置参数是由技术人员预先存储在服务器中,在本发明实施例中,技术人员也可以在需要时对服务器中的预置参数进行修改。
S406,客户端根据服务器的待下载文件的文件名和所述预置参数,按照SFTP协议从服务器接收所述待下载文件。
S407,服务器根据发送给客户端的待下载文件生成服务器MD5文件,并向客户端发送返回消息,所述返回消息表示服务器MD5文件已生成。MD5文件是指通过MD5算法生成的文件。此处需要说明的是,在步骤S406中,客户端接收到待下载文件之后,可以向服务器发送表示文件已经接收到的响应消息,然后,服务器根据该响应消息执行步骤S407。
S408,客户端根据所述返回消息,向服务器发送下载服务器MD5文件的请求消息。
S409,服务器根据所述请求消息将所述服务器MD5文件发送至客户端。
S410,客户端接收所述服务器MD5文件之后,比较服务器MD5文件和客户端MD5文件是否相等,当服务器MD5文件与客户端MD5文件相等时,则执行S411,当服务器MD5文件与客户端MD5文件不相等时,则执行S412。
S411,指示用户文件下载成功。
S412,指示用户文件下载失败,此时,由用户决定是否重新下载。
可见,生成MD5文件可以用于校验数据的完整性,具体而言,如果在下载的过程中出现错误,导致服务器接收到的文件与客户端发送的文件不一致,则服务器生成的MD5文件与客户端生成的MD5文件也不一致,此时文件下载失败,由用户决定是否重新下载。
在另一种实施方式中,如果客户端下载到的文件是打包文件,例如TAR打包文件,则客户端在成功下载文件之后,所述文件下载方法还可包括客户端根据待下载文件的文件名对接收到的下载文件解包,例如TAR解包。
以上是对本发明方法的详细描述,下面将结合图5-图9分别介绍本发明的系统。
图5是本发明的一种基于SFTP协议的文件传输系统的结构示意图。如图5所示,所述文件传输系统包括客户端1和服务器2,客户端1和服务器2通过网络连接并实现文件的传输。
具体而言,客户端1的结构如图6所示,客户端1包括预置参数读取模块10、客户端文件传输模块11、文件打包模块12、文件解包模块13和客户端文件校验模块14。其中,
预置参数读取模块10,用于从服务器2中读取预置参数,所述预置参数包括上传路径、下载路径、服务器IP、端口、用户名和密码。
客户端文件传输模块11,用于根据待上传文件的文件名和所述预置参数,按照SFTP协议将所述待上传文件发送至服务器2,或者根据服务器2的待下载文件的文件名和所述预置参数,按照SFTP协议从服务器2接收所述待下载文件。
文件打包模块12,用于根据待上传文件的文件名对客户端文件传输模块11待上传的文件打包。在一种实施方式中,客户端1在读取预置参数之后并且在将待上传文件发送至服务器2之前,可以根据待上传文件的文件名对待上传文件打包,例如,TAR打包。通过文件打包,可以提高文件的上传速度,并且可以一次性上传多个文件,提高效率。
文件解包模块13,用于根据待下载文件的文件名对客户端文件传输模块11接收到的下载文件解包。如果客户端1下载到的文件是打包文件,例如TAR打包文件,则客户端1在成功下载文件之后,还要根据待下载文件的文件名对接收到的下载文件解包,例如TAR解包。
客户端文件校验模块14,用于对上传或下载后的文件进行文件校验。
具体地,如图7所示,客户端文件校验模块14包括第一接收单元140、第一发送单元141、第二接收单元142、客户端MD5文件生成单元143、比较单元144和传输结果指示单元145。其中,
第一接收单元140,用于接收服务器2发送的返回消息,所述返回消息表示服务器MD5文件已生成。MD5文件是指通过MD5算法生成的文件。
第一发送单元141,用于根据第一接收单元140接收的返回消息,向服务器2发送下载所述服务器MD5文件的请求消息。
第二接收单元142,用于接收来自服务器2的服务器MD5文件。
客户端MD5文件生成单元143,用于根据客户端文件传输模块11向服务器2发送的待上传文件生成客户端MD5文件,或者用于根据客户端文件传输模块11接收到的下载文件生成客户端MD5文件。
比较单元144,用于比较所述服务器MD5文件和客户端MD5文件是否相等。
传输结果指示单元145,用于当比较单元144比较出所述服务器MD5文件与客户端MD5文件相等时,指示用户文件上传或下载成功,或者用于当比较单元144比较出所述服务器MD5文件与客户端MD5文件不相等时,指示用户文件上传或下载失败。可见,生成MD5文件可以用于校验数据的完整性,具体而言,如果在上传的过程中出现错误,导致服务器接收到的文件与客户端发送的文件不一致,则服务器生成的MD5文件与客户端生成的MD5文件也不一致,此时文件上传失败,由用户决定是否重传。
图8是本发明的文件传输系统中服务器2的结构示意图。如图8所示,服务器2包括预置参数存储模块20、流量控制模块21、服务器文件传输模块22和服务器文件校验模块23。其中,
预置参数存储模块20,用于预先存储预置参数,所述预置参数包括上传路径、下载路径、服务器IP、端口、用户名和密码。其中,所述预置参数是由技术人员预先存储在服务器2中,在本发明实施例中,技术人员也可以在需要时对服务器2中的预置参数进行修改。
流量控制模块21,用于在文件传输过程中实现流量控制,其包括:阈值存储单元210、阈值设置单元211、阈值读取单元212和阈值判断单元213。其中,
阈值存储单元210,用于预先存储用户流控阈值。
阈值设置单元211,用于设置客户端对应的IP流控阈值。
阈值读取单元212,用于从阈值存储单元210和阈值设置单元211中读取用户流控阈值和IP流控阈值。
阈值判断单元213,用于判断所述IP流控阈值是否大于用户流控阈值。
通过将用户流控和IP流控相结合的方式,可以在不同的情况下更加灵活地实现流控。
服务器文件传输模块22,用于根据所述预置参数从客户端1接收待上传文件,或者用于根据所述预置参数向客户端1发送待下载文件。具体地,服务器文件传输模块22包括发送单元220和接收单元221。其中,
发送单元220,用于当阈值判断单元212判断出用户流控阈值小于IP流控阈值时,则按照所述用户流控阈值将待下载文件发送至客户端1,或者用于当阈值判断单元212判断出用户流控阈值大于IP流控阈值时,则按照所述IP流控阈值将待下载文件发送至客户端1。例如,用户流控阈值为100kb/s,IP流控阈值为200kb/s,则发送单元220按照阈值小的用户流控阈值来发送文件,从而实现更好的流量控制。
接收单元221,用于当阈值比较单元212比较出用户流控阈值小于IP流控阈值时,则按照所述用户流控阈值从客户端1接收待上传文件,或者用于当阈值比较单元212比较出IP流控阈值小于用户流控阈值时,则按照所述IP流控阈值从客户端1接收待上传文件。
服务器文件校验模块23,用于对上传或下载后的文件进行文件校验。
具体地,如图9所示,服务器文件校验模块23包括服务器MD5文件生成单元230、第二发送单元231、第三接收单元232和第三发送单元233。其中,
服务器MD5文件生成单元230,用于根据服务器文件传输模块22接收到的上传文件生成服务器MD5文件,或者根据服务器文件传输模块22发送给客户端1的待下载文件生成服务器MD5文件。在本发明实施例中,客户端1接收到待下载文件之后,可以向服务器2发送表示文件已经接收到的响应消息,然后,服务器在根据该响应消息由服务器MD5文件生成单元230生成服务器MD5文件。
第二发送单元231,用于在服务器MD5文件生成单元生成MD5文件之后,向客户端1发送返回消息,所述返回消息表示服务器MD5文件已生成。
第三接收单元232,用于接收来自客户端1的下载服务器MD5文件的请求消息。
第三发送单元233,用于根据第三接收单元232接收到的请求消息,将所述MD5文件发送至客户端1。
综上所述,本发明通过由客户端读取预先存储在服务器中的包括上传和下载路径的预置参数,然后根据该预置参数与服务器进行文件传输,从而避免手动指定上传或下载文件路径,从而提高业务人员的处理速度,并且可以消除因手动操作本地磁盘目录带来的安全隐患,更好地保护客户端或服务器的运行环境。
通过对以上实施方式的描述,本领域的技术人员可以清楚地了解到本发明可借助软件结合硬件平台的方式来实现,当然也可以全部通过硬件来实施。基于这样的理解,本发明的技术方案对背景技术做出贡献的全部或者部分可以以软件产品的形式体现出来,该计算机软件产品可以存储在存储介质中,如ROM/RAM、磁碟、光盘等,包括若干指令用以使得一台计算机设备(可以是个人计算机,服务器,或者网络设备等)执行本发明各个实施例或者实施例的某些部分所述的方法。
以上所公开的仅为本发明的具体实施方式,仅用于对本发明进行举例说明,不能以此限定本发明之保护范围,本领域技术人员在不脱离本发明实质的前提下可以进行各种修改、变化或替换,因此,依照本发明所作的各种等同变化,仍属于本发明所涵盖的范围。

Claims (11)

1.一种基于SFTP协议的文件上传方法,其特征在于,所述文件上传方法包括:
客户端从服务器中读取预置参数,所述预置参数包括上传路径、服务器IP、端口、用户名和密码,所述预置参数预先存储在所述服务器中;
客户端根据待上传文件的文件名和所述预置参数,按照SFTP协议将所述待上传文件发送至所述服务器;
其中,在所述客户端将待上传文件发送至服务器之后,所述文件上传方法还包括:
所述服务器读取所述客户端对应的用户流控阈值和IP流控阈值,
判断所述IP流控阈值是否大于用户流控阈值,
当判断出IP流控阈值小于用户流控阈值时,则按照所述IP流控阈值接收所述待上传文件,
当判断出IP流控阈值大于用户流控阈值时,则按照所述用户流控阈值接收所述待上传文件。
2.根据权利要求1所述的文件上传方法,其特征在于,在所述客户端读取预置参数之后并且在将待上传文件发送至服务器之前,所述文件上传方法还包括:
所述客户端根据待上传文件的文件名对待上传文件打包。
3.根据权利要求1所述的文件上传方法,其特征在于,在所述服务器接收待上传文件之后,所述文件上传方法还包括:
所述服务器根据接收到的上传文件生成服务器MD5文件,并向所述客户端发送返回消息,所述返回消息表示服务器MD5文件已生成;
所述客户端根据所述返回消息,向所述服务器发送下载服务器MD5文件的请求消息;
所述服务器根据所述请求消息将所述服务器MD5文件发送至所述客户端;
所述客户端接收所述服务器MD5文件之后,根据向服务器发送的待上传文件生成客户端MD5文件;
所述客户端比较所述服务器MD5文件和客户端MD5文件是否相等,
当所述服务器MD5文件与客户端MD5文件相等时,则提示用户文件上传成功,
当所述服务器MD5文件与客户端MD5文件不相等时,则提示用户文件上传失败。
4.一种基于SFTP协议的文件下载方法,其特征在于,所述文件下载方法包括:
客户端从服务器中读取预置参数,所述预置参数包括下载路径、服务器IP、端口、用户名和密码,所述预置参数预先存储在所述服务器中;
客户端根据服务器的待下载文件的文件名和所述预置参数,按照SFTP协议从所述服务器接收所述待下载文件;
其中,在所述客户端读取预置参数之后并且在从服务器接收所述待下载文件之前,所述文件下载方法还包括:
所述服务器读取所述客户端对应的用户流控阈值和IP流控阈值;
判断所述IP流控阈值是否大于用户流控阈值,
当判断出IP流控阈值小于用户流控阈值时,则按照所述IP流控阈值将所述待下载文件发送至所述客户端,
当判断出IP流控阈值大于用户流控阈值时,则按照所述用户流控阈值将所述待下载文件发送至所述客户端。
5.根据权利要求4所述的文件下载方法,其特征在于,在所述客户端从服务器接收待下载文件之后,所述文件下载方法还包括:
所述服务器根据所述发送给客户端的待下载文件生成服务器MD5文件,并向所述客户端发送返回消息,所述返回消息表示服务器MD5文件已生成;
所述客户端根据所述返回消息,向所述服务器发送下载服务器MD5文件的请求消息;
所述服务器根据所述请求消息将所述服务器MD5文件发送至所述客户端;
所述客户端接收所述服务器MD5文件之后,根据接收到的下载文件生成客户端MD5文件;
所述客户端比较所述服务器MD5文件和客户端MD5文件是否相等,
当所述服务器MD5文件与客户端MD5文件相等时,则提示用户文件下载成功,
当所述服务器MD5文件与客户端MD5文件不相等时,则提示用户文件下载失败。
6.根据权利要求5所述的文件下载方法,其特征在于,在所述文件下载成功之后,所述文件下载方法还包括:
所述客户端根据待下载文件的文件名对接收到的下载文件解包。
7.一种服务器,其特征在于,所述服务器包括:
预置参数存储模块,用于预先存储预置参数,所述预置参数包括上传路径、下载路径、服务器IP、端口、用户名和密码;
服务器文件传输模块,用于根据所述预置参数从客户端接收待上传文件,或者用于根据所述预置参数向客户端发送待下载文件;
其中,所述服务器还包括流量控制模块,该流量控制模块包括:
阈值存储单元,用于预先存储用户流控阈值,
阈值设置单元,用于设置所述客户端对应的IP流控阈值,
阈值读取单元,用于从所述阈值存储单元和阈值设置单元中读取所述用户流控阈值和IP流控阈值,
阈值判断单元,用于判断所述IP流控阈值是否大于用户流控阈值;
所述服务器文件传输模块包括:
发送单元,用于当所述阈值判断单元判断出用户流控阈值小于IP流控阈值时,则按照所述用户流控阈值将待下载文件发送至客户端,或者用于当所述阈值判断单元判断出用户流控阈值大于IP流控阈值时,则按照所述IP流控阈值将待下载文件发送至客户端,
接收单元,用于当所述阈值判断单元判断出用户流控阈值小于IP流控阈值时,则按照所述用户流控阈值从客户端接收待上传文件,或者用于当所述阈值判断单元判断出IP流控阈值小于用户流控阈值时,则按照所述IP流控阈值从客户端接收待上传文件。
8.根据权利要求7所述的服务器,其特征在于,所述服务器还包括服务器文件校验模块,其中,该服务器文件校验模块包括:
服务器MD5文件生成单元,用于根据所述服务器文件传输模块接收到的上传文件生成服务器MD5文件,或者根据所述服务器文件传输模块发送给客户端的待下载文件生成服务器MD5文件;
第二发送单元,用于在服务器MD5文件生成单元生成MD5文件之后,向所述客户端发送返回消息,所述返回消息表示服务器MD5文件已生成;
第三接收单元,用于接收来自所述客户端的下载服务器MD5文件的请求消息;
第三发送单元,用于根据第三接收单元接收到的请求消息,将所述MD5文件发送至客户端。
9.一种基于SFTP协议的文件传输系统,其特征在于,所述系统包括客户端和如权利要求7或8所述的服务器,其中,所述客户端包括:
预置参数读取模块,用于从服务器中读取预置参数,所述预置参数包括上传路径、下载路径、服务器IP、端口、用户名和密码,所述预置参数预先存储在所述服务器中;
客户端文件传输模块,用于根据待上传文件的文件名和所述预置参数,按照SFTP协议将所述待上传文件发送至所述服务器,或者根据服务器的待下载文件的文件名和所述预置参数,按照SFTP协议从所述服务器接收所述待下载文件。
10.如权利要求9所述的文件传输系统,其特征在于,所述客户端还包括:
文件打包模块,用于根据待上传文件的文件名对所述客户端文件传输模块待上传的文件打包;
文件解包模块,用于根据待下载文件的文件名对所述客户端文件传输模块接收到的下载文件解包。
11.如权利要求9所述的文件传输系统,其特征在于,所述客户端还包括客户端文件校验模块,其中,该客户端文件校验模块包括:
第一接收单元,用于接收所述服务器发送的返回消息,所述返回消息表示服务器MD5文件已生成;
第一发送单元,用于根据所述第一接收单元接收的返回消息,向所述服务器发送下载所述服务器MD5文件的请求消息;
第二接收单元,用于接收来自所述服务器的服务器MD5文件;
客户端MD5文件生成单元,用于根据所述客户端文件传输模块向所述服务器发送的待上传文件生成客户端MD5文件,或者用于根据所述客户端文件传输模块接收到的下载文件生成客户端MD5文件;
比较单元,用于比较所述服务器MD5文件和客户端MD5文件是否相等;
传输结果指示单元,用于当所述比较单元比较出所述服务器MD5文件与客户端MD5文件相等时,指示用户文件上传或下载成功,或者用于当所述比较单元比较出所述服务器MD5文件与客户端MD5文件不相等时,指示用户文件上传或下载失败。
CN201110180715.6A 2011-06-27 2011-06-27 基于sftp协议的文件上传与下载方法、系统及相关设备 Active CN102231742B (zh)

Priority Applications (1)

Application Number Priority Date Filing Date Title
CN201110180715.6A CN102231742B (zh) 2011-06-27 2011-06-27 基于sftp协议的文件上传与下载方法、系统及相关设备

Applications Claiming Priority (1)

Application Number Priority Date Filing Date Title
CN201110180715.6A CN102231742B (zh) 2011-06-27 2011-06-27 基于sftp协议的文件上传与下载方法、系统及相关设备

Publications (2)

Publication Number Publication Date
CN102231742A CN102231742A (zh) 2011-11-02
CN102231742B true CN102231742B (zh) 2014-10-29

Family

ID=44844275

Family Applications (1)

Application Number Title Priority Date Filing Date
CN201110180715.6A Active CN102231742B (zh) 2011-06-27 2011-06-27 基于sftp协议的文件上传与下载方法、系统及相关设备

Country Status (1)

Country Link
CN (1) CN102231742B (zh)

Families Citing this family (9)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN102591667B (zh) * 2012-01-16 2015-05-27 深圳市同洲电子股份有限公司 一种远程发布应用的方法及装置
CN103944949A (zh) * 2013-01-21 2014-07-23 中国电信股份有限公司 文件上传的方法和系统、以及云存储设备
CN104714992A (zh) * 2013-12-12 2015-06-17 南宁市磁汇科技有限公司 向web页面动态插入本地文件的一键式处理方法和装置
CN104539690B (zh) * 2014-12-24 2018-05-04 大连理工大学 一种基于反馈机制和md5码检测的服务器远程数据同步方法
CN107239239A (zh) * 2016-03-28 2017-10-10 平安科技(深圳)有限公司 数据传输方法和系统
CN109861973B (zh) * 2018-12-21 2022-07-12 北京天融信网络安全技术有限公司 信息传输方法、装置、电子设备及计算机可读介质
CN110177154B (zh) * 2019-06-17 2021-07-02 深圳前海微众银行股份有限公司 一种文件交互处理方法、装置及系统
CN111666745B (zh) * 2020-06-03 2023-07-25 中国建设银行股份有限公司 一种文件下载方法、装置、服务器及介质
CN112468586A (zh) * 2020-11-26 2021-03-09 许继集团有限公司 一种电场监控单机信息采集的方法及系统

Citations (3)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
WO2004114586A1 (en) * 2003-06-24 2004-12-29 International Business Machines Corporation Method and system for authentically servers in a distributed application environment
CN1949765A (zh) * 2005-10-10 2007-04-18 华为技术有限公司 获得被管设备的ssh主机公开密钥的方法和系统
CN101765156A (zh) * 2009-12-14 2010-06-30 华为技术有限公司 流量控制方法及装置

Family Cites Families (2)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
JP2007141102A (ja) * 2005-11-21 2007-06-07 Internatl Business Mach Corp <Ibm> ソフトウェアをインストールするためのプログラム、記録媒体、及び装置
US8719901B2 (en) * 2008-10-24 2014-05-06 Synopsys, Inc. Secure consultation system

Patent Citations (3)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
WO2004114586A1 (en) * 2003-06-24 2004-12-29 International Business Machines Corporation Method and system for authentically servers in a distributed application environment
CN1949765A (zh) * 2005-10-10 2007-04-18 华为技术有限公司 获得被管设备的ssh主机公开密钥的方法和系统
CN101765156A (zh) * 2009-12-14 2010-06-30 华为技术有限公司 流量控制方法及装置

Non-Patent Citations (2)

* Cited by examiner, † Cited by third party
Title
《网络安全协议SSH的研究与实现》;甘长华;《中国优秀硕士学位论文全文数据库》;20090430;第11页-第14页,第16页第3行-第20页,第31页-第36页,第55页-第58页 *
甘长华.《网络安全协议SSH的研究与实现》.《中国优秀硕士学位论文全文数据库》.2009,

Also Published As

Publication number Publication date
CN102231742A (zh) 2011-11-02

Similar Documents

Publication Publication Date Title
CN102231742B (zh) 基于sftp协议的文件上传与下载方法、系统及相关设备
US11388236B2 (en) Distributed cloud file storage
EP3179701B1 (en) File upload and download methods and associated server
US10965732B2 (en) Streaming zip
US10516526B2 (en) Data transmitting method, server and client
US10474831B1 (en) Large network attached storage encryption
CN102739681B (zh) 一种登录控件进行服务器登录的方法和装置
CN109391673B (zh) 一种管理更新文件的方法、系统及终端设备
CN102687472B (zh) 发送、接收数据的处理装置及方法
JP2014149813A (ja) モバイル端末で大容量のファイルが添付されたメールを送信する方法およびシステム
CN102821161A (zh) 一种网络安全审计方法、装置及系统
CN107947917A (zh) 一种生成白盒密钥的方法及装置
CN114466015B (zh) 一种基于多云架构的数据存储系统及方法
US20170289237A1 (en) Network file transfer including file obfuscation
EP3819802A1 (en) Data consistency checking method and data uploading/downloading apparatus
CN103685332A (zh) 文件上传方法、客户端、服务器及系统
CN112468511A (zh) 文件传输方法和装置
CN109408076A (zh) 一种app批量发版方法、装置及系统
CN115242413A (zh) 物联网设备固件安全升级方法、装置、电子设备及介质
CN111158716B (zh) 版本升级调用方法、装置、计算机系统及可读存储介质
CN104346460A (zh) 进行文件下载的方法、装置及浏览器客户端
CN115297104B (zh) 文件上传方法、装置、电子设备和存储介质
CN110772785A (zh) 游戏存档的共享方法、装置及电子设备
CN112328279B (zh) 系统固件文件升级方法、装置及系统
CN104184804A (zh) 云存储系统及其提供和从其下载数据的系统和方法

Legal Events

Date Code Title Description
C06 Publication
PB01 Publication
C10 Entry into substantive examination
SE01 Entry into force of request for substantive examination
C14 Grant of patent or utility model
GR01 Patent grant