CN106534282A - 一种移动终端上传文件的方法和装置 - Google Patents

一种移动终端上传文件的方法和装置 Download PDF

Info

Publication number
CN106534282A
CN106534282A CN201610944316.5A CN201610944316A CN106534282A CN 106534282 A CN106534282 A CN 106534282A CN 201610944316 A CN201610944316 A CN 201610944316A CN 106534282 A CN106534282 A CN 106534282A
Authority
CN
China
Prior art keywords
file
piecemeal
mobile terminal
server
upload
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.)
Pending
Application number
CN201610944316.5A
Other languages
English (en)
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.)
Nubia Technology Co Ltd
Original Assignee
Nubia Technology Co Ltd
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 Nubia Technology Co Ltd filed Critical Nubia Technology Co Ltd
Priority to CN201610944316.5A priority Critical patent/CN106534282A/zh
Publication of CN106534282A publication Critical patent/CN106534282A/zh
Pending legal-status Critical Current

Links

Classifications

    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L67/00Network arrangements or protocols for supporting network services or applications
    • H04L67/01Protocols
    • H04L67/06Protocols specially adapted for file transfer, e.g. file transfer protocol [FTP]
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F16/00Information retrieval; Database structures therefor; File system structures therefor
    • G06F16/10File systems; File servers
    • G06F16/16File or folder operations, e.g. details of user interfaces specifically adapted to file systems
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F16/00Information retrieval; Database structures therefor; File system structures therefor
    • G06F16/10File systems; File servers
    • G06F16/17Details of further file system functions
    • G06F16/174Redundancy elimination performed by the file system
    • G06F16/1748De-duplication implemented within the file system, e.g. based on file segments
    • G06F16/1752De-duplication implemented within the file system, e.g. based on file segments based on file chunks

Abstract

本发明公开了一种移动终端上传文件的方法和装置,包含:接收上传文件到服务器的命令,获取待上传文件,对文件按照公式Y=N‑X*(n‑1)进行分块、直到Y小于X为止;其中N为设定的固定分块值,X为设定的递减值,n为当前分块次数;逐个上传分块,并检测上传是否成功,如果检测到全部分块上传成功,则结束;否则对文件未上传成功的部分按照上述公式重新分块并上传,直到文件全部上传成功。本发明提高了移动终端文件上传的成功率,减少因上传失败带来的重复上传工作,进而节省了文件上传所需的整体时间和流量。

Description

一种移动终端上传文件的方法和装置
技术领域
本发明涉及移动终端技术领域,尤其涉及一种移动终端上传文件的方法和装置。
背景技术
移动端的网络容易出现波动,不稳定。当用户使用移动APP上传大文件的时候,如果服务器处理慢或者当前网络信号波动,就会出现文件传输失败。假设文件大小是8M,用户在传到5M的位置失败了,用户重新发送的时候会重新发送整个文件,相当于浪费了用户的流量,多次失败之后用户很有可能放弃这款APP,为终端APP带来用户损失。
发明内容
本发明的主要目的在于提出一种移动终端上传文件的方法和装置,旨在解决现有移动终端在上传文件时,一旦出现上传失败,会通过重新上传的方式处理,这样的方式没有降低上传的难度、且存在重复上传已完成部分的问题,致使上传所花费的时间和流量的浪费。
为实现上述目的,本发明提供的一种移动终端上传文件的方法,包含:
接收上传文件到服务器的命令,获取待上传文件,对文件按照公式Y=N-X*(n-1)进行分块、直到Y小于X为止,其中N为设定的固定分块值,X为设定的递减值,n为当前分块次数;
逐个上传分块,并检测上传是否成功,如果检测到全部分块上传成功,则结束;否则对文件未上传成功的部分按照上述公式重新分块并上传,直到文件全部上传成功。
可选的,所述服务器包含业务服务器和文件服务器,所述文件上传后存储于文件服务器。
可选的,上传分块的同时上传所述分块的开始位置和结束位置至服务器。
可选的,所述分块的开始位置为已经发送的文件大小;所述分块的结束位置为已经发送的文件大小与当前分块的大小之和。
可选的,所述递减值小于或等于所述固定分块值的一半。
此外,为实现上述目的,本发明还提出一种移动终端上传文件的装置,包含:
文件获取单元,用于接收上传文件到服务器的命令,获取待上传文件,或者接收到文件上传失败的信号后,获取未上传成功的文件;
分块单元,用于对文件获取单元所获取的文件按照公式Y=N-X*(n-1)进行分块、直到Y小于X为止,其中N为设定的固定分块值,X为设定的递减值,n为当前分块次数;
上传单元,逐个上传分块以及上传不能再被分块的剩余文件,并检测上传是否成功,如果检测到全部分块上传成功的信号,则结束;否则发出上传失败的信号。
可选的,所述服务器包含业务服务器和文件服务器,所述文件上传后存储于文件服务器。
可选的,还包含:位置获取单元,用于获取上传分块的开始位置和结束位置并上传至服务器。
可选的,所述分块的开始位置为已经发送的文件大小;所述分块的结束位置为已经发送的文件大小与当前分块的大小之和。
可选的,所述递减值小于或等于所述固定分块值的一半。
本发明提出的移动终端上传文件的方法和装置,通过对文件进行切割分块,将整体文件上传的方式改为分块上传,并在文件上传失败的时候,只对未上传成功的部分进行重新切割上传,提高了文件在网络条件不好等情况下上传文件的成功率,且避免重复上传已成功部分,从而为终端节省流量和上传文件的时间。
附图说明
图1为实现本发明各个实施例的一个可选的移动终端的硬件结构示意图;
图2为如图1所示的移动终端的无线通信系统示意图;
图3为本发明第一实施例提供的一种移动终端上传文件的方法流程示意图;
图4为本发明第二实施例提供的一种移动终端上传文件的方法流程示意图;
图5为本发明第三实施例提供的一种移动终端上传文件的装置结构示意图;
图6为本发明第四实施例提供的一种移动终端上传文件的装置结构示意图。
本发明目的的实现、功能特点及优点将结合实施例,参照附图做进一步说明。
具体实施方式
应当理解,此处所描述的具体实施例仅仅用以解释本发明,并不用于限定本发明。
现在将参考附图描述实现本发明各个实施例的移动终端。在后续的描述中,使用用于表示元件的诸如“模块”、“部件”或“单元”的后缀仅为了有利于本发明的说明,其本身并没有特定的意义。因此,"模块"与"部件"可以混合地使用。
移动终端可以以各种形式来实施。例如,本发明中描述的终端可以包括诸如移动电话、智能电话、笔记本电脑、数字广播接收器、PDA(个人数字助理)、PAD(平板电脑)、PMP(便携式多媒体播放器)、导航装置等等的移动终端以及诸如数字TV、台式计算机等等的固定终端。下面,假设终端是移动终端。然而,本领域技术人员将理解的是,除了特别用于移动目的的元件之外,根据本发明的实施方式的构造也能够应用于固定类型的终端。
图1为实现本发明各个实施例的一个可选的移动终端的硬件结构示意。
移动终端100可以包括无线通信单元110、A/V(音频/视频)输入单元120、用户输入单元130、感测单元140、输出单元150、存储器160、接口单元170、控制器180和电源单元190等等。图1示出了具有各种组件的移动终端,但是应理解的是,并不要求实施所有示出的组件。可以替代地实施更多或更少的组件。将在下面详细描述移动终端的元件。
无线通信单元110通常包括一个或多个组件,其允许移动终端100与无线通信系统或网络之间的无线电通信。例如,无线通信单元可以包括广播接收模块111、移动通信模块112、无线互联网模块113、短程通信模块114和位置信息模块115中的至少一个。
广播接收模块111经由广播信道从外部广播管理服务器接收广播信号和/或广播相关信息。广播信道可以包括卫星信道和/或地面信道。广播管理服务器可以是生成并发送广播信号和/或广播相关信息的服务器或者接收之前生成的广播信号和/或广播相关信息并且将其发送给终端的服务器。广播信号可以包括TV广播信号、无线电广播信号、数据广播信号等等。而且,广播信号可以进一步包括与TV或无线电广播信号组合的广播信号。广播相关信息也可以经由移动通信网络提供,并且在该情况下,广播相关信息可以由移动通信模块112来接收。广播信号可以以各种形式存在,例如,其可以以数字多媒体广播(DMB)的电子节目指南(EPG)、数字视频广播手持(DVB-H)的电子服务指南(ESG)等等的形式而存在。广播接收模块111可以通过使用各种类型的广播系统接收信号广播。特别地,广播接收模块111可以通过使用诸如多媒体广播-地面(DMB-T)、数字多媒体广播-卫星(DMB-S)、数字视频广播-手持(DVB-H),前向链路媒体(MediaFLO@)的数据广播系统、地面数字广播综合服务(ISDB-T)等等的数字广播系统接收数字广播。广播接收模块111可以被构造为适合提供广播信号的各种广播系统以及上述数字广播系统。经由广播接收模块111接收的广播信号和/或广播相关信息可以存储在存储器160(或者其它类型的存储介质)中。
移动通信模块112将无线电信号发送到基站(例如,接入点、节点B等等)、外部终端以及服务器中的至少一个和/或从其接收无线电信号。这样的无线电信号可以包括语音通话信号、视频通话信号、或者根据文本和/或多媒体消息发送和/或接收的各种类型的数据。
无线互联网模块113支持移动终端的无线互联网接入。该模块可以内部或外部地耦接到终端。该模块所涉及的无线互联网接入技术可以包括WLAN(无线LAN)(Wi-Fi)、Wibro(无线宽带)、Wimax(全球微波互联接入)、HSDPA(高速下行链路分组接入)等等。
短程通信模块114是用于支持短程通信的模块。短程通信技术的一些示例包括蓝牙TM、射频识别(RFID)、红外数据协会(IrDA)、超宽带(UWB)、紫蜂TM等等。
位置信息模块115是用于检查或获取移动终端的位置信息的模块。位置信息模块的典型示例是GPS(全球定位系统)。根据当前的技术,GPS模块115计算来自三个或更多卫星的距离信息和准确的时间信息并且对于计算的信息应用三角测量法,从而根据经度、纬度和高度准确地计算三维当前位置信息。当前,用于计算位置和时间信息的方法使用三颗卫星并且通过使用另外的一颗卫星校正计算出的位置和时间信息的误差。此外,GPS模块115能够通过实时地连续计算当前位置信息来计算速度信息。
A/V输入单元120用于接收音频或视频信号。A/V输入单元120可以包括相机121和麦克风1220,相机121对在视频捕获模式或图像捕获模式中由图像捕获装置获得的静态图片或视频的图像数据进行处理。处理后的图像帧可以显示在显示单元151上。经相机121处理后的图像帧可以存储在存储器160(或其它存储介质)中或者经由无线通信单元110进行发送,可以根据移动终端的构造提供两个或更多相机1210。麦克风122可以在电话通话模式、记录模式、语音识别模式等等运行模式中经由麦克风接收声音(音频数据),并且能够将这样的声音处理为音频数据。处理后的音频(语音)数据可以在电话通话模式的情况下转换为可经由移动通信模块112发送到移动通信基站的格式输出。麦克风122可以实施各种类型的噪声消除(或抑制)算法以消除(或抑制)在接收和发送音频信号的过程中产生的噪声或者干扰。
用户输入单元130可以根据用户输入的命令生成键输入数据以控制移动终端的各种操作。用户输入单元130允许用户输入各种类型的信息,并且可以包括键盘、锅仔片、触摸板(例如,检测由于被接触而导致的电阻、压力、电容等等的变化的触敏组件)、滚轮、摇杆等等。特别地,当触摸板以层的形式叠加在显示单元151上时,可以形成触摸屏。
感测单元140检测移动终端100的当前状态,(例如,移动终端100的打开或关闭状态)、移动终端100的位置、用户对于移动终端100的接触(即,触摸输入)的有无、移动终端100的取向、移动终端100的加速或减速移动和方向等等,并且生成用于控制移动终端100的操作的命令或信号。例如,当移动终端100实施为滑动型移动电话时,感测单元140可以感测该滑动型电话是打开还是关闭。另外,感测单元140能够检测电源单元190是否提供电力或者接口单元170是否与外部装置耦接。
接口单元170用作至少一个外部装置与移动终端100连接可以通过的接口。例如,外部装置可以包括有线或无线头戴式耳机端口、外部电源(或电池充电器)端口、有线或无线数据端口、存储卡端口、用于连接具有识别模块的装置的端口、音频输入/输出(I/O)端口、视频I/O端口、耳机端口等等。识别模块可以是存储用于验证用户使用移动终端100的各种信息并且可以包括用户识别模块(UIM)、客户识别模块(SIM)、通用客户识别模块(USIM)等等。另外,具有识别模块的装置(下面称为"识别装置")可以采取智能卡的形式,因此,识别装置可以经由端口或其它连接装置与移动终端100连接。接口单元170可以用于接收来自外部装置的输入(例如,数据信息、电力等等)并且将接收到的输入传输到移动终端100内的一个或多个元件或者可以用于在移动终端和外部装置之间传输数据。
另外,当移动终端100与外部底座连接时,接口单元170可以用作允许通过其将电力从底座提供到移动终端100的路径或者可以用作允许从底座输入的各种命令信号通过其传输到移动终端的路径。从底座输入的各种命令信号或电力可以用作用于识别移动终端是否准确地安装在底座上的信号。输出单元150被构造为以视觉、音频和/或触觉方式提供输出信号(例如,音频信号、视频信号、警报信号、振动信号等等)。输出单元150可以包括显示单元151、音频输出模块152、警报单元153等等。
显示单元151可以显示在移动终端100中处理的信息。例如,当移动终端100处于电话通话模式时,显示单元151可以显示与通话或其它通信(例如,文本消息收发、多媒体文件下载等等)相关的用户界面(UI)或图形用户界面(GUI)。当移动终端100处于视频通话模式或者图像捕获模式时,显示单元151可以显示捕获的图像和/或接收的图像、示出视频或图像以及相关功能的UI或GUI等等。
同时,当显示单元151和触摸板以层的形式彼此叠加以形成触摸屏时,显示单元151可以用作输入装置和输出装置。显示单元151可以包括液晶显示器(LCD)、薄膜晶体管LCD(TFT-LCD)、有机发光二极管(OLED)显示器、柔性显示器、三维(3D)显示器等等中的至少一种。这些显示器中的一些可以被构造为透明状以允许用户从外部观看,这可以称为透明显示器,典型的透明显示器可以例如为TOLED(透明有机发光二极管)显示器等等。根据特定想要的实施方式,移动终端100可以包括两个或更多显示单元(或其它显示装置),例如,移动终端可以包括外部显示单元(未示出)和内部显示单元(未示出)。触摸屏可用于检测触摸输入压力以及触摸输入位置和触摸输入面积。
音频输出模块152可以在移动终端处于呼叫信号接收模式、通话模式、记录模式、语音识别模式、广播接收模式等等模式下时,将无线通信单元110接收的或者在存储器160中存储的音频数据转换音频信号并且输出为声音。而且,音频输出模块152可以提供与移动终端100执行的特定功能相关的音频输出(例如,呼叫信号接收声音、消息接收声音等等)。音频输出模块152可以包括扬声器、蜂鸣器等等。
警报单元153可以提供输出以将事件的发生通知给移动终端100。典型的事件可以包括呼叫接收、消息接收、键信号输入、触摸输入等等。除了音频或视频输出之外,警报单元153可以以不同的方式提供输出以通知事件的发生。例如,警报单元153可以以振动的形式提供输出,当接收到呼叫、消息或一些其它进入通信(incomingcommunication)时,警报单元153可以提供触觉输出(即,振动)以将其通知给用户。通过提供这样的触觉输出,即使在用户的移动电话处于用户的口袋中时,用户也能够识别出各种事件的发生。警报单元153也可以经由显示单元151或音频输出模块152提供通知事件的发生的输出。
存储器160可以存储由控制器180执行的处理和控制操作的软件程序等等,或者可以暂时地存储己经输出或将要输出的数据(例如,电话簿、消息、静态图像、视频等等)。而且,存储器160可以存储关于当触摸施加到触摸屏时输出的各种方式的振动和音频信号的数据。
存储器160可以包括至少一种类型的存储介质,所述存储介质包括闪存、硬盘、多媒体卡、卡型存储器(例如,SD或DX存储器等等)、随机访问存储器(RAM)、静态随机访问存储器(SRAM)、只读存储器(ROM)、电可擦除可编程只读存储器(EEPROM)、可编程只读存储器(PROM)、磁性存储器、磁盘、光盘等等。而且,移动终端100可以与通过网络连接执行存储器160的存储功能的网络存储装置协作。
控制器180通常控制移动终端的总体操作。例如,控制器180执行与语音通话、数据通信、视频通话等等相关的控制和处理。另外,控制器180可以包括用于再现(或回放)多媒体数据的多媒体模块1810,多媒体模块1810可以构造在控制器180内,或者可以构造为与控制器180分离。控制器180可以执行模式识别处理,以将在触摸屏上执行的手写输入或者图片绘制输入识别为字符或图像。
电源单元190在控制器180的控制下接收外部电力或内部电力并且提供操作各元件和组件所需的适当的电力。
这里描述的各种实施方式可以以使用例如计算机软件、硬件或其任何组合的计算机可读介质来实施。对于硬件实施,这里描述的实施方式可以通过使用特定用途集成电路(ASIC)、数字信号处理器(DSP)、数字信号处理装置(DSPD)、可编程逻辑装置(PLD)、现场可编程门阵列(FPGA)、处理器、控制器、微控制器、微处理器、被设计为执行这里描述的功能的电子单元中的至少一种来实施,在一些情况下,这样的实施方式可以在控制器180中实施。对于软件实施,诸如过程或功能的实施方式可以与允许执行至少一种功能或操作的单独的软件模块来实施。软件代码可以由以任何适当的编程语言编写的软件应用程序(或程序)来实施,软件代码可以存储在存储器160中并且由控制器180执行。
至此,己经按照其功能描述了移动终端。下面,为了简要起见,将描述诸如折叠型、直板型、摆动型、滑动型移动终端等等的各种类型的移动终端中的滑动型移动终端作为示例。因此,本发明能够应用于任何类型的移动终端,并且不限于滑动型移动终端。
如图1中所示的移动终端100可以被构造为利用经由帧或分组发送数据的诸如有线和无线通信系统以及基于卫星的通信系统来操作。
现在将参考图2描述其中根据本发明的移动终端能够操作的通信系统。
这样的通信系统可以使用不同的空中接口和/或物理层。例如,由通信系统使用的空中接口包括例如频分多址(FDMA)、时分多址(TDMA)、码分多址(CDMA)和通用移动通信系统(UMTS)(特别地,长期演进(LTE))、全球移动通信系统(GSM)等等。作为非限制性示例,下面的描述涉及CDMA通信系统,但是这样的教导同样适用于其它类型的系统。
参考图2,CDMA无线通信系统可以包括多个移动终端100、多个基站(BS)270、基站控制器(BSC)275和移动交换中心(MSC)280。MSC280被构造为与公共电话交换网络(PSTN)290形成接口。MSC280还被构造为与可以经由回程线路耦接到基站270的BSC275形成接口。回程线路可以根据若干己知的接口中的任一种来构造,所述接口包括例如E1/T1、ATM,IP、PPP、帧中继、HDSL、ADSL或xDSL。将理解的是,如图2中所示的系统可以包括多个BSC2750。
每个BS270可以服务一个或多个分区(或区域),由多向天线或指向特定方向的天线覆盖的每个分区放射状地远离BS270。或者,每个分区可以由用于分集接收的两个或更多天线覆盖。每个BS270可以被构造为支持多个频率分配,并且每个频率分配具有特定频谱(例如,1.25MHz,5MHz等等)。
分区与频率分配的交叉可以被称为CDMA信道。BS270也可以被称为基站收发器子系统(BTS)或者其它等效术语。在这样的情况下,术语"基站"可以用于笼统地表示单个BSC275和至少一个BS270。基站也可以被称为"蜂窝站"。或者,特定BS270的各分区可以被称为多个蜂窝站。
如图2中所示,广播发射器(BT)295将广播信号发送给在系统内操作的移动终端100。如图1中所示的广播接收模块111被设置在移动终端100处以接收由BT295发送的广播信号。在图2中,示出了几个全球定位系统(GPS)卫星300。卫星300帮助定位多个移动终端100中的至少一个。
在图2中,描绘了多个卫星300,但是理解的是,可以利用任何数目的卫星获得有用的定位信息。如图1中所示的GPS模块115通常被构造为与卫星300配合以获得想要的定位信息。替代GPS跟踪技术或者在GPS跟踪技术之外,可以使用可以跟踪移动终端的位置的其它技术。另外,至少一个GPS卫星300可以选择性地或者额外地处理卫星DMB传输。
作为无线通信系统的一个典型操作,BS270接收来自各种移动终端100的反向链路信号。移动终端100通常参与通话、消息收发和其它类型的通信。特定基站270接收的每个反向链路信号被在特定BS270内进行处理。获得的数据被转发给相关的BSC275。BSC提供通话资源分配和包括BS270之间的软切换过程的协调的移动管理功能。BSC275还将接收到的数据路由到MSC280,其提供用于与PSTN290形成接口的额外的路由服务。类似地,PSTN290与MSC280形成接口,MSC与BSC275形成接口,并且BSC275相应地控制BS270以将正向链路信号发送到移动终端100。
基于上述一个可选的移动终端硬件结构以及通信系统,提出本发明方法各个实施例。
实施例一
如图3所示,本发明第一实施例提出一种移动终端上传文件的方法,包括:
S101,接收上传文件到服务器的命令,获取待上传文件;
具体的,上传文件的动作启动,通常需要终端使用人启动一个文件上传的命令,该命令可能是通过屏幕输入的命令,也可能是通过语音输入的命令,当终端接收到关于启动上传文件的命令后,获取整个待上传的文件。
S102,对文件按照公式Y=N-X*(n-1)进行分块、直到Y小于X,其中N为设定的固定分块值,X为设定的递减值,n为当前分块次数;
具体的,固定分块值和递减值为默认设置,或由终端使用人设置,即每次上传文件时,先按照固定分块值大小对上传文件进行分块,固定分块值一般代表最优的分块大小,当按照固定分块值分块后的文件不能成功上传时,按照固定分块值递减一个递减值的大小进行再次分块,递减值一般代表最小分割值,所述递减值小于或等于所述固定分块值的一半。举例来说,首次分块,n=1,按照固定分块值N进行分块,按照固定分块值大小将文件分割为若干个分块,当文件在上传的过程中发生网络中断或网速降低导致上传失败时,发生上传失败的分块可以被精确定位到,进而可以精确区分已上传成功部分和未上传成功部分,便于在恢复上传时只对未长传部分进行处理。
S103,逐个上传所述若干分块;
具体的,为了使分割后的文件能够在上传后还原到未分割的状态,需要将分割后的分块按照一定的次序排列并依次序逐个上传。
S104,检测各个分块上传是否成功;如果检测到全部分块上传成功,则执行S106;否则执行S105;
具体的,在分块上传的过程中,检测每个分块是否上传成功,如果所有分块都上传成功了,则表示整个文件被上传成功,如果某一个分块被检测到上传失败,则表示这个分块之前的部分全部上传成功,这个分块以及这个分块之后的部分全部上传失败。
S105,获取未上传成功的部分;返回执行S102;
具体的,获取该上传失败的分块以及该分块之后的所有分块,将这些分块重新合并后再按照Y=N-X*(n-1)进行分块,直到Y小于X。例如:二次分块,n=2,则按照N-X来分块,直到Y小于X时,剩余最后一个不能再递减分块的部分,则直接进行上传直到上传完成。
S106,结束。
以上实现的移动终端上传文件的方法,通过对文件进行切割分块,将整体文件上传的方式改为分块上传,并在文件上传失败的时候,只对未上传成功的部分进行重新切割,提高了文件在网络条件不好等情况下上传文件的成功率,且避免重复上传已成功部分而节省流量和时间。
实施例二
如图4所示,本发明第二实施例提出一种移动终端上传文件的方法,包括:
S201,接收上传文件到服务器命令,获取待上传文件;
具体的,上传文件的动作启动,通常需要终端使用人启动一个文件上传的命令,该命令可能是通过屏幕输入的命令,也可能是通过语音输入的命令,当终端接收到关于启动上传文件的命令后,获取整个待上传的文件。
为提高用户上传文件的速度,将服务器进行隔离为业务服务器和文件服务器,文件要上传的服务器分为业务服务器和文件服务器,上传的文件直接存储于其中的文件服务器。
S202,对文件按照公式Y=N-X*(n-1)进行分块,直到Y小于X,其中N为设定的固定分块值,X为设定的递减值,n为当前分块次数;
具体的,固定分块值和递减值为默认设置,或由终端使用人设置,即每次上传文件时,按照固定分块值大小对上传文件进行分块,固定分块值一般代表最优的分块大小,当按照固定分块值分块后的文件不能成功上传时,按照固定分块值递减一个递减值的大小进行再次分块。举例来说,首次分块,n=1,按照固定分块值N进行分块,按照固定分块值大小将文件分割为若干个分块,当文件在上传的过程中发生网络中断或网速降低导致上传失败时,发生上传失败的分块可以被精确定位到,进而可以精确区分已上传成功部分和未上传成功部分,便于在恢复上传时只对未长传部分进行处理。
S203,逐个上传分块以及每个分块的开始位置和结束位置至服务器;
具体的,为了使分割后的文件能够在上传后还原到未分割的状态,保证文件上传不出现顺序错乱,在上传分块的时候,会把每个分块的开始位置:和结束位置告诉服务器,每个分块开始的位置为:已经发送的文件大小;每个分块结束的位置为:已经发送的文件大小+当前分块大小;保证服务器在接受文件的时候,能将文件写入文件服务器的正确的位置。
文件服务器在接受到文件上传的请求时,先找到当前传输文件对应的本地缓存,然后读取出应用上传的文件开始位置和结束位置,最后再读取文件内容,将文件内容写在对应的位置。
S204,检测各个分块上传是否成功;如果检测到全部分块上传成功,则执行S206;否则执行S205;
具体的,在分块上传的过程中,检测每个分块是否上传成功,如果所有分块都上传成功了,则表示整个文件被上传成功,如果某一个分块被检测到上传失败,则表示这个分块之前的部分全部上传成功,这个分块以及这个分块之后的部分全部上传失败。
S205,获取未上传成功的部分;返回执行S202;
具体的,获取该上传失败的分块以及该分块之后的所有分块,将这些分块重新合并后再按照Y=N-X*(n-1)进行分块,直到Y小于X。
例如:二次分块,n=2,则按照N-X来分块,直到Y小于X,剩余最后一个不能再递减分块的部分,则直接进行上传直到上传完成。
S206,结束。
以上实现的移动终端上传文件的方法,通过对对服务器进行隔离,将上传文件上传到文件服务器,可以有效提高文件上传的速度,另外对分块的开始位置和结束位置与分块一起上传,提高了文件上传后顺序的准确性,进而使分块后的文件可以上传后完整复原。
实施例三
如图5所示,本发明第三实施例提出一种移动终端上传文件的装置,包括:文件获取单元10,分块单元20,上传单元30。
文件获取单元10,用于接收上传文件到服务器命令,获取待上传文件,或者接收到文件上传失败的信号后,获取未上传成功的文件。
具体的,上传文件的动作启动,通常需要终端使用人启动一个文件上传的命令,该命令可能是通过屏幕输入的命令,也可能是通过语音输入的命令,当终端的文件获取单元10接收到关于启动上传文件的命令后,获取整个待上传的文件,或者文件获取单元10接收到文件上传失败的信号后,获取未上传成功的文件。
为提高用户上传文件的速度,将服务器进行隔离为业务服务器和文件服务器,文件要上传的服务器分为业务服务器和文件服务器,上传的文件直接存储于其中的文件服务器。
分块单元20,用于对文件获取单元所获取的文件按照公式Y=N-X*(n-1)进行分块、直到Y小于X为止,其中N为设定的固定分块值,X为设定的递减值,n为当前分块次数;
具体的,固定分块值和递减值为默认设置,或由终端使用人设置,即每次上传文件时,按照固定分块值大小对上传文件进行分块,固定分块值一般代表最优的分块大小,递减值代表最小分块值,递减值小于或等于固定分块值的一半。当按照固定分块值分块后的文件不能成功上传时,按照固定分块值递减一个递减值的大小进行再次分块。举例来说,首次分块,n=1,分块单元20按照固定分块值N进行分块,将文件分割为若干个分块,当文件在上传的过程中发生网络中断或网速降低导致上传失败时,发生上传失败的分块可以被精确定位到,进而可以精确区分已上传成功部分和未上传成功部分,便于在恢复上传时只对未长传部分进行处理。
具体的,在分块上传的过程中,上传单元30检测每个分块是否上传成功,如果所有分块都上传成功了,则表示整个文件被上传成功,如果某一个分块被检测到上传失败,则表示这个分块之前的部分全部上传成功,这个分块以及这个分块之后的部分全部上传失败。分块单元20获取到上传失败的信号后,获取该上传失败的分块以及该分块之后的所有分块,将这些分块重新合并后再按照Y=N-X*(n-1)进行分块,直到Y小于X。例如:二次分块,n=2,则按照N-X来分块,直到Y小于X,剩余最后一个不能再递减分块的部分,则直接进行上传直到上传完成。
上传单元30,逐个上传所述若干分块以及上传不能再被分块的剩余文件,并检测上传是否成功,如果检测到全部分块上传成功的信号,则结束;否则发出上传失败的信号。
具体的,为了使分割后的文件能够在上传后还原到未分割的状态,需要将分割后的分块按照一定的次序排列并依次序逐个上传。如果上传单元30检测到全部分块上传成功的信号,则结束;否则上传单元30向分块单元20发出上传失败的信号。
以上实现的移动终端上传文件的装置,通过对文件进行切割分块,将整体文件上传的方式改为分块上传,并在文件上传失败的时候,只对未上传成功的部分进行重新切割,提高了文件在网络条件不好等情况下上传文件的成功率,且避免重复上传已成功部分而节省流量和时间。
实施例四
如图6所示,本发明第四实施例提出一种移动终端上传文件的装置,包括:文件获取单元10,分块单元20,位置获取单元40,上传单元30。
文件获取单元10,分块单元20,上传单元30与实施例三相同,在此不再赘述,仅对位置获取单元进行特别说明。
位置获取单元40,用于获取上传分块的开始位置和结束位置并上传至服务器。
具体的,为了使分割后的文件能够在上传后还原到未分割的状态,保证文件上传不出现顺序错乱,在上传分块的时候,位置获取单元40获取每个分块的开始位置和结束位置并上传位置信息至服务器,每个分块开始的位置为:已经发送的文件大小;每个分块结束的位置为:已经发送的文件大小+当前分块大小;保证服务器在接受文件的时候,能将文件写入正确的位置。
文件服务器在接收到文件上传的请求时,先找到当前传输文件对应的本地缓存,然后读取出应用上传的文件开始位置和结束位置,最后再读取文件内容,将文件内容写在对应的位置。
以上实现的移动终端上传文件的装置,通过对对服务器进行隔离,将上传文件上传到文件服务器,可以有效提高文件上传的速度,另外对分块的开始位置和结束位置与分块一起上传,提高了文件上传后顺序的准确性,进而使分块后的文件可以上传后完整复原。
需要说明的是,在本文中,术语“包括”、“包含”或者其任何其他变体意在涵盖非排他性的包含,从而使得包括一系列要素的过程、方法、物品或者装置不仅包括那些要素,而且还包括没有明确列出的其他要素,或者是还包括为这种过程、方法、物品或者装置所固有的要素。在没有更多限制的情况下,由语句“包括一个……”限定的要素,并不排除在包括该要素的过程、方法、物品或者装置中还存在另外的相同要素。
上述本发明实施例序号仅仅为了描述,不代表实施例的优劣。
通过以上的实施方式的描述,本领域的技术人员可以清楚地了解到上述实施例方法可借助软件加必需的通用硬件平台的方式来实现,当然也可以通过硬件,但很多情况下前者是更佳的实施方式。基于这样的理解,本发明的技术方案本质上或者说对现有技术做出贡献的部分可以以软件产品的形式体现出来,该计算机软件产品存储在一个存储介质(如ROM/RAM、磁碟、光盘)中,包括若干指令用以使得一台终端设备(可以是手机,计算机,服务器,空调器,或者网络设备等)执行本发明各个实施例所述的方法。
以上仅为本发明的优选实施例,并非因此限制本发明的专利范围,凡是利用本发明说明书及附图内容所作的等效结构或等效流程变换,或直接或间接运用在其他相关的技术领域,均同理包括在本发明的专利保护范围内。

Claims (10)

1.一种移动终端上传文件的方法,其特征在于包含:
接收上传文件到服务器的命令,获取待上传文件,对文件按照公式Y=N-X*(n-1)进行分块、直到Y小于X为止,其中N为设定的固定分块值,X为设定的递减值,n为当前分块次数;
逐个上传分块,并检测上传是否成功,如果检测到全部分块上传成功,则结束;否则对文件未上传成功的部分按照上述公式重新分块并上传,直到文件全部上传成功。
2.根据权利要求1所述的移动终端上传文件的方法,其特征在于:所述服务器包含业务服务器和文件服务器,所述文件上传后存储于文件服务器。
3.根据权利要求1所述的移动终端上传文件的方法,其特征在于:上传分块的同时上传所述分块的开始位置和结束位置至服务器。
4.根据权利要求3所述的移动终端上传文件的方法,其特征在于:所述分块的开始位置为已经发送的文件大小;所述分块的结束位置为已经发送的文件大小与当前分块的大小之和。
5.根据权利要求1所述的移动终端上传文件的方法,其特征在于:所述递减值小于或等于所述固定分块值的一半。
6.一种移动终端上传文件的装置,其特征在于包含:
文件获取单元,用于接收上传文件到服务器的命令,获取待上传文件,或者接收到文件上传失败的信号后,获取未上传成功的文件;
分块单元,用于对文件获取单元所获取的文件按照公式Y=N-X*(n-1)进行分块、直到Y小于X为止,其中N为设定的固定分块值,X为设定的递减值,n为当前分块次数;
上传单元,逐个上传分块以及上传不能再被分块的剩余文件,并检测上传是否成功,如果检测到全部分块上传成功的信号,则结束;否则发出上传失败的信号。
7.根据权利要求6所述的移动终端上传文件的装置,其特征在于:所述服务器包含业务服务器和文件服务器,所述文件上传后存储于文件服务器。
8.根据权利要求6所述的移动终端上传文件的装置,其特征在于还包含:位置获取单元,用于获取上传分块的开始位置和结束位置并上传至服务器。
9.根据权利要求8所述的移动终端上传文件的装置,其特征在于:所述分块的开始位置为已经发送的文件大小;所述分块的结束位置为已经发送的文件大小与当前分块的大小之和。
10.根据权利要求6所述的移动终端上传文件的装置,其特征在于:所述递减值小于或等于所述固定分块值的一半。
CN201610944316.5A 2016-10-26 2016-10-26 一种移动终端上传文件的方法和装置 Pending CN106534282A (zh)

Priority Applications (1)

Application Number Priority Date Filing Date Title
CN201610944316.5A CN106534282A (zh) 2016-10-26 2016-10-26 一种移动终端上传文件的方法和装置

Applications Claiming Priority (1)

Application Number Priority Date Filing Date Title
CN201610944316.5A CN106534282A (zh) 2016-10-26 2016-10-26 一种移动终端上传文件的方法和装置

Publications (1)

Publication Number Publication Date
CN106534282A true CN106534282A (zh) 2017-03-22

Family

ID=58293152

Family Applications (1)

Application Number Title Priority Date Filing Date
CN201610944316.5A Pending CN106534282A (zh) 2016-10-26 2016-10-26 一种移动终端上传文件的方法和装置

Country Status (1)

Country Link
CN (1) CN106534282A (zh)

Cited By (1)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN107832309A (zh) * 2017-10-18 2018-03-23 广东小天才科技有限公司 一种语言翻译的方法、装置、可穿戴设备及存储介质

Citations (4)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN101158954A (zh) * 2007-11-07 2008-04-09 上海爱数软件有限公司 一种在计算机存储中识别重复数据的方法
CN101609495A (zh) * 2009-08-05 2009-12-23 北京逍遥掌信息技术有限公司 一种电子文件数字版权管理方法
US20120136937A1 (en) * 2006-11-30 2012-05-31 Red Hat, Inc. Automated evaluation of content based on user activities
CN105282200A (zh) * 2014-07-18 2016-01-27 中国电信股份有限公司 断点续传的方法与服务器

Patent Citations (4)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US20120136937A1 (en) * 2006-11-30 2012-05-31 Red Hat, Inc. Automated evaluation of content based on user activities
CN101158954A (zh) * 2007-11-07 2008-04-09 上海爱数软件有限公司 一种在计算机存储中识别重复数据的方法
CN101609495A (zh) * 2009-08-05 2009-12-23 北京逍遥掌信息技术有限公司 一种电子文件数字版权管理方法
CN105282200A (zh) * 2014-07-18 2016-01-27 中国电信股份有限公司 断点续传的方法与服务器

Cited By (1)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN107832309A (zh) * 2017-10-18 2018-03-23 广东小天才科技有限公司 一种语言翻译的方法、装置、可穿戴设备及存储介质

Similar Documents

Publication Publication Date Title
CN104951229B (zh) 屏幕截图方法和装置
CN104954867A (zh) 媒体播放方法及装置
CN106453652A (zh) 日志文件上传方法及系统
CN106803860A (zh) 一种终端应用的存储处理方法和装置
CN104951236A (zh) 一种终端设备壁纸的配置方法及相应终端设备
CN105302864A (zh) 根据屏幕分辨率加载图片的装置和方法
CN104898940A (zh) 图片处理方法及装置
CN105263195A (zh) 数据传输装置及方法
CN105278995A (zh) 应用程序的管理方法、系统、服务器和移动终端
CN106598538A (zh) 指令集合更新方法及系统
CN105872997A (zh) 一种短信合并方法及终端设备
CN105573916A (zh) 故障检测方法及移动终端
CN104866095A (zh) 移动终端及其桌面管理方法和装置
CN106657643A (zh) 一种移动终端及通讯会话显示方法
CN106488035A (zh) 一种移动终端和控制方法
CN106790994A (zh) 控件的触发方法及移动终端
CN106506364A (zh) 一种接入方法、客户端和路由服务器
CN106412328A (zh) 一种获取用户反馈信息的方法和装置
CN105740668A (zh) 终端锁屏装置和方法
CN106227454B (zh) 一种触控轨迹检测系统及方法
CN107092510A (zh) 移动终端及其固件升级方法与装置
CN106534498A (zh) 一种应用文件夹的控制装置、方法及移动终端
CN106550133A (zh) 来电提醒装置及方法
CN106569690A (zh) 防止误触装置和方法
CN105721757A (zh) 一种调整拍摄参数的装置和方法

Legal Events

Date Code Title Description
C06 Publication
PB01 Publication
SE01 Entry into force of request for substantive examination
SE01 Entry into force of request for substantive examination
RJ01 Rejection of invention patent application after publication
RJ01 Rejection of invention patent application after publication

Application publication date: 20170322