CN109726028A - 一种中间存储方法 - Google Patents
一种中间存储方法 Download PDFInfo
- Publication number
- CN109726028A CN109726028A CN201910047758.3A CN201910047758A CN109726028A CN 109726028 A CN109726028 A CN 109726028A CN 201910047758 A CN201910047758 A CN 201910047758A CN 109726028 A CN109726028 A CN 109726028A
- Authority
- CN
- China
- Prior art keywords
- shear plate
- client
- transfer
- message
- user
- 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.)
- Granted
Links
Landscapes
- Information Transfer Between Computers (AREA)
- Information Retrieval, Db Structures And Fs Structures Therefor (AREA)
Abstract
本发明涉及一种中间存储方法,该方法提供了一个中转服务端,为不同客户端中拷贝对象的上传和下载提供中转服务,使得不同客户端之间可共享剪切对象,并且进一步提供了保护中转数据隐私的方法。
Description
【技术领域】
本发明属计算机数据管理领域,尤其涉及一种计算机上的中间存储方法。
【背景技术】
随着4A系统的推广和安全级别的提高,系统剪切板已经不能满足管理员的需求。实际操作中需要剪切板能够满足系统上行拷贝和下行拷贝的控制,并且需要对剪切对象进行分别控制和权限开放,且在开放的权限范围内可以对操作进行审计,管理员能够在事后进行查询历史操作。
【发明内容】
为了解决现有技术中的上述问题,本发明提供了一种中间存储方法。
本发明采用的技术方案具体如下:
一种中间存储方法,包括以下步骤:
(1)用户在中转服务端注册,注册信息包括剪切板ID;
(2)用户在第一客户端设置其使用的剪切板ID以及粘贴命令键组合;
(3)用户在第一客户端使用拷贝命令,将选择的对象拷贝到第一客户端的系统剪切板中;
(4)第一客户端计算所述粘贴命令键组合的哈希值,并扩展所述哈希值,扩展结果与所述对象的位数相同;
(5)设所述对象为object,所述扩展结果为K,则第一客户端计算Result=object⊕K,并生成一个中转消息,所述中转消息中包括了所述Result和第一客户端当前使用的剪切板ID,并将所述中转消息发送给中转服务端;
(6)中转服务端接收到所述中转消息,基于所述中转消息,将所述Result存储到所述剪切板ID对应的中转剪切板中;
(7)用户在第二客户端设置其使用的剪切板ID;
(8)用户在第二客户端使用粘贴命令键组合,第二客户端生成一个同步消息,所述同步消息中包括了第二客户端的剪切板ID和上次同步的时间戳;
(9)所述第二客户端将所述同步消息发送给中转服务端,中转服务端根据同步消息确定是否有新的剪切板数据需要同步到第二客户端,并生成一个同步响应消息,所述同步响应消息中包括了本次同步的时间戳以及所述新剪切板数据;中转服务端将所述同步响应消息发送给所述第二客户端;
(10)第二客户端接收所述同步响应消息,从同步响应消息中解析出新剪切板数据,对于新剪切板数据中的每一个Result,第二客户端计算所述粘贴命令键组合的哈希值,并扩展所述哈希值,使扩展结果K与所述Result的位数相同,通过计算Result⊕K得到相应的对象。
进一步地,所述剪切板ID是剪切板的唯一标识符,用于在中转服务端区分不同的中转剪切板。
进一步地,所述对象是文本或者文件。
进一步地,用户可在客户端同时设置多个剪切板ID,相应的中转消息也包括所述多个剪切板ID。
进一步地,中转剪切板按照收到中转消息的时间顺序来存储中转消息中的对象,从而在中转剪切板中形成一个基于时间顺序的对象队列。
进一步地,所述时间戳是真实时间,或者是同步序号。
进一步地,如果没有需要同步的新数据,则所述同步响应消息就只包括本次同步的时间戳。
进一步地,如果同步响应消息中包括了多个新剪切板数据,则同步响应消息中包括了这些新剪切板数据在时间上的先后顺序。
进一步地,在步骤10之后,所述第二客户端直接粘贴系统剪切板中最新的对象。
进一步地,在步骤10之后,所述第二客户端向用户展示系统剪切板中的多个对象,由用户来选择其要粘贴的对象。
【附图说明】
此处所说明的附图是用来提供对本发明的进一步理解,构成本申请的一部分,但并不构成对本发明的不当限定,在附图中:
图1是本发明方法应用的系统结构图。
【具体实施方式】
下面将结合附图以及具体实施例来详细说明本发明,其中的示意性实施例以及说明仅用来解释本发明,但并不作为对本发明的限定。
参见附图1,其示出了本发明所应用的一个基本环境结构,该环境中包括至少两个客户端,以及一个中转服务端,客户端和中转服务端之间通过网络连接并传输数据。本发明方法的目的是在不同客户端之间共享剪切对象,每个客户端都具有其自己的系统剪切板,当一个客户端在其系统剪切板中增加一个对象后,可以通过中转服务端发送给另一个客户端,从而使得另一个客户端可以使用该对象。下面详细说明本发明的方法流程。
(1)用户在中转服务端注册,注册信息包括剪切板ID。
由于系统中可以具有大量的客户端,为了只获取需要的剪切对象,首先需要对剪切对象进行区分。为此,用户先在中转服务端注册剪切板ID,所述剪切板ID是剪切板的唯一标识符,用于在中转服务端区分不同的中转剪切板。
(2)用户在第一客户端设置其使用的剪切板ID。
用户使用的剪切板ID可以是自己注册的,也可以是其他用户注册的。如果是其他用户注册,需要在事先与其他用户沟通,获取其剪切板ID。
用户也可以同时设置多个剪切板ID,如果设置了多个剪切板ID,则意味着用户同时使用了多个中转剪切板,每个剪切对象可以同时上传到所述多个中转剪切板。
(3)用户在第一客户端使用拷贝命令,将选择的对象拷贝到第一客户端的系统剪切板中。
例如,在计算机中通常使用的拷贝命令是“Ctrl+C”,当用户选择某个对象,并按下“Ctrl+C”后,该对象就被拷贝到系统剪切板中。所述对象可以是一段文本或者一个文件等等,具体的对象类型本发明不作限制。
(4)所述第一客户端生成一个中转消息,所述中转消息中包括了所述对象和第一客户端当前使用的剪切板ID,并将所述中转消息发送给中转服务端。
具体的,设中转消息为M,则M={object,ID},其中object代表所述对象,ID为所述剪切板ID。
如果第一客户端使用了多个剪切板ID,则M={object,ID1,ID2,……}。
(5)中转服务端接收到所述中转消息,基于所述中转消息,将所述对象存储到所述剪切板ID对应的中转剪切板中。
如前所述,每个剪切板ID对应了一个中转剪切板,所述中转剪切板是由中转服务端维护的,当用户注册了一个剪切板ID后,中转服务端就为其建立了对应的中转剪切板。因此,当中转服务端接收到所述中转消息后,可以基于中转消息将对象存储到相应的中转剪切板中。
对于同一个中转剪切板,中转服务端可能会先后收到多个相应的中转消息,则中转剪切板按照收到中转消息的时间顺序来存储中转消息中的对象,从而在中转剪切板中形成一个基于时间顺序的对象队列。
(6)用户在第二客户端设置其使用的剪切板ID。
第二客户端的剪切板ID取决于用户想要使用的中转剪切板,想要与哪些客户端共享剪切板。需要说明的是,第一客户端和第二客户端在本发明中的地位完全是等价的,第一客户端和第二客户端使用了相同的剪切板ID,则这两个客户端共享同一个中转剪切板。
(7)用户在第二客户端使用粘贴命令,第二客户端生成一个同步消息,所述同步消息中包括了第二客户端的剪切板ID和上次同步的时间戳。
在计算机中常见的粘贴命令是“Ctrl+V”,当然也可以使用自定义的粘贴命令(这一点在后面说明)。当第二客户端接收到粘贴命令时,首先将本地的系统剪切板与中转剪切板进行同步,获取中转剪切板中的新对象,然后决定粘贴哪个对象。
每次同步,中转服务端都会给出一个相应的同步时间戳,以方便后续同步时的增量同步。如果这是第二客户端的第一个同步消息,则将同步消息中的时间戳设置为0,以表示这是第一次同步。
(8)所述第二客户端将所述同步消息发送给中转服务端,中转服务端根据同步消息确定是否有新对象需要同步到第二客户端,并生成一个同步响应消息,所述同步响应消息中包括了本次同步的时间戳以及所述新对象;中转服务端将所述同步响应消息发送给所述第二客户端。
具体的,首先中转服务端根据同步消息中的剪切板ID确定其对应的中转剪切板,然后中转服务器根据同步消息中的时间戳确定上一次同步的时间,在上一次同步时间之后,该中转剪切板中新增加的对象就是需要同步到第二客户端的对象。如果没有需要同步的新对象,则所述同步响应消息就只包括本次同步的时间戳。所述时间戳可以是真实的时间,也可以是一个同步的序号,只要能表明时间先后关系即可。
如果同步响应消息中包括了多个新对象,则同步响应消息也应当表明这些新对象在时间上的先后顺序,以方便第二客户端确定哪个对象是最新的剪切对象。
(9)第二客户端接收所述同步响应消息,将同步响应消息中的新对象存储于本地的系统剪切板中,根据当前的系统剪切板确定所述粘贴命令所要粘贴的对象。
例如,第二客户端可以直接粘贴系统剪切板中最新的对象,也可以向用户展示系统剪切板中的多个对象,由用户来选择其要粘贴的对象。
上述实施例的过程说明了本发明方法的基本流程,但是该实施例没有考虑数据隐私性,有时候用户拷贝的内容只希望共享给指定的用户,而不希望被其他用户(包括中转服务端)看见。实现这一点通常需要比较复杂的加密操作,本发明的第二实施例提出了一种较为简单的实现方法,保证了数据隐私性,且在用户操作上依旧保持简单,保证了用户体验的连续性。具体步骤说明如下,其中与第一实施例相同的部分不再详细说明。
(1)用户在中转服务端注册,注册信息包括剪切板ID。
(2)用户在第一客户端设置其使用的剪切板ID以及粘贴命令键组合。
所述粘贴命令键组合是多个键盘按键的组合,例如,所述粘贴命令键组合可以是“Ctrl+A+B”,或者是“Alt+C+1”,或者“Shift+E+F”。命令键组合以三个按键组合为宜,当然也可以设计更加复杂的命令键组合,本发明对此不作限制。
(3)用户在第一客户端使用拷贝命令,将选择的对象拷贝到第一客户端的系统剪切板中。
(4)第一客户端计算所述粘贴命令键组合的哈希值,并扩展所述哈希值,扩展结果与所述对象的位数相同。
例如,假设粘贴命令键组合为“Ctrl+A+B”,则连接Ctrl、A、B三个键的ASCII码值,得到组合键信息,计算该组合键信息的哈希值H,哈希算法可以使用MD5,则H的长度为128位。假设所述对象的长度为200位,则取该哈希值H的前72位,连接在H后面形成一个200位的扩展结果。
(5)设所述对象为object,所述扩展结果为K,则第一客户端计算Result=object⊕K,并生成一个中转消息,所述中转消息中包括了所述Result和第一客户端当前使用的剪切板ID,并将所述中转消息发送给中转服务端。
(6)中转服务端接收到所述中转消息,基于所述中转消息,将所述Result存储到所述剪切板ID对应的中转剪切板中。
(7)用户在第二客户端设置其使用的剪切板ID。
(8)用户在第二客户端使用粘贴命令键组合,第二客户端生成一个同步消息,所述同步消息中包括了第二客户端的剪切板ID和上次同步的时间戳。
步骤8中使用的粘贴命令键组合必须和第一客户端设置的粘贴命令键组合相同,否则第二客户端无法正确获得剪切对象。
粘贴命令键组合在此所起的作用与第一实施例的粘贴命令相同,例如:使用“Ctrl+A+B”这样的粘贴命令键组合代替了原始的“Ctrl+V”。
(9)所述第二客户端将所述同步消息发送给中转服务端,中转服务端根据同步消息确定是否有新的剪切板数据需要同步到第二客户端,并生成一个同步响应消息,所述同步响应消息中包括了本次同步的时间戳以及所述新剪切板数据;中转服务端将所述同步响应消息发送给所述第二客户端。
与第一实施例不同,这里的剪切板数据不再是对象本身,而是上述步骤5中计算的各个对象相应的Result。
(10)第二客户端接收所述同步响应消息,从同步响应消息中解析出新剪切板数据,对于新剪切板数据中的每一个Result,第二客户端计算所述粘贴命令键组合的哈希值,并扩展所述哈希值,使扩展结果K与所述Result的位数相同,通过计算Result⊕K得到相应的对象。
步骤10中的哈希值及其扩展方式与步骤4中的相同,因此可以进行相应的逆运算以恢复原始的对象。
(11)第二客户端将得到的新对象存储于本地的系统剪切板中,根据当前的系统剪切板确定所述粘贴命令所要粘贴的对象。
通过第二实施例的上述步骤,包括中转服务端在内的其他人无法看到剪切板中的原始对象,只有知晓剪切板ID及其相应的粘贴命令键组合的用户,才可以正确获得第一客户端的剪切对象,这里的粘贴命令键组合起到了保护隐私的作用,并且自身只是替代了原来的粘贴命令,并没有给用户带来过于复杂的操作,保证了用户体验。
以上所述仅是本发明的较佳实施方式,故凡依本发明专利申请范围所述的构造、特征及原理所做的等效变化或修饰,均包括于本发明专利申请范围内。
Claims (10)
1.一种中间存储方法,其特征在于,包括以下步骤:
(1)用户在中转服务端注册,注册信息包括剪切板ID;
(2)用户在第一客户端设置其使用的剪切板ID以及粘贴命令键组合;
(3)用户在第一客户端使用拷贝命令,将选择的对象拷贝到第一客户端的系统剪切板中;
(4)第一客户端计算所述粘贴命令键组合的哈希值,并扩展所述哈希值,扩展结果与所述对象的位数相同;
(5)设所述对象为object,所述扩展结果为K,则第一客户端计算Result=object⊕K,并生成一个中转消息,所述中转消息中包括了所述Result和第一客户端当前使用的剪切板ID,并将所述中转消息发送给中转服务端;
(6)中转服务端接收到所述中转消息,基于所述中转消息,将所述Result存储到所述剪切板ID对应的中转剪切板中;
(7)用户在第二客户端设置其使用的剪切板ID;
(8)用户在第二客户端使用粘贴命令键组合,第二客户端生成一个同步消息,所述同步消息中包括了第二客户端的剪切板ID和上次同步的时间戳;
(9)所述第二客户端将所述同步消息发送给中转服务端,中转服务端根据同步消息确定是否有新的剪切板数据需要同步到第二客户端,并生成一个同步响应消息,所述同步响应消息中包括了本次同步的时间戳以及所述新剪切板数据;中转服务端将所述同步响应消息发送给所述第二客户端;
(10)第二客户端接收所述同步响应消息,从同步响应消息中解析出新剪切板数据,对于新剪切板数据中的每一个Result,第二客户端计算所述粘贴命令键组合的哈希值,并扩展所述哈希值,使扩展结果K与所述Result的位数相同,通过计算Result⊕K得到相应的对象。
2.根据权利要求1所述的方法,其特征在于,所述剪切板ID是剪切板的唯一标识符,用于在中转服务端区分不同的中转剪切板。
3.根据权利要求1-2任意一项所述的方法,其特征在于,所述对象是文本或者文件。
4.根据权利要求1-3任意一项所述的方法,其特征在于,用户可在客户端同时设置多个剪切板ID,相应的中转消息也包括所述多个剪切板ID。
5.根据权利要求1-4任意一项所述的方法,其特征在于,中转剪切板按照收到中转消息的时间顺序来存储中转消息中的对象,从而在中转剪切板中形成一个基于时间顺序的对象队列。
6.根据权利要求1所述的方法,其特征在于,所述时间戳是真实时间,或者是同步序号。
7.根据权利要求1所述的方法,其特征在于,如果没有需要同步的新数据,则所述同步响应消息就只包括本次同步的时间戳。
8.根据权利要求1所述的方法,其特征在于,如果同步响应消息中包括了多个新剪切板数据,则同步响应消息中包括了这些新剪切板数据在时间上的先后顺序。
9.根据权利要求1所述的方法,其特征在于,在步骤10之后,所述第二客户端直接粘贴系统剪切板中最新的对象。
10.根据权利要求1所述的方法,其特征在于,在步骤10之后,所述第二客户端向用户展示系统剪切板中的多个对象,由用户来选择其要粘贴的对象。
Priority Applications (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN201910047758.3A CN109726028B (zh) | 2019-01-17 | 2019-01-17 | 一种中间存储方法 |
Applications Claiming Priority (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN201910047758.3A CN109726028B (zh) | 2019-01-17 | 2019-01-17 | 一种中间存储方法 |
Publications (2)
Publication Number | Publication Date |
---|---|
CN109726028A true CN109726028A (zh) | 2019-05-07 |
CN109726028B CN109726028B (zh) | 2023-05-26 |
Family
ID=66298403
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
CN201910047758.3A Active CN109726028B (zh) | 2019-01-17 | 2019-01-17 | 一种中间存储方法 |
Country Status (1)
Country | Link |
---|---|
CN (1) | CN109726028B (zh) |
Cited By (1)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN111651967A (zh) * | 2020-07-31 | 2020-09-11 | 北京东方通软件有限公司 | 一种支持容器云平台的会话复制方法及装置 |
Citations (6)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN101997900A (zh) * | 2009-08-26 | 2011-03-30 | 中国移动通信集团公司 | 一种跨终端的拷贝粘贴系统、装置及方法 |
US20150207850A1 (en) * | 2012-09-11 | 2015-07-23 | Google Inc. | Clipboard |
CN105323272A (zh) * | 2014-06-25 | 2016-02-10 | 中兴通讯股份有限公司 | 一种管理剪切板的方法、终端和系统 |
US9537705B1 (en) * | 2009-03-31 | 2017-01-03 | EMC IP Holding Company LLC | Global space reduction groups |
CN106302123A (zh) * | 2016-08-17 | 2017-01-04 | 广州视睿电子科技有限公司 | 一种数据提取、粘贴处理的方法、装置及其系统 |
CN106648392A (zh) * | 2016-12-28 | 2017-05-10 | 北京小米移动软件有限公司 | 粘贴数据的方法及装置 |
-
2019
- 2019-01-17 CN CN201910047758.3A patent/CN109726028B/zh active Active
Patent Citations (6)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US9537705B1 (en) * | 2009-03-31 | 2017-01-03 | EMC IP Holding Company LLC | Global space reduction groups |
CN101997900A (zh) * | 2009-08-26 | 2011-03-30 | 中国移动通信集团公司 | 一种跨终端的拷贝粘贴系统、装置及方法 |
US20150207850A1 (en) * | 2012-09-11 | 2015-07-23 | Google Inc. | Clipboard |
CN105323272A (zh) * | 2014-06-25 | 2016-02-10 | 中兴通讯股份有限公司 | 一种管理剪切板的方法、终端和系统 |
CN106302123A (zh) * | 2016-08-17 | 2017-01-04 | 广州视睿电子科技有限公司 | 一种数据提取、粘贴处理的方法、装置及其系统 |
CN106648392A (zh) * | 2016-12-28 | 2017-05-10 | 北京小米移动软件有限公司 | 粘贴数据的方法及装置 |
Cited By (2)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN111651967A (zh) * | 2020-07-31 | 2020-09-11 | 北京东方通软件有限公司 | 一种支持容器云平台的会话复制方法及装置 |
CN111651967B (zh) * | 2020-07-31 | 2020-11-24 | 北京东方通软件有限公司 | 一种支持容器云平台的会话复制方法及装置 |
Also Published As
Publication number | Publication date |
---|---|
CN109726028B (zh) | 2023-05-26 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
EP2378718B1 (en) | Method, node and system for controlling version in distributed system | |
JP4732661B2 (ja) | クライアントのデータベースとサーバーのデータベースとを同期させる方法 | |
CN103701913B (zh) | 数据同步方法及装置 | |
CN102054035B (zh) | 一种基于数据范围的数据库数据同步方法 | |
CN109542865A (zh) | 分布式集群系统配置文件同步方法、装置、系统及介质 | |
WO2001077858A3 (en) | System and method for synchronizing data records between multiple databases | |
CN108259175B (zh) | 一种分布式密码服务方法和系统 | |
CN102098342A (zh) | 一种基于事务级的数据同步方法、装置及系统 | |
CN105208058B (zh) | 基于web会话共享的信息交互系统 | |
CN102546773A (zh) | 提供复原性服务 | |
CN103491055A (zh) | 一种在多个客户端间同步信息的方法、客户端和服务器 | |
CN103442042A (zh) | 增量数据同步方法及系统 | |
EP2721506A2 (en) | Efficient state reconciliation | |
CN103841180B (zh) | 一种基于操作指令的网络数据同步方法、装置、终端设备和服务器 | |
CN104869478B (zh) | 楼宇对讲设备远程配置方法和系统 | |
WO2017162079A1 (zh) | 一种数据的同步方法和装置 | |
CN105745902A (zh) | 同步多个客户端的事件历史 | |
CN105989191A (zh) | 进行数据同步的信息处理设备和数据同步方法 | |
CN111597536A (zh) | 一种hadoop集群kerberos高可用认证方法 | |
CN101387949B (zh) | 应急系统客户端界面显示方法及系统 | |
CN105933379A (zh) | 一种业务处理方法、设备及系统 | |
US20220269808A1 (en) | Document management system | |
CN108650168B (zh) | 多人会话的成员数据获取方法和装置、存储介质、处理器 | |
CN109726028A (zh) | 一种中间存储方法 | |
JP2000222268A (ja) | 複数のコンピュータ間におけるファイルの同期方法 |
Legal Events
Date | Code | Title | Description |
---|---|---|---|
PB01 | Publication | ||
PB01 | Publication | ||
SE01 | Entry into force of request for substantive examination | ||
SE01 | Entry into force of request for substantive examination | ||
GR01 | Patent grant | ||
GR01 | Patent grant |