一种联系人同步装置及方法与流程

文档序号:12694527阅读:193来源:国知局
一种联系人同步装置及方法与流程

本发明涉及移动通信技术领域,尤指一种联系人同步装置及方法。



背景技术:

现代人的交际面越来越广,需要存储的联系人信息业越来越多。为防止设备中联系人信息的丢失,各手机厂商以及软件厂商纷纷推出了联系人信息云同步的功能。可以理解的是,同一联系人可能有不止一个号码,如办公室或家庭的联系电话、固话或手机号码等,为方便查看,在进行联系人信息的同步时,通常会对同一联系人的联系人条目进行合并处理。

在公开号为“CN105872124A”,发明名称为“联系人同步装置及方法”的申请中,指出了通过云端同步服务器对同一联系人的联系人条目进行合并处理,导致云端同步服务器效率下降的问题,并提出通过将在同步服务器集中执行的联系人条目的合并处理分散到用户侧各个独立的联系人同步装置执行,能够降低同步服务器的处理压力,提高联系人同步的效率。但是,在实际应用中,当联系人条目中包含附件时(该附件可以为联系人头像、来电铃声等),使用这样的同步装置和方法,容易导致客户端和服务器数据交互时,联系人附件信息丢失或不同步的现象。



技术实现要素:

为了解决上述技术问题,本发明提供了一种联系人同步装置及方法,旨在保证客户端和服务器之间的联系人附件信息的同步。

为了达到本发明目的,本发明实施例的技术方案是这样实现的:

一种联系人同步装置,包括请求模块、合并模块、下载模块、上传模块和同步模块;其中,

请求模块,用于发送联系人同步请求至服务器,以供服务器基于接收的联系人同步请求返回待同步云端联系人数据;

合并模块,用于根据接收的待同步云端联系人数据中的云端附件信息,生成待下载附件列表并将其发送至下载模块;将接收的待同步云端联系人数据与本地联系人数据合并,将修改标记为预设值的合并后本地联系人数据,标记为待同步本地联系人数据并将其发送至上传模块和同步模块;

下载模块,用于根据待下载附件列表下载附件;

上传模块,用于将待同步本地联系人数据中的本地附件信息所关联的附件,上传至服务器;通知同步模块;

同步模块,用于接收到来自上传模块的通知,将待同步本地联系人数据发送至服务器,以供服务器基于接收的待同步本地联系人数据更新云端联系人数据。

可选地,所述上传模块中的将附件上传至服务器具体包括,将附件进行分块处理,并按分块顺序并发上传。

可选地,所述云端附件信息包括云端文件序列号和附件云端路径;所述本地附件信息包括本地文件序列号、云端文件序列号、附件云端路径和附件本地路径。

可选地,所述云端附件信息和本地附件信息还包括文件大小、文件校验码和文件创建时间。

可选地,所述上传模块将附件上传至服务器之前,先发送携带鉴权信息的上传附件请求至服务器,以供所述服务器基于接收的鉴权信息进行鉴权操作,并在鉴权通过时响应上传模块的上传附件请求。

一种联系人同步方法,包括以下步骤:

客户端发送联系人同步请求至服务器;

服务器基于接收的联系人同步请求,返回待同步云端联系人数据;

客户端根据接收的待同步云端联系人数据中的云端附件信息,生成待下载附件列表;并将接收的待同步云端联系人数据与本地联系人数据合并,将修改标记为预设值的合并后本地联系人数据,标记为待同步本地联系人数据;

客户端根据待下载附件列表下载附件;

客户端将待同步本地联系人数据中的本地附件信息所关联的附件,上传至服务器;

客户端将待同步本地联系人数据发送至服务器;

服务器根据接收的待同步本地联系人数据,更新云端联系人数据。

可选地,所述客户端上传附件至服务器时,将附件进行分块处理,并按分块顺序并发上传。

可选地,所述云端附件信息包括云端文件序列号和附件云端路径;所述本地附件信息包括本地文件序列号、云端文件序列号、附件云端路径和附件本地路径。

可选地,所述云端附件信息和本地附件信息还包括文件大小、文件校验码和文件创建时间。

可选地,所述客户端将附件上传至服务器之前,先发送携带鉴权信息的上传附件请求至服务器,以供所述服务器基于接收的鉴权信息进行鉴权操作,并在鉴权通过时响应客户端的上传附件请求。

本发明的联系人同步装置及方法,通过采用先发送附件、再发送待同步本地联系人条目的顺序,可以防止采用相反顺序时,由于客户端网络断掉,附件上传不了导致服务器端存在缺失附件的联系人数据的问题,从而保证了服务器端的联系人数据的完整性,实现了客户端和服务器之间的联系人附件信息的同步。

附图说明

此处所说明的附图用来提供对本发明的进一步理解,构成本申请的一部分,本发明的示意性实施例及其说明用于解释本发明,并不构成对本发明的不当限定。在附图中:

图1为实现本发明各个实施例的移动终端的硬件结构示意图;

图2为本发明联系人同步装置第一实施例的功能模块示意图;

图3为本发明联系人同步装置第二实施例的功能模块示意图;

图4为本发明联系人同步方法第一实施例的流程示意图;

图5为本发明联系人同步方法第二实施例的流程示意图。

具体实施方式

下面将结合附图及实施例对本发明的技术方案进行更详细的说明。

现在将参考附图描述实现本发明各个实施例的移动终端。在后续的描述中,使用用于表示元件的诸如“模块”、“部件”或“单元”的后缀仅为了有利于本发明的说明,其本身并没有特定的意义。因此,"模块"与"部件"可以混合地使用。

移动终端可以以各种形式来实施。例如,本发明中描述的终端可以包括诸如移动电话、智能电话、笔记本电脑、数字广播接收器、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是否与外部装置耦接。感测单元140可以包括接近传感器1410将在下面结合触摸屏来对此进行描述。

接口单元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所示,在本发明的一种联系人同步装置的第一实施例中,该联系人同步装置包括:

请求模块,用于发送联系人同步请求至服务器,以供服务器基于接收的联系人同步请求返回待同步云端联系人数据;

合并模块,用于根据接收的待同步云端联系人数据中的云端附件信息,生成待下载附件列表,并将待下载附件列表发送至下载模块;将待同步云端联系人数据与本地联系人数据合并,将修改标记为预设值的合并后本地联系人数据,标记为待同步本地联系人数据,并将待同步本地联系人数据分别发送至上传模块和同步模块;

下载模块,用于根据待下载附件列表下载附件;

上传模块,用于将待同步本地联系人数据中的本地附件信息所关联的附件,上传至服务器;并通知同步模块;

同步模块,用于接收到来自上传模块的通知,将待同步本地联系人数据发送至服务器,以供服务器基于接收的待同步本地联系人数据更新云端联系人数据。

进一步地,在本实施例中,为保证联系人数据以及服务器的安全,请求模块发送联系人同步请求之前,先发送鉴权信息至服务器,以供服务器基于接收的鉴权信息进行鉴权操作,并在鉴权通过时返回配置有第一生存时间的用户令牌(token),可选地,第一生存时间可以设置为一个月或其它任意的时间段长度。其中,鉴权信息包括客户端的归属用户的用户标识和密码。服务器通过该用户标识和密码验证客户端是否合法,是则鉴权通过。

请求模块发送携带用户令牌和客户端版本号的联系人同步请求至服务器。服务器接收到联系人同步请求后,首先验证用户令牌是否有效,即是否超过第一生存时间;在用户令牌有效时,通过鉴权操作时产生的用户标识和用户令牌的映射关系,查找目标用户的云端联系人数据中,所有服务器版本号大于客户端版本号的云端联系人数据,并将其作为待同步云端联系人数据,另外服务器生成一个配置有第二生存时间的会话标识(Session ID),服务器返回待同步云端联系人数据时,同时返回该会话标识和当前服务器版本号;可选地,第二生存时间可以设置为五分钟或其它任意的时间段长度。

进一步地,合并模块收到服务器返回的携带会话标识和当前服务器版本号的待同步云端联系人数据后,记录该会话标识,比较当前服务器版本号与客户端版本号,如果当前服务器版本号大于客户端版本号,依次提取待同步云端联系人数据中的各云端联系人数据;

基于提取的云端联系人数据所携带的云端标识,以及客户端存储的云端标识和本地标识的映射关系,获取与该云端标识对应的本地标识,判断该本地标识所关联的本地联系人数据的附件云端路径与提取的云端联系人数据的附件云端路径是否一致,如果不一致,将该本地标识与提取的云端联系人数据中的附件云端路径加入待下载附件列表;

判断该本地标识所关联的本地联系人数据的修改标记是否为预设值;

当本地标识所关联的本地联系人数据的修改标记为预设值时,基于提取的云端联系人数据创建新的本地联系人数据,并分配新的本地标识,将分配的本地标识与默认云端标识关联,以及将分配的本地标识关联的修改标记置为预设值;

当本地标识所关联的本地联系人数据的修改标记不为预设值时,将本地标识所关联的本地联系人数据替换为提取的云端联系人数据;

在完成待同步云端联系人数据的提取操作后,将待下载附件列表发送至下载模块,对所关联的修改标记为预设值的各本地联系人数据进行合并操作;

将客户端版本号修改为当前服务器版本号;以及

将所关联的修改标记为预设值的合并后本地联系人数据,标记为待同步本地联系人数据,并将待同步本地联系人数据分别发送至上传模块和同步模块。

进一步地,下载模块,根据待下载附件列表中的附件云端路径下载附件,并将附件信息存储至本地标识所关联的本地联系人数据的本地附件信息中。通常来说,本地联系人数据中电话号码、姓名等信息出现重复的可能性比较大,因此本发明采用先合并重复的本地联系人数据、再下载附件的顺序,可以避免多次重复的下载附件,节约了网络带宽。

可选地,客户端本地联系人数据中的本地附件信息包括本地文件序列号、云端文件序列号、附件云端路径、附件本地路径。

可选地,客户端本地联系人数据中的本地附件信息还包括文件大小、文件校验码和文件创建时间等。

进一步地,上传模块依次提取待同步本地联系人数据中的各本地联系人数据,检测提取的本地联系人数据中是否包括附件且附件云端路径是否为空,如果包括附件且附件云端路径为空,则将该附件上传至服务器,记录服务器返回的附件云端路径信息,生成上传附件列表,将该本地联系人数据关联的云端标识和附件云端路径加入上传附件列表,并将上传附件列表发送至同步模块,通知同步模块。

可选地,上传模块将附件上传至服务器时,将附件进行分块处理,并按分块顺序并发上传。

可选地,附件服务器和联系人数据服务器可以是一体的或分离的,通过搭建分离的附件服务器和联系人数据服务器,可以为客户端上传附件预留更多的上行带宽,从而保证了用户的上传体验。

可选地,上传模块将附件上传至服务器之前,首先发送携带用户令牌的上传附件请求至服务器,以供服务器在且仅在用户令牌的第一生存时间内响应接收的上传附件请求。由于通常用户上传的附件比较大,上传时间也比较长,而用户令牌配置的第一生存时间通常比会话标识配置的第二生存时间长,因此通过用户令牌对上传附件请求进行鉴权,可以保证上传附件请求不会在短期内失效。

进一步地,同步模块接收到上传模块的通知后,设置待同步本地联系人数据的附件变更标记,发送携带会话标识、客户端版本号、附件变更标记和上传附件列表的待同步本地联系人数据至服务器。服务器收到待同步本地联系人数据后,先验证待同步本地联系人数据中的会话标识是否有效,如果会话标识失效(会话标识超过第二生存时间),提示客户端会话标识失效;如果会话标识有效,

服务器检测附件变更标记是否为预设值,如果附件变更标记为预设值,验证上传附件列表中的附件云端路径是否为有效链接,如果附件云端路径的链接无效,提示客户端先上传附件;如果附件云端路径的链接有效,

服务器验证客户端操作是否被锁且客户端版本号是否等于当前服务器版本号,如果客户端操作被锁或客户端版本号不等于当前服务器版本号,删除会话标识,并提示客户端稍后重新发起同步请求;如果客户端操作未被锁且客户端版本号等于当前服务器版本号,

服务器对该用户添加操作锁,逐个处理待同步本地联系人数据,处理完成后将当前服务器版本号加一,删除会话标识,对用户解锁。

服务器逐个处理待同步本地联系人数据,具体包括:

服务器依次提取待同步本地联系人数据中的各本地联系人数据;在每次提取到本地联系人数据时,若提取的本地联系人数据的删除标记为预设值,基于提取的本地联系人数据所携带的云端标识,以及服务器存储的云端标识和云端联系人数据的映射关系,删除对应的云端联系人数据;若提取的本地联系人数据的删除标记不是预设值,判断提取的本地联系人数据所携带的云端标识是否为默认云端标识,

在提取的本地联系人数据所携带的云端标识为默认云端标识时,基于提取的本地联系人数据创建新的云端联系人数据,并分配新的云端标识,将新的云端标识与提取的本地联系人数据所携带的本地标识关联;

在提取的本地联系人数据所携带的云端标识不为默认云端标识时,将该云端标识所关联的云端联系人数据替换为提取的本地联系人数据,并将该记录的服务器版本号字段更新为当前服务器版本加一。

本发明的联系人同步装置,采用先发送附件、再发送待同步本地联系人数据的顺序,可以防止采用相反顺序时,由于客户端网络断掉,附件上传不了导致服务器端存在缺失附件的联系人数据的问题,并且通过服务器定期清理没有与任何联系人数据关联的附件,从而保证了服务器端的联系人数据的完整性。

在本实施例中,客户端本地联系人数据包括客户端本地联系人条目和本地附件信息,客户端本地联系人条目和本地附件信息可以存储在一起,也可以分开存储。当两者分开存储时,通过本地标识(Local ID)将客户端本地联系人条目与对应的本地附件信息相关联,每个客户端本地联系人条目可以对应多个附件。客户端本地联系人条目的存储记录结构如表1所示。

表1

客户端本地联系人数据中的本地附件信息,存储记录结构如表2所示。

表2

服务器云端联系人数据包括服务器云端联系人条目和云端附件信息,服务器云端联系人条目和云端附件信息可以存储在一起,也可以分开存储。当两者分开存储时,通过云端标识(Server ID)将云端联系人条目与对应的云端附件信息相关联。服务器云端联系人条目的存储记录结构如表3所示。

表3

云端附件信息的存储记录结构如表4所示。

表4

进一步地,参照图3,在本发明的一种联系人同步装置的第二实施例中,该联系人同步装置还包括:

更新模块,用于接收服务器返回的云端标识和本地标识的映射关系,更新本地存储的云端标识和本地标识的映射关系。

服务器更新完云端联系人数据后,返回新的云端标识和本地标识的映射关系至更新模块所在的客户端,供更新模块更新其所在的客户端存储的云端标识与本地标识的映射关系,实现服务器端映射关系和客户端映射关系的同步。

如图4所示,在本发明的一种联系人同步方法的第一实施例中,该联系人同步方法,包括如下步骤:

步骤S10,客户端发送联系人同步请求至服务器;

步骤S20,服务器基于接收的联系人同步请求,返回待同步云端联系人数据;

步骤S30,客户端根据接收的待同步云端联系人数据中的云端附件信息,生成待下载附件列表;并将接收的待同步云端联系人数据与本地联系人数据合并,将修改标记为预设值的合并后本地联系人数据,标记为待同步本地联系人数据;

步骤S40,客户端根据待下载附件列表下载附件;

步骤S50,客户端将待同步本地联系人数据中的本地附件信息所关联的附件,上传至服务器;

步骤S60,客户端将待同步本地联系人数据发送至服务器;

步骤S70,服务器根据接收的待同步本地联系人数据,更新云端联系人数据。

进一步地,在本实施例中,为保证联系人数据以及服务器的安全,步骤S10之前还包括:

发送鉴权信息至服务器,以供服务器基于接收的鉴权信息进行鉴权操作,并在鉴权通过时返回配置有第一生存时间的用户令牌(token),可选地,第一生存时间可以设置为一个月或其它任意的时间段长度。其中,鉴权信息包括客户端的归属用户的用户标识和密码。服务器通过该用户标识和密码验证客户端是否合法,是则鉴权通过;

步骤S10包括:

客户端发送携带用户令牌和客户端版本号的联系人同步请求至服务器,以供服务器在且仅在用户令牌的第一生存时间内根据客户端版本号响应接收的联系人同步请求。

进一步地,在本实施例步骤S20中,服务器接收到联系人同步请求后,首先验证用户令牌是否有效,即是否超过第一生存时间;在用户令牌有效时,通过鉴权操作时产生的用户标识和用户令牌的映射关系,查找目标用户的云端联系人数据中,所有服务器版本号大于客户端版本号的云端联系人数据,将其作为待同步云端联系人数据,另外服务器生成一配置有第二生存时间的会话标识(Session ID),服务器返回待同步云端联系人数据时,同时返回该会话标识和当前服务器版本号;可选地,第二生存时间可以设置为五分钟或其它任意的时间段长度。

进一步地,在本实施例步骤S30中,客户端获取到服务器返回的携带会话标识和当前服务器版本号的待同步云端联系人数据后,记录该会话标识,比较当前服务器版本号与客户端版本号,如果当前服务器版本号大于客户端版本号,根据返回的待同步云端联系人数据修改本地联系人数据,具体包括如下步骤:

步骤A,依次提取待同步云端联系人数据中的各云端联系人数据,基于提取的云端联系人数据所携带的云端标识,以及客户端存储的云端标识和本地标识的映射关系,获取提取的云端联系人数据对应的本地标识,判断该本地标识所关联的附件云端路径与提取的云端联系人数据的附件云端路径是否一致,若不一致,将该本地标识与提取的云端联系人数据中的附件云端路径加入待下载附件列表;

步骤B,判断获取的本地标识所关联的修改标记是否为预设值,是则执行步骤C,否则执行步骤D;

步骤C,基于提取的云端联系人数据创建新的本地联系人数据,并分配新的本地标识,将分配的本地标识与默认云端标识关联,以及将分配的本地标识关联的修改标记置为预设值;若当前提取的云端联系人数据为最后一条,则转入步骤E,否则转入执行步骤A;

步骤D,将获取的本地标识关联的本地联系人数据替换为提取的云端联系人数据,若当前提取的云端联系人数据为最后一条,则转入执行步骤E,否则转入执行步骤A;

步骤E,对所关联的修改标记为预设值的各本地联系人数据进行合并操作,将客户端版本号修改为当前服务器版本号;以及将所关联的修改标记为预设值的合并后本地联系人数据,标记为待同步本地联系人数据。

进一步地,本实施例中,步骤S40,根据待下载附件列表中的附件云端路径下载附件,并将附件信息存储至本地标识所关联的本地附件信息中。

可选地,本地附件信息包括本地文件序列号、云端文件序列号、附件云端路径、附件本地路径。

可选地,本地附件信息还包括文件大小、文件校验码和文件创建时间等。

可选地,本实施例中,步骤S50,客户端依次提取待同步本地联系人数据中的各本地联系人数据,判断提取的本地联系人数据中是否包括附件且附件云端路径是否为空,如果包括附件且附件云端路径为空,则将该附件上传至服务器,记录服务器返回的云端路径信息,生成上传附件列表,并将该本地联系人数据关联的云端标识和附件云端路径加入上传附件列表。

可选地,客户端上传附件至服务器时,将附件进行分块处理,并按分块顺序并发上传。

可选地,附件服务器和联系人数据服务器可以是一体的或分离的,通过搭建分离的附件服务器和联系人数据服务器,可以为客户端上传附件预留更多的上行带宽,从而保证了用户的上传体验。

可选地,客户端将附件上传至服务器之前,先发送携带用户令牌的上传附件请求至服务器,以供服务器在且仅在用户令牌的第一生存时间内响应接收的上传附件请求。由于通常用户上传的附件比较大,上传时间也比较长,而用户令牌配置的第一生存时间通常比会话标识配置的第二生存时间长,因此通过用户令牌对上传附件请求进行鉴权,可以保证上传附件请求不会在短期内失效。

进一步地,在本实施例步骤S60中,客户端设置待同步本地联系人数据的附件变更标记,发送携带会话标识、客户端版本号、附件变更标记和上传附件列表的待同步本地联系人数据至服务器。本发明的联系人同步方法,采用先发送附件、再发送待同步本地联系人数据的顺序,可以防止采用相反顺序时,由于客户端网络断掉,附件上传不了导致服务器端存在缺失附件的联系人数据的问题,并且通过服务器定期清理没有与任何联系人数据关联的附件,从而保证了服务器端的联系人数据的完整性。

进一步地,步骤S70,服务器基于接收的待同步本地联系人数据,更新云端联系人数据,具体包括:

步骤S701,服务器验证待同步本地联系人数据中的会话标识是否有效,如果会话标识失效(会话标识超过第二生存时间),提示客户端会话标识失效;如果会话标识有效,转到步骤S702;

步骤S702,服务器检测接收的待同步本地联系人数据中的附件变更标记,如果附件变更标记为预设值,检测上传附件列表中的附件云端路径是否为有效链接,如果附件云端路径的链接无效,提示客户端先上传附件;如果附件云端路径的链接有效或附件变更标记不为预设值,转到步骤S703;

步骤S703,服务器验证客户端操作是否被锁且客户端版本号是否等于当前服务器版本号,如果客户端操作被锁或客户端版本号不等于当前服务器版本号,删除会话标识,并提示客户端稍后重新发起同步请求;如果客户端操作未被锁且客户端版本号等于当前服务器版本号,转到步骤S704;

步骤S704,服务器对该用户添加操作锁,逐个处理待同步本地联系人数据,处理完成后将当前服务器版本号加一,删除会话标识,对用户解锁。

进一步地,步骤S704中,服务器逐个处理待同步本地联系人数据,具体包括:

服务器依次提取待同步本地联系人数据中的各本地联系人数据;若提取的本地联系人数据的删除标记为预设值,基于提取的本地联系人数据所携带的云端标识,以及服务器存储的云端标识和云端联系人数据的映射关系,删除对应的云端联系人数据;若提取的本地联系人数据的删除标记不是预设值,判断提取的本地联系人数据所携带的云端标识是否为默认云端标识,

在提取的本地联系人数据所携带的云端标识为默认云端标识时,基于提取的本地联系人数据创建新的云端联系人数据,并分配新的云端标识,将新的云端标识与提取的本地联系人数据所携带的本地标识关联;

在提取的本地联系人数据所携带的云端标识不为默认云端标识时,将该云端标识所关联的云端联系人数据替换为提取的本地联系人数据,并将该记录的服务器版本号字段更新为当前服务器版本加一。

进一步地,参照图5,在本发明的一种联系人同步方法的第二实施例中,该联系人同步方法包括如下步骤:

步骤S10,客户端发送联系人同步请求至服务器;

步骤S20,服务器基于接收的联系人同步请求,返回待同步云端联系人数据;

步骤S30,客户端根据接收的待同步云端联系人数据中的云端附件信息,生成待下载附件列表;并将接收的待同步云端联系人数据与本地联系人数据合并,将修改标记为预设值的合并后本地联系人数据,标记为待同步本地联系人数据;

步骤S40,客户端根据待下载附件列表下载附件;

步骤S50,客户端将待同步本地联系人数据中的本地附件信息所关联的附件,上传至服务器;

步骤S60,客户端将待同步本地联系人数据发送至服务器;

步骤S70,服务器根据接收的待同步本地联系人数据,更新云端联系人数据;

步骤S80,服务器返回新的云端标识与本地标识的映射关系至客户端;

步骤S90,客户端更新其存储的云端标识与本地标识的映射关系。

在本实施例中,通过步骤S80和S90,实现服务器端与客户端映射关系的同步。

需要说明的是,在本文中,术语“包括”、“包含”或者其任何其他变体意在涵盖非排他性的包含,从而使得包括一系列要素的过程、方法、物品或者装置不仅包括那些要素,而且还包括没有明确列出的其他要素,或者是还包括为这种过程、方法、物品或者装置所固有的要素。在没有更多限制的情况下,由语句“包括一个……”限定的要素,并不排除在包括该要素的过程、方法、物品或者装置中还存在另外的相同要素。

通过以上的实施方式的描述,本领域的技术人员可以清楚地了解到上述实施例方法可借助软件加必需的通用硬件平台的方式来实现,当然也可以通过硬件,但很多情况下前者是更佳的实施方式。基于这样的理解,本发明的技术方案本质上或者说对现有技术做出贡献的部分可以以软件产品的形式体现出来,该计算机软件产品存储在一个存储介质(如ROM/RAM、磁碟、光盘)中,包括若干指令用以使得一台终端设备(可以是手机,计算机,服务器,空调器,或者网络设备等)执行本发明各个实施例所述的方法。

以上仅为本发明的优选实施例,并非因此限制本发明的专利范围,凡是利用本发明说明书及附图内容所作的等效结构或等效流程变换,或直接或间接运用在其他相关的技术领域,均同理包括在本发明的专利保护范围内。

当前第1页1 2 3 
网友询问留言 已有0条留言
  • 还没有人留言评论。精彩留言会获得点赞!
1