CN109687960A - 基于多个公共非对称密钥池的抗量子计算代理云存储方法和系统 - Google Patents
基于多个公共非对称密钥池的抗量子计算代理云存储方法和系统 Download PDFInfo
- Publication number
- CN109687960A CN109687960A CN201811643851.2A CN201811643851A CN109687960A CN 109687960 A CN109687960 A CN 109687960A CN 201811643851 A CN201811643851 A CN 201811643851A CN 109687960 A CN109687960 A CN 109687960A
- Authority
- CN
- China
- Prior art keywords
- key
- public
- file
- defence
- user terminal
- 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
Classifications
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04L—TRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
- H04L9/00—Cryptographic mechanisms or cryptographic arrangements for secret or secure communications; Network security protocols
- H04L9/08—Key distribution or management, e.g. generation, sharing or updating, of cryptographic keys or passwords
- H04L9/0861—Generation of secret information including derivation or calculation of cryptographic keys or passwords
- H04L9/0869—Generation of secret information including derivation or calculation of cryptographic keys or passwords involving random numbers or seeds
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04L—TRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
- H04L63/00—Network architectures or network communication protocols for network security
- H04L63/04—Network architectures or network communication protocols for network security for providing a confidential data exchange among entities communicating through data packet networks
- H04L63/0428—Network architectures or network communication protocols for network security for providing a confidential data exchange among entities communicating through data packet networks wherein the data content is protected, e.g. by encrypting or encapsulating the payload
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04L—TRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
- H04L9/00—Cryptographic mechanisms or cryptographic arrangements for secret or secure communications; Network security protocols
- H04L9/08—Key distribution or management, e.g. generation, sharing or updating, of cryptographic keys or passwords
- H04L9/0816—Key establishment, i.e. cryptographic processes or cryptographic protocols whereby a shared secret becomes available to two or more parties, for subsequent use
- H04L9/0819—Key transport or distribution, i.e. key establishment techniques where one party creates or otherwise obtains a secret value, and securely transfers it to the other(s)
- H04L9/0822—Key transport or distribution, i.e. key establishment techniques where one party creates or otherwise obtains a secret value, and securely transfers it to the other(s) using key encryption key
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04L—TRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
- H04L9/00—Cryptographic mechanisms or cryptographic arrangements for secret or secure communications; Network security protocols
- H04L9/08—Key distribution or management, e.g. generation, sharing or updating, of cryptographic keys or passwords
- H04L9/0816—Key establishment, i.e. cryptographic processes or cryptographic protocols whereby a shared secret becomes available to two or more parties, for subsequent use
- H04L9/0852—Quantum cryptography
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04L—TRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
- H04L9/00—Cryptographic mechanisms or cryptographic arrangements for secret or secure communications; Network security protocols
- H04L9/08—Key distribution or management, e.g. generation, sharing or updating, of cryptographic keys or passwords
- H04L9/0894—Escrow, recovery or storing of secret information, e.g. secret key escrow or cryptographic key storage
- H04L9/0897—Escrow, recovery or storing of secret information, e.g. secret key escrow or cryptographic key storage involving additional devices, e.g. trusted platform module [TPM], smartcard or USB
Landscapes
- Engineering & Computer Science (AREA)
- Computer Security & Cryptography (AREA)
- Computer Networks & Wireless Communication (AREA)
- Signal Processing (AREA)
- Computer Hardware Design (AREA)
- Computing Systems (AREA)
- General Engineering & Computer Science (AREA)
- Physics & Mathematics (AREA)
- Electromagnetism (AREA)
- Theoretical Computer Science (AREA)
- Storage Device Security (AREA)
Abstract
本发明涉及一种基于多个公共非对称密钥池的抗量子计算代理云存储方法和系统,包括服务器、公共密钥池装置和用户端,用户端上传与数据文件相关数据至公共密钥池装置,该装置利用量子密钥卡生成密钥并分别加密数据密钥和个人密钥,利用防御公私钥指针随机数提取防御公钥加密密钥;用户端发送读请求,公共密钥池装置下载相关数据获得个人密钥,将个人密钥及数据文件发送用户端,用户端利用身份私钥获得数据文件。云存储全过程,服务器端无法接触到用户端各类密钥以及明文数据文件,各加密方式与密钥池结合,进一步保证文件密钥安全。同时使用仅对密钥卡公开的公钥对文件密钥进行加密,密钥卡的设计,大大降低被恶意软件窃取密钥的可能性。
Description
技术领域
本发明涉及云存储领域,尤其涉及基于多个公共非对称密钥池的抗量子计算代理云存储方法和系统。
背景技术
随着科技的发展,云存储已经越来越成为一种趋势,各种云存储技术层出不穷,为了保证云存储数据的安全,通常会利用各种加密方法来保证数据的安全性,例如,可以通过非对称密钥加密来保证数据的安全性,非对称密钥加密需要使用不同的密钥来分别完成加密和解密操作,一个公开发布,即公钥,另一个由用户自己秘密保存,即私钥。信息发送者用公钥去加密,而信息接收者用私钥去解密。
由于云存储中多采用共享存储,这使得服务商需要对私钥进行控制,导致私钥的安全性较低。公开号为CN103236934A,发明名称为“一种云存储安全控制的方法”的发明专利文献,公开了一种用于解决私钥安全性较低的问题的方法。该发明使用两种不同的加密方式对用户的私钥进行加密并分别存储。
正如大多数人所了解的,量子计算机在密码破解上有着巨大潜力。当今主流的非对称(公钥)加密算法,如RSA加密算法,大多数都是基于大整数的因式分解或者有限域上的离散指数的计算这两个数学难题。他们的破解难度也就依赖于解决这些问题的效率。传统计算机上,要求解这两个数学难题,花费时间为指数时间(即破解时间随着公钥长度的增长以指数级增长),这在实际应用中是无法接受的。而为量子计算机量身定做的秀尔算法可以在多项式时间内(即破解时间随着公钥长度的增长以k次方的速度增长,其中k为与公钥长度无关的常数)进行整数因式分解或者离散对数计算,从而为RSA、离散对数加密算法的破解提供可能。
当前企业或事业单位有时有数据上云的需求,而公有云一般不容易受这些单位信任,被认为信息安全可能有问题,或者密钥容易被黑客所获得并破解,因此造成了公有云客户对数据上云有后顾之忧。
现有技术存在的问题:
(1)在服务器上进行密钥存储有一定的危险性。公有云客户对数据上云有后顾之忧。
(2)公开号为CN103236934A,发明名称为“一种云存储安全控制的方法”的发明专利文献,使用用户公钥对文件密钥进行加密,由于量子计算机能快速通过公钥得到对应的私钥,因此该方案很容易被量子计算机破解。
发明内容
基于此,有必要针对上述问题,提供一种基于多个公共非对称密钥池的抗量子计算代理云存储方法和系统。
一种基于多个公共非对称密钥池的抗量子计算代理云存储方法,包括用户端上传利用文件密钥加密的数据文件、数据密钥及个人密钥至公共密钥池装置,所述公共密钥池装置将利用防御公私钥指针随机数提取防御公钥,同时利用随机数发生器生成密钥,令该密钥分别加密所述数据密钥和所述个人密钥,同时使该防御公钥加密所述密钥,所述公共密钥池装置将所述利用文件密钥加密的数据文件、防御公私钥指针随机数、防御公钥加密所述密钥以及密钥分别加密的数据密钥和个人密钥上传至服务器,其中,所述用户端及所述公共密钥池装置均配置有密钥卡,加密操作均在密钥卡内进行。
当前有很多存储云服务,其中包括很多公有云。下文中,存储云的服务器即云服务端简称为服务器,云客户端群组中的云用户端简称为用户端。
本实施例中用户端为接入存储云的设备,可为移动终端,或为固定终端。终端均配备有密钥卡。本实施例中,属于一个用户端群组的各个用户端所匹配的密钥卡颁发方为密钥卡的主管方,一般为某企业或事业单位的管理部门;密钥卡被颁发方为密钥卡的主管方所管理的成员,一般为某企业或事业单位的各级员工,其使用存储云用户端进行云端数据存取,下文统称成员所使用的存储云用户端为用户端。用户端首先到密钥卡的主管方申请开户。当用户端进行注册登记获批后,将得到密钥卡(具有唯一的ID)。密钥卡存储了客户所需要的密钥,密钥卡还存有客户的注册登记信息,内置有身份认证协议,至少包括密钥生成算法以及认证函数,或其他与身份认证相关的算法。密钥卡中还带有随机数发生器。
在其中一个实施例中,所述公共密钥池装置包括:
防御非对称密钥池,所述防御非对称密钥池分为防御公钥池及防御私钥池,分别用于存储防御公钥及防御私钥;
身份非对称密钥池,所述身份非对称密钥池的公钥区拥有所有用户端的公钥,身份非对称密钥池的私钥区存储本用户端的私钥。
在其中一个实施例中,所述用户端有一个或多个,所述公共密钥池装置内存储有供各用户端访问的公共密钥池,所述用户端与所述公共密钥池装置通信连接,上传数据文件的用户端利用所述公共密钥池装置将文件密钥加密的数据文件上传至服务器,下载数据文件的用户端利用所述公共密钥池结合来自服务器的真随机数相应解出文件密钥以解密出数据文件。
在其中一个实施例中,所述个人密钥生成方法为利用身份公钥加密所述文件密钥获得个人密钥,其中,所述身份公钥的加密方法包括:将身份公钥指针随机数结合身份公钥指针函数得到身份公钥指针,利用该身份公钥指针从所述身份非对称密钥池中提取对应的身份公钥。
在其中一个实施例中,所述防御公钥生成方法包括:将防御公私钥指针随机数结合防御公钥指针函数得到防御公钥指针,利用该防御公钥指针从所述防御非对称密钥池中提取对应的防御公钥。
在其中一个实施例中,所述用户端通过所述公共密钥池装置将数据文件的Hash值上传至所述服务器,所述数据文件的Hash值作为所述服务器是否进行去重的标识。
一种基于多个公共非对称密钥池的抗量子计算代理云存储方法,包括服务器接收并存储来自公共密钥池装置利用文件密钥加密的数据文件、防御公私钥指针随机数、防御公钥加密的密钥以及该密钥分别加密的数据密钥和个人密钥,所述密钥是利用所述公共密钥池装置所配有的密钥卡中量子随机数发生器生成,所述防御公钥由防御公私钥指针随机数在所述公共密钥池装置中提取。
在其中一个实施例中,所述个人密钥生成方法为利用身份公钥加密所述文件密钥获得个人密钥,其中,所述身份公钥的加密方法包括:将身份公钥指针随机数结合身份公钥指针函数得到身份公钥指针,利用该身份公钥指针从身份非对称密钥池中提取对应的身份公钥;
所述数据密钥生成方式为利用文件特征值加密所述文件密钥得到数据密钥。
在其中一个实施例中,所述服务器还接收并存储来自所述用户端的数据文件的Hash值,其中所述数据文件的Hash值为服务器是否进行去重的指示标识;
当服务器依据所述指示标识判断去重时,所述服务器向所述用户端发送数据密钥;
当服务器依据所述指示标识判断不需去重时,接受存储来自所述用户端的所述数据文件的Hash值。
一种基于多个公共非对称密钥池的抗量子计算代理云存储系统,包括服务器、公共密钥池装置和用户端,用户端上传利用文件密钥加密的数据文件、数据密钥及个人密钥至公共密钥池装置,所述公共密钥池装置将利用防御公私钥指针随机数提取防御公钥,同时利用随机数发生器生成密钥,令该密钥分别加密所述数据密钥和所述个人密钥,同时使该防御公钥加密所述密钥,所述公共密钥池装置将所述利用文件密钥加密的数据文件、防御公私钥指针随机数、防御公钥加密所述密钥以及密钥分别加密的数据密钥和个人密钥上传至服务器,其中,所述用户端及所述公共密钥池装置均配置有密钥卡,加密操作均在密钥卡内进行;
服务器接收并存储来自公共密钥池装置利用文件密钥加密的数据文件、防御公私钥指针随机数、防御公钥加密的密钥以及该密钥分别加密的数据密钥和个人密钥;
用户端发送读取文件请求至公共密钥池装置,公共密钥池装置下载文件密钥加密的数据文件、防御公私钥指针随机数、防御公钥加密的密钥以及该密钥加密的个人密钥;并利用所述防御公私钥指针随机数提取防御私钥,该防御私钥解密获得密钥进而获得个人密钥,所述公共密钥池装置将所述个人密钥及所述文件密钥加密的数据文件发送至所述用户端,所述用户端利用身份私钥解密所述个人密钥获得文件密钥,所述文件密钥解密获得数据文件,完成文件读取。
上述一种基于多个公共非对称密钥池的抗量子计算代理云存储方法和系统,包括服务器、公共密钥池装置和用户端,用户端上传利用文件密钥加密的数据文件、数据密钥及个人密钥至公共密钥池装置,所述公共密钥池装置将利用防御公私钥指针随机数提取防御公钥,同时利用随机数发生器生成密钥并分别加密数据密钥和个人密钥,同时使该防御公钥加密所述密钥,所述公共密钥池装置将所述利用文件密钥加密的数据文件、防御公私钥指针随机数、防御公钥加密所述密钥以及密钥分别加密的数据密钥和个人密钥上传至服务器;服务器接收并存储来自公共密钥池装置利用文件密钥加密的数据文件、防御公私钥指针随机数、防御公钥加密的密钥以及该密钥分别加密的数据密钥和个人密钥;用户端发送读请求至公共密钥池装置,公共密钥池装置下载相关数据;并利用所述防御公私钥指针随机数获得个人密钥,并将所述个人密钥及所述文件密钥加密的数据文件发送至所述用户端,所述用户端利用身份私钥解密所述个人密钥获得文件密钥进而获得数据文件,完成文件读取。云存储全过程中,服务器端无法接触到用户端各类密钥(公钥、私钥、文件密钥等)以及明文数据文件。服务器上存储的个人密钥与数据密钥为使用不同方法加密的=文件密钥。本实施例中使用仅对密钥卡公开的公钥对文件密钥进行加密,密钥卡是独立的硬件隔离设备,被恶意软件或恶意操作窃取密钥的可能性大大降低。
附图说明
图1为本发明实施例提供的存储系统的结构示意图;
图2为本发明实施例提供的用户端的密钥区结构示意图;
图3为本发明实施例提供的公共密钥池装置的密钥区结构示意图;
图4为本发明实施例提供的公共密钥池装置的结构示意图;
图5为公共密钥池装置的随机数发生器产生的随机数的加密方式示意图;
图6为本发明实施例提供的防御非对称密钥池存储方式流程图;
图7为本发明实施例提供的身份非对称密钥池存储方式流程图;
图8为本发明实施例提供的防御公私钥读取方式流程图;
图中(a)部分为防御公钥读取方式流程图;
图中(b)部分为防御私钥读取方式流程图;
图9为本发明实施例提供的身份公钥读取方式流程图;
图10为本发明实施例1提供的不需去重的存储方法时序图;
图11为本发明实施例1提供的需要去重的存储方法时序图;
图12为本发明实施例提供的服务器的某文件存储区的示意图;
图13为本发明实施例2提供的读取方法的时序图。
具体实施方式
一种基于多个公共非对称密钥池的抗量子计算代理云存储系统,包括服务器、公共密钥池装置和用户端,用户端上传利用文件密钥加密的数据文件、数据密钥及个人密钥至公共密钥池装置,所述公共密钥池装置将利用防御公私钥指针随机数提取防御公钥,同时利用随机数发生器生成密钥,令该密钥分别加密所述数据密钥和所述个人密钥,同时使该防御公钥加密所述密钥,所述公共密钥池装置将所述利用文件密钥加密的数据文件、防御公私钥指针随机数、防御公钥加密所述密钥以及密钥分别加密的数据密钥和个人密钥上传至服务器,其中,所述用户端及所述公共密钥池装置均配置有密钥卡,加密操作均在密钥卡内进行;
服务器接收并存储来自公共密钥池装置利用文件密钥加密的数据文件、防御公私钥指针随机数、防御公钥加密的密钥以及该密钥分别加密的数据密钥和个人密钥;
用户端发送读取文件请求至公共密钥池装置,公共密钥池装置下载文件密钥加密的数据文件、防御公私钥指针随机数、防御公钥加密的密钥以及该密钥加密的个人密钥;并利用所述防御公私钥指针随机数提取防御私钥,该防御私钥解密获得密钥进而获得个人密钥,所述公共密钥池装置将所述个人密钥及所述文件密钥加密的数据文件发送至所述用户端,所述用户端利用身份私钥解密所述个人密钥获得文件密钥,所述文件密钥解密获得数据文件,完成文件读取。
图1为本发明实施例提供的存储系统的结构示意图,公共密钥池装置与用户端群组CC以及云存储CS分别网络连接。其中用户端群组CC由多个用户端组成。每个用户端都有自己匹配的密钥卡,密钥卡中密钥区结构如图2所示,每个密钥卡内部存储该用户端的身份私钥KA以及身份公钥密钥池IPKP,密钥池中存有所有成员的身份公钥。密钥卡中还存储有该用户端的公钥指针随机数,图中KRA/KA即指A的身份公钥指针随机数/身份私钥。用户端A对外公开的公钥KRA,即公钥的指针随机数。用户端群组中的其他成员同理。
身份公钥的存储方式如图7所示,文字描述如下:对某个用户随机取身份公钥指针随机数kr,结合特定的身份公钥指针函数frkp得到身份公钥指针rkp并从相应的身份非对称密钥池IPKP中的对应位置存入该用户的身份公钥krk。
公共密钥池装置P的结构示意图如图4所示,公共密钥池装置P带有密钥卡,公共密钥池装置P带有根密钥区,可以取出根密钥KRP。公共密钥池装置P还带有随机数产生器,该随机数产生器优选为量子随机数发生器,可产生真随机数作为密钥的密钥,该密钥的密钥称为KKP。KP指用户端群组CC所拥有的公共密钥池,存储在公共密钥池装置P。KP容量巨大,例如可以从1G~4096G不等,均为真随机数,优选为量子随机数。公共密钥池装置P可存储多个KP,图中公共密钥池装置P存储有1~M共M个KP区域。每个KP区域使用不同的KKP。KP包括被加密的KKP和被KKP加密的密钥区。密钥区结构如图3所示,分为防御非对称密钥池(公钥/私钥)、身份非对称密钥池(公钥)以及身份非对称密钥(私钥)。其中,防御非对称密钥池的公钥与私钥一一对应,身份非对称密钥池的公钥区拥有本组织所有用户的公钥,身份非对称密钥池的私钥区存储本用户的私钥。密钥的密钥KKP用根密钥KRP加密,如图5所示。
防御非对称密钥池的存储方式如图6所示,文字描述如下:对某个用户随机取防御公私钥指针随机数rd,防御公私钥指针随机数rd结合特定的防御公钥指针函数fpp得到防御公钥指针pp并从防御非对称密钥池DPKP中的对应位置存入该用户的防御公钥pk;防御公私钥指针随机数rd结合特定的防御私钥指针函数fsp得到防御私钥指针sp并从防御非对称密钥池DSKP中的对应位置存入该用户的防御私钥sk。防御公钥pk和防御私钥sk是成对的公私钥对。
以下步骤中,在各用户端涉及的多处操作,都在匹配的密钥卡中进行。在公共密钥池涉及的多处操作,都在匹配的密钥卡中进行。
以下结合附图及实施例,对本发明进行进一步详细说明。应当理解,此处所描述的具体实施例仅仅用于解释本发明,并不用于限定本发明。
实施例1
步骤1.1.用户端将数据文件的Hash值上传至服务器:用户端计算出数据文件的Hash值,并将该Hash值上传至公共密钥池装置P。密钥池装置P收到后转发给服务器。服务器为了减轻存储压力,将对文件进行密文去重,即鉴别重复文件。
步骤1.2.服务器鉴别重复文件:服务器对文件的Hash值进行考虑来鉴别重复文件,即如果两份文件具有相同的Hash值则认为有相同的数据文件需要去重。若服务器判断不需要去重,服务器保存收到的这个Hash值并执行步骤1.3。若需要去重,服务器执行步骤1.4。
步骤1.3.若服务器不需要去重,将文件存储在云服务器上的时序图如图10所示,文字描述如下:
步骤1.3.1服务器通知用户端生成文件密钥:服务器保存收到的Hash值后,将服务器不存在具有相同数据文件的信息发送给公共密钥池装置P,由公共密钥池装置P转发给用户端。以下将该用户端标识为用户端1,用户端1的身份标识为ID1,以此类推。
步骤1.3.2用户端生成需要上传的内容并发送至密钥池装置P:用户端1使用随机数发生器生成的文件密钥kf加密数据文件得到密文。使用文件特征值加密文件密钥kf得到数据密钥。文件特征值的计算方法为预定义的算法,可以是但不限于Hash计算、文件压缩或其他文件特征计算算法。
用户端1使用自己的身份公钥krk1加密文件密钥kf得到个人密钥1。本专利明文身份公钥不公开,仅公开身份公钥指针随机数。由身份公钥指针随机数kr得到身份公钥krk的过程如图9所示,文字描述如下:
使用自己的身份公钥指针随机数kr结合特定的身份公钥指针函数frkp得到身份公钥指针rkp,然后从相应的身份非对称密钥池IPKP中的对应位置取出身份公钥krk。
用户端1将ID1、密文、数据密钥和个人密钥1发送至公共密钥池装置P。
步骤1.3.3公共密钥池装置P对数据进行防御性加密后上传至服务器:得到密文,数据密钥和个人密钥1后,公共密钥池装置P使用随机数发生器生成密钥k0。公共密钥池装置P通过防御公私钥指针随机数r0得到防御公钥pk0,过程如图8(a)所示,文字描述如下:
防御公私钥指针随机数r0结合特定的防御公钥指针函数fpp得到防御公钥指针pp,然后从相应的防御非对称密钥池DPKP中的对应位置取出防御公钥pk0。
使用密钥k0加密数据密钥,再使用防御公钥pk0加密密钥k0。
公共密钥池装置P通过用户端1的防御公私钥指针随机数r1得到防御公钥pk1,过程图如8(a)所示,文字描述与上文相同。公共密钥池装置P使用随机数发生器生成密钥k1,使用密钥k1加密个人密钥1,再使用防御公钥pk1加密密钥k1。
公共密钥池装置P将密文、防御公私钥指针随机数r0、防御公钥pk0加密的密钥k0,密钥k0加密的数据密钥、ID1、防御公私钥指针随机数r1、防御公钥pk1加密的密钥k1、密钥k1加密的个人密钥1发送至服务器。
步骤1.3.4服务器保存相应信息:服务器将收到的信息一一进行保存。
步骤1.4.若服务器需要去重,将文件存储在云服务器上的时序图如图11所示,文字描述如下:
步骤1.4.1服务器向公共密钥池装置P发送数据密钥:服务器将使用密钥k0加密的数据密钥发送给公共密钥池装置P,一并发送的还有防御公私钥指针随机数r0和使用防御公钥pk0加密的密钥k0。
步骤1.4.2密钥池将数据密钥发送至用户端:公共密钥池装置收到后,通过防御公私钥指针随机数r0得到防御私钥sk0,过程如图8(b)所示,文字描述如下:
防御公私钥指针随机数r0结合特定的防御私钥指针函数fsp得到防御私钥指针sp,然后从相应的防御非对称密钥池DSKP中的对应位置取出防御私钥sk0。
公共密钥池装置P使用防御私钥sk0解密得到密钥k0,再使用密钥k0解密得到数据密钥。然后将数据密钥发送至用户端。以下将该用户端标识为用户端2,用户端2的身份标识为ID2。
步骤1.4.3用户端得到文件密钥并上传个人密钥:用户端2收到数据密钥后,根据数据文件生成的文件特征值,并使用文件特征值解密数据密钥得到文件密钥kf。用户端2使用自己的身份公钥指针随机数kr从身份非对称密钥池中提取出自己的身份公钥krk,过程如图9所示,文字描述与上文相同。用户端2使用身份公钥krk加密文件密钥kf得到个人密钥2后,将ID2与个人密钥2一起发送至公共密钥池装置P。
步骤1.4.4公共密钥池装置P对数据进行防御性加密后上传至服务器:ID2和个人密钥2后,公共密钥池装置P通过用户端2的防御公私钥指针随机数r2得到防御公钥pk2,过程图如8(a)所示,文字描述与上文相同。公共密钥池装置P使用随机数发生器生成密钥k2,使用密钥k2加密个人密钥2,再使用防御公钥pk2加密密钥k2。
公共密钥池装置P将ID2、防御公私钥指针随机数r2、防御公钥pk2加密的密钥k2、密钥k2加密的个人密钥2发送至服务器。
步骤1.4.5服务器保存相应信息:服务器将收到的信息一一进行保存。
n个用户上传同一个文件后,该文件的存储区如图12所示,存储有文件的Hash值,使用文件密钥加密文件得到的文件密文,防御公私钥指针随机r0、使用防御公钥pk0加密密钥k0和使用密钥k0加密的数据密钥,ID(1~n)、r(1~n)、使用pk(1~n)加密的k(1~n)和使用k(1~n)加密的个人密钥(1~n)。
实施例2
图13为本发明实施例提供的读取方法的时序图。
步骤2.1.用户端发起读取文件请求:以用户端n为例,用户端n将想要读取的文件的Hash值作为一个请求,请求中还包括用户端的IDn。用户端n将请求发送至公共密钥池装置P后,公共密钥池装置P将其转发至服务器。
步骤2.2.服务器返回相应信息:服务器收到文件Hash值后,找到与该Hash值对应的文件的存储区,将密文、IDn、防御公私钥指针随机rn、使用防御公钥pkn加密的密钥kn和使用密钥kn加密的个人密钥n发送至公共密钥池装置P。
步骤2.3.公共密钥池装置P解密得到个人密钥并转发至用户端:公共密钥池装置P通过防御公私钥指针随机rn得到防御私钥skn,具体过程如图8(b)所示,文字描述与上文相同。使用防御私钥skn解密得到密钥kn后,使用密钥kn解密得到个人密钥n。将个人密钥n与密文一起发送至用户端。
步骤2.4.用户端得到数据文件:用户端使用自己的身份私钥解密个人密钥n得到文件密钥kf,使用文件密钥kf解密密文得到数据文件,完成对服务器文件的读取。
密钥卡从智能卡技术上发展而来,是结合了量子物理学技术(搭载量子随机数发生器的情况下)、密码学技术、硬件安全隔离技术的身份认证和加解密产品。密钥卡的内嵌芯片和操作系统可以提供密钥的安全存储和密码算法等功能。由于其具有独立的数据处理能力和良好的安全性,密钥卡成为私钥和密钥池的安全载体。每一个密钥卡都有硬件PIN码保护,PIN码和硬件构成了用户使用密钥卡的两个必要因素。即所谓“双因子认证”,用户只有同时取得保存了相关认证信息的密钥卡和用户PIN码,才可以登录系统。即使用户的PIN码被泄露,只要用户持有的密钥卡不被盗取,合法用户的身份就不会被仿冒;如果用户的密钥卡遗失,拾到者由于不知道用户PIN码,也无法仿冒合法用户的身份。
本实施例中云存储全过程中,服务器端都无法接触到用户端各类密钥(公钥、私钥、文件密钥等)以及明文数据文件。不仅如此,服务器上存储的个人密钥与数据密钥为使用不同方法加密的随机数,该随机数结合特定的密钥选择算法可得到一个指针。该指针指向密钥池中某个特定的区域,在没有得到密钥池的情况下,即使破解了个人密钥或数据密钥也无法得到加密文件的文件密钥。本专利使用仅对密钥卡公开的公钥对文件密钥进行加密,且使用密钥卡存储公钥,密钥卡是独立的硬件隔离设备,被恶意软件或恶意操作窃取密钥的可能性大大降低。由于量子计算机无法得到用户公钥,于是也无法得到对应的私钥,因此该方案不容易被量子计算机破解。
以上所述实施例的各技术特征可以进行任意的组合,为使描述简洁,未对上述实施例中的各个技术特征所有可能的组合都进行描述,然而,只要这些技术特征的组合不存在矛盾,都应当认为是本说明书记载的范围。
以上所述实施例仅表达了本发明的几种实施方式,其描述较为具体和详细,但并不能因此而理解为对发明专利范围的限制。应当指出的是,对于本领域的普通技术人员来说,在不脱离本发明构思的前提下,还可以做出若干变形和改进,这些都属于本发明的保护范围。因此,本发明专利的保护范围应以所附权利要求为准。
Claims (10)
1.一种基于多个公共非对称密钥池的抗量子计算代理云存储方法,其特征在于,包括用户端上传利用文件密钥加密的数据文件、数据密钥及个人密钥至公共密钥池装置,所述公共密钥池装置将利用防御公私钥指针随机数提取防御公钥,同时利用随机数发生器生成密钥,令该密钥分别加密所述数据密钥和所述个人密钥,同时使该防御公钥加密所述密钥,所述公共密钥池装置将所述利用文件密钥加密的数据文件、防御公私钥指针随机数、防御公钥加密所述密钥以及密钥分别加密的数据密钥和个人密钥上传至服务器,其中,所述用户端及所述公共密钥池装置均配置有密钥卡,加密操作均在密钥卡内进行。
2.根据权利要求1所述的基于多个公共非对称密钥池的抗量子计算代理云存储方法,其特征在于,所述公共密钥池装置包括:
防御非对称密钥池,所述防御非对称密钥池分为防御公钥池及防御私钥池,分别用于存储防御公钥及防御私钥;
身份非对称密钥池,所述身份非对称密钥池的公钥区拥有所有用户端的公钥,身份非对称密钥池的私钥区存储本用户端的私钥。
3.根据权利要求2所述的基于多个公共非对称密钥池的抗量子计算代理云存储方法,其特征在于,所述用户端有一个或多个,所述公共密钥池装置内存储有供各用户端访问的公共密钥池,所述用户端与所述公共密钥池装置通信连接,上传数据文件的用户端利用所述公共密钥池装置将文件密钥加密的数据文件上传至服务器,下载数据文件的用户端利用所述公共密钥池结合来自服务器的真随机数相应解出文件密钥以解密出数据文件。
4.根据权利要求2所述的基于多个公共非对称密钥池的抗量子计算代理云存储方法,其特征在于,所述个人密钥生成方法为利用身份公钥加密所述文件密钥获得个人密钥,其中,所述身份公钥的加密方法包括:将身份公钥指针随机数结合身份公钥指针函数得到身份公钥指针,利用该身份公钥指针从所述身份非对称密钥池中提取对应的身份公钥。
5.根据权利要求2所述的基于多个公共非对称密钥池的抗量子计算代理云存储方法,其特征在于,所述防御公钥生成方法包括:将防御公私钥指针随机数结合防御公钥指针函数得到防御公钥指针,利用该防御公钥指针从所述防御非对称密钥池中提取对应的防御公钥。
6.根据权利要求1所述的基于多个公共非对称密钥池的抗量子计算代理云存储方法,其特征在于,所述用户端通过所述公共密钥池装置将数据文件的Hash值上传至所述服务器,所述数据文件的Hash值作为所述服务器是否进行去重的标识。
7.一种基于多个公共非对称密钥池的抗量子计算代理云存储方法,其特征在于,包括服务器接收并存储来自公共密钥池装置利用文件密钥加密的数据文件、防御公私钥指针随机数、防御公钥加密的密钥以及该密钥分别加密的数据密钥和个人密钥,所述密钥是利用所述公共密钥池装置所配有的密钥卡中量子随机数发生器生成,所述防御公钥由防御公私钥指针随机数在所述公共密钥池装置中提取。
8.根据权利要求7所述的基于多个公共非对称密钥池的抗量子计算代理云存储方法,其特征在于,
所述个人密钥生成方法为利用身份公钥加密所述文件密钥获得个人密钥,其中,所述身份公钥的加密方法包括:将身份公钥指针随机数结合身份公钥指针函数得到身份公钥指针,利用该身份公钥指针从身份非对称密钥池中提取对应的身份公钥;
所述数据密钥生成方式为利用文件特征值加密所述文件密钥得到数据密钥。
9.根据权利要求8所述的基于多个公共非对称密钥池的抗量子计算代理云存储方法,其特征在于,所述服务器还接收并存储来自所述用户端的数据文件的Hash值,其中所述数据文件的Hash值为服务器是否进行去重的指示标识;
当服务器依据所述指示标识判断去重时,所述服务器向所述用户端发送数据密钥;
当服务器依据所述指示标识判断不需去重时,接受存储来自所述用户端的所述数据文件的Hash值。
10.一种基于多个公共非对称密钥池的抗量子计算代理云存储系统,包括服务器、公共密钥池装置和用户端,其特征在于,
用户端上传利用文件密钥加密的数据文件、数据密钥及个人密钥至公共密钥池装置,所述公共密钥池装置将利用防御公私钥指针随机数提取防御公钥,同时利用随机数发生器生成密钥,令该密钥分别加密所述数据密钥和所述个人密钥,同时使该防御公钥加密所述密钥,所述公共密钥池装置将所述利用文件密钥加密的数据文件、防御公私钥指针随机数、防御公钥加密所述密钥以及密钥分别加密的数据密钥和个人密钥上传至服务器,其中,所述用户端及所述公共密钥池装置均配置有密钥卡,加密操作均在密钥卡内进行;
服务器接收并存储来自公共密钥池装置利用文件密钥加密的数据文件、防御公私钥指针随机数、防御公钥加密的密钥以及该密钥分别加密的数据密钥和个人密钥;
用户端发送读取文件请求至公共密钥池装置,公共密钥池装置下载文件密钥加密的数据文件、防御公私钥指针随机数、防御公钥加密的密钥以及该密钥加密的个人密钥;并利用所述防御公私钥指针随机数提取防御私钥,该防御私钥解密获得密钥进而获得个人密钥,所述公共密钥池装置将所述个人密钥及所述文件密钥加密的数据文件发送至所述用户端,所述用户端利用身份私钥解密所述个人密钥获得文件密钥,所述文件密钥解密获得数据文件,完成文件读取。
Priority Applications (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN201811643851.2A CN109687960B (zh) | 2018-12-29 | 2018-12-29 | 基于多个公共非对称密钥池的抗量子计算代理云存储方法和系统 |
Applications Claiming Priority (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN201811643851.2A CN109687960B (zh) | 2018-12-29 | 2018-12-29 | 基于多个公共非对称密钥池的抗量子计算代理云存储方法和系统 |
Publications (2)
Publication Number | Publication Date |
---|---|
CN109687960A true CN109687960A (zh) | 2019-04-26 |
CN109687960B CN109687960B (zh) | 2021-08-10 |
Family
ID=66191445
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
CN201811643851.2A Active CN109687960B (zh) | 2018-12-29 | 2018-12-29 | 基于多个公共非对称密钥池的抗量子计算代理云存储方法和系统 |
Country Status (1)
Country | Link |
---|---|
CN (1) | CN109687960B (zh) |
Cited By (2)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN110930251A (zh) * | 2019-10-18 | 2020-03-27 | 如般量子科技有限公司 | 基于联盟链和隐式证书的抗量子计算云存储方法及系统 |
CN114710359A (zh) * | 2022-04-15 | 2022-07-05 | 辽宁工控科技有限公司 | 工业网络动态密钥管理方法及工业网络加密通信方法 |
Citations (10)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN102546181A (zh) * | 2012-01-09 | 2012-07-04 | 西安电子科技大学 | 基于密钥池的云存储加解密方法 |
US20140068254A1 (en) * | 2012-08-29 | 2014-03-06 | Box, Inc. | Upload and download streaming encryption to/from a cloud-based platform |
CN105024801A (zh) * | 2015-07-06 | 2015-11-04 | 国网山东寿光市供电公司 | 一种量子加密通信方法 |
CN105162772A (zh) * | 2015-08-04 | 2015-12-16 | 三星电子(中国)研发中心 | 一种物联网设备认证与密钥协商方法和装置 |
CN106452740A (zh) * | 2016-09-23 | 2017-02-22 | 浙江神州量子网络科技有限公司 | 一种量子通信服务站、量子密钥管理装置以及密钥配置网络和方法 |
CN107682375A (zh) * | 2017-11-21 | 2018-02-09 | 武汉珈港科技有限公司 | 一种密钥管理和动态密钥保护方法 |
CN108173881A (zh) * | 2018-02-23 | 2018-06-15 | 苏州汉辰数字科技有限公司 | 一种量子流数据块的随机存储方法与系统 |
CN108989033A (zh) * | 2018-07-31 | 2018-12-11 | 如般量子科技有限公司 | 一种基于公共密钥池的云存储安全控制方法和系统 |
CN108985099A (zh) * | 2018-07-31 | 2018-12-11 | 如般量子科技有限公司 | 一种基于公共密钥池的代理云存储安全控制方法和系统 |
CN109104276A (zh) * | 2018-07-31 | 2018-12-28 | 如般量子科技有限公司 | 一种基于密钥池的云存储安全控制方法和系统 |
-
2018
- 2018-12-29 CN CN201811643851.2A patent/CN109687960B/zh active Active
Patent Citations (10)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN102546181A (zh) * | 2012-01-09 | 2012-07-04 | 西安电子科技大学 | 基于密钥池的云存储加解密方法 |
US20140068254A1 (en) * | 2012-08-29 | 2014-03-06 | Box, Inc. | Upload and download streaming encryption to/from a cloud-based platform |
CN105024801A (zh) * | 2015-07-06 | 2015-11-04 | 国网山东寿光市供电公司 | 一种量子加密通信方法 |
CN105162772A (zh) * | 2015-08-04 | 2015-12-16 | 三星电子(中国)研发中心 | 一种物联网设备认证与密钥协商方法和装置 |
CN106452740A (zh) * | 2016-09-23 | 2017-02-22 | 浙江神州量子网络科技有限公司 | 一种量子通信服务站、量子密钥管理装置以及密钥配置网络和方法 |
CN107682375A (zh) * | 2017-11-21 | 2018-02-09 | 武汉珈港科技有限公司 | 一种密钥管理和动态密钥保护方法 |
CN108173881A (zh) * | 2018-02-23 | 2018-06-15 | 苏州汉辰数字科技有限公司 | 一种量子流数据块的随机存储方法与系统 |
CN108989033A (zh) * | 2018-07-31 | 2018-12-11 | 如般量子科技有限公司 | 一种基于公共密钥池的云存储安全控制方法和系统 |
CN108985099A (zh) * | 2018-07-31 | 2018-12-11 | 如般量子科技有限公司 | 一种基于公共密钥池的代理云存储安全控制方法和系统 |
CN109104276A (zh) * | 2018-07-31 | 2018-12-28 | 如般量子科技有限公司 | 一种基于密钥池的云存储安全控制方法和系统 |
Cited By (4)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN110930251A (zh) * | 2019-10-18 | 2020-03-27 | 如般量子科技有限公司 | 基于联盟链和隐式证书的抗量子计算云存储方法及系统 |
CN110930251B (zh) * | 2019-10-18 | 2023-09-29 | 如般量子科技有限公司 | 基于联盟链和隐式证书的抗量子计算云存储方法及系统 |
CN114710359A (zh) * | 2022-04-15 | 2022-07-05 | 辽宁工控科技有限公司 | 工业网络动态密钥管理方法及工业网络加密通信方法 |
CN114710359B (zh) * | 2022-04-15 | 2024-02-06 | 沈阳邦粹科技有限公司 | 工业网络动态密钥管理方法及工业网络加密通信方法 |
Also Published As
Publication number | Publication date |
---|---|
CN109687960B (zh) | 2021-08-10 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
CN109151053A (zh) | 基于公共非对称密钥池的抗量子计算云存储方法和系统 | |
CN109150519A (zh) | 基于公共密钥池的抗量子计算云存储安全控制方法和系统 | |
CN103124269B (zh) | 云环境下基于动态口令与生物特征的双向身份认证方法 | |
CN104219228B (zh) | 一种用户注册、用户识别方法及系统 | |
CN109104276A (zh) | 一种基于密钥池的云存储安全控制方法和系统 | |
CN104253694B (zh) | 一种用于网络数据传输的保密方法 | |
CN108282329B (zh) | 一种双向身份认证方法及装置 | |
CN113691502B (zh) | 通信方法、装置、网关服务器、客户端及存储介质 | |
US20110145576A1 (en) | Secure method of data transmission and encryption and decryption system allowing such transmission | |
CN108985099A (zh) | 一种基于公共密钥池的代理云存储安全控制方法和系统 | |
CN108989033A (zh) | 一种基于公共密钥池的云存储安全控制方法和系统 | |
CN106104562A (zh) | 机密数据安全储存和恢复系统及方法 | |
CN101815091A (zh) | 密码提供设备、密码认证系统和密码认证方法 | |
CN106130716A (zh) | 基于认证信息的密钥交换系统及方法 | |
CN107465665A (zh) | 一种基于指纹识别技术的文件加解密方法 | |
CN109495251A (zh) | 基于密钥卡的抗量子计算智能家庭云存储方法和系统 | |
CN109347923A (zh) | 基于非对称密钥池的抗量子计算云存储方法和系统 | |
CN115499118A (zh) | 报文密钥生成、文件加密、解密方法、装置、设备和介质 | |
CN109787747A (zh) | 基于多个非对称密钥池的抗量子计算多重加密云存储方法和系统 | |
CN106230840B (zh) | 一种高安全性的口令认证方法 | |
CN109299618B (zh) | 基于量子密钥卡的抗量子计算云存储方法和系统 | |
CN109687960A (zh) | 基于多个公共非对称密钥池的抗量子计算代理云存储方法和系统 | |
CN106257859A (zh) | 一种密码使用方法 | |
CN109302283B (zh) | 基于公共非对称密钥池的抗量子计算代理云存储方法和系统 | |
CN109412788B (zh) | 基于公共密钥池的抗量子计算代理云存储安全控制方法和系统 |
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 |