CN109710617B - 一种基于默克尔证明的安全数据交易方法 - Google Patents
一种基于默克尔证明的安全数据交易方法 Download PDFInfo
- Publication number
- CN109710617B CN109710617B CN201811639954.1A CN201811639954A CN109710617B CN 109710617 B CN109710617 B CN 109710617B CN 201811639954 A CN201811639954 A CN 201811639954A CN 109710617 B CN109710617 B CN 109710617B
- Authority
- CN
- China
- Prior art keywords
- data
- block
- buyer
- chain
- mercker
- 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
Links
Images
Abstract
本发明公开了一种基于默克尔证明的安全数据交易方法,其中数据是在链下以默克尔树的结构进行存储,数据提供者将任意剔除一个默克尔数据块然后将剩余的数据块通过链下进行传输,而挑选出来的块的交易是通过区块链上的智能合约来进行的。首先,购买者先去区块链上冻结一笔转给数据提供者的资金,并标示自己缺失的数据块哈希值,然后只要数据提供者能提供对应这个哈希的数据块,智能合约自动将资金转给数据提供者,同时购买者也可以在链上获取这个数据。本发明结合区块链解决了数据交易的安全、可信问题,通过区块链保证了资金和数据交换的一致性,避免了任何一方抵赖的问题。
Description
技术领域
本发明涉及区块链智能合约资金交易、数据的默克尔树存储领域,尤其涉及一种基于默克尔证明的安全数据交易方法。
背景技术
智能合约(英语:Smart Contract)是一种旨在以信息化方式传播、验证或执行合同的计算机协议。智能合约允许在没有第三方的情况下进行可信交易,这些交易可追踪且不可逆转。
默克尔树是区块链的重要数据结构,其作用是快速归纳和校验区块数据的存在性和完整性。一般意义上来讲,它是哈希大量聚集数据“块”的一种方式,它依赖于将这些数据“块”分裂成较小单位的数据块,每一个bucket块仅包含几个数据“块”,然后取每个bucket单位数据块再次进行哈希,重复同样的过程,直至剩余的哈希总数仅变为1。
基于默克尔证明的安全数据交易方法是结合默克尔树安全校验数据块存在性的优点和区块链智能合约不可篡改性和按照既定合约执行的特点而得出的一种安全数据交易方法。
然而,现有的技术很难保证资金和数据交互的一致性问题,如果存在一方耍赖的情况,还需要一个公认可信的第三方权威机构去作为担保。
发明内容
本发明的目的是针对数据交易双方不信任,交易环境不安全的问题,提出一种基于默克尔证明的安全数据交易方法。
本烦的目的是通过如下技术方案实现的:一种基于默克尔证明的安全数据交易方法,数据是在链下以默克尔树的结构进行存储,每份数据有一个唯一的哈希值对应,该方法具体包括如下步骤:
(1)购买者向数据提供者获取一份数据,数据提供者将任意挑选出默克尔树中的一个块,然后把剩下的直接发给购买者,同时也会告诉购买者缺失块的哈希值。
(2)购买者收到缺失了一个块的数据后,会到区块链上冻结一笔需要付给数据提供者的资金,并声明缺失块的哈希值。
(3)数据提供者只要到区块链上提供这个数据块,智能合约自动判断提供的数据块是否符合购买者的需求,如果满足需求,那么智能合约按照既定逻辑将资金转给数据提供者;同时购买者即可到区块链上下载这个数据;如果不满足条件,则此次交易认为失败;
进一步地,数据提供者需要把数据以默克尔树的结构存储在链下,并把这个数据的哈希值保存到区块链智能合约上,以证实数据的真实存在性。
进一步地,为了避免区块链上存储的数据过大,所以缺失块的大小一定不能太大,否则就失去了链下存储数据,链上数据交易的初衷。
进一步地,为了避免区块链上存储的数据过大,智能合约管理者需要定时清理没用的交易数据。
进一步地,数据提供者在针对同一个购买者时,挑选数据块必须是幂等的,否则购买者可以通过多次获取数据来拼凑出完整数据。
本发明的有益效果如下:
本发明结合区块链解决了数据交易的安全、可信问题,通过区块链保证了资金和数据交换的一致性,避免了任何一方的抵赖。
附图说明
图1为本发明的基于默克尔证明的安全数据交易方法的流程图。
具体实施方式
下面根据附图和具体实施例详细描述本发明,本发明的目的和效果将变得更加明显。
如图1所示,一种基于默克尔证明的安全数据交易方法,数据是在链下以默克尔树的结构进行存储,每份数据有一个唯一的哈希值对应,该方法具体包括如下步骤:
(1)购买者向数据提供者获取一份数据,数据提供者将任意挑选出默克尔树中的一个块,然后把剩下的直接发给购买者,同时也会告诉购买者缺失块的哈希值。
(2)购买者收到缺失了一个块的数据后,会到区块链上冻结一笔需要付给数据提供者的资金,并声明缺失块的哈希值。
(3)数据提供者只要到区块链上提供这个数据块,智能合约自动判断提供的数据块是否符合购买者的需求,如果满足需求,那么智能合约按照既定逻辑将资金转给数据提供者;同时购买者即可到区块链上下载这个数据;如果不满足条件,则此次交易认为失败;
进一步地,数据提供者需要把数据以默克尔树的结构存储在链下,并把这个数据的哈希值保存到区块链智能合约上,以证实数据的真实存在性。
进一步地,为了避免区块链上存储的数据过大,所以缺失块的大小一定不能太大,否则就失去了链下存储数据,链上数据交易的初衷。
进一步地,为了避免区块链上存储的数据过大,智能合约管理者需要定时清理没用的交易数据。
进一步地,数据提供者在针对同一个购买者时,挑选数据块必须是幂等的,否则购买者可以通过多次获取数据来拼凑出完整数据。
Claims (4)
1.一种基于默克尔证明的安全数据交易方法,其特征在于,数据是在链下以默克尔树的结构进行存储,每份数据有一个唯一的哈希值对应,该方法具体包括如下步骤:
(1)购买者向数据提供者获取一份数据,数据提供者将任意挑选出默克尔树中的一个块,然后把剩下的直接发给购买者,同时也会告诉购买者缺失块的哈希值;数据提供者在针对同一个购买者时,挑选数据块必须是幂等的,否则购买者可以通过多次获取数据来拼凑出完整数据;
(2)购买者收到缺失了一个块的数据后,会到区块链上冻结一笔需要付给数据提供者的资金,并声明缺失块的哈希值;
(3)数据提供者只要到区块链上提供这个数据块,智能合约自动判断提供的数据块是否符合购买者的需求,如果满足需求,那么智能合约按照既定逻辑将资金转给数据提供者;同时购买者即可到区块链上下载这个数据;如果不满足条件,则此次交易认为失败。
2.根据权利要求1所述的一种基于默克尔证明的安全数据交易方法,其特征在于,数据提供者需要把数据以默克尔树的结构存储在链下,并把这个数据的哈希值保存到区块链智能合约上,以证实数据的真实存在性。
3.根据权利要求1所述的一种基于默克尔证明的安全数据交易方法,其特征在于,为了避免区块链上存储的数据过大,所以缺失块的大小一定不能太大,否则就失去了链下存储数据,链上数据交易的初衷。
4.根据权利要求1所述的一种基于默克尔证明的安全数据交易方法,其特征在于,为了避免区块链上存储的数据过大,智能合约管理者需要定时清理没用的交易数据。
Priority Applications (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN201811639954.1A CN109710617B (zh) | 2018-12-29 | 2018-12-29 | 一种基于默克尔证明的安全数据交易方法 |
Applications Claiming Priority (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN201811639954.1A CN109710617B (zh) | 2018-12-29 | 2018-12-29 | 一种基于默克尔证明的安全数据交易方法 |
Publications (2)
Publication Number | Publication Date |
---|---|
CN109710617A CN109710617A (zh) | 2019-05-03 |
CN109710617B true CN109710617B (zh) | 2021-07-30 |
Family
ID=66260204
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
CN201811639954.1A Active CN109710617B (zh) | 2018-12-29 | 2018-12-29 | 一种基于默克尔证明的安全数据交易方法 |
Country Status (1)
Country | Link |
---|---|
CN (1) | CN109710617B (zh) |
Families Citing this family (4)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN110415117A (zh) * | 2019-06-28 | 2019-11-05 | 阿里巴巴集团控股有限公司 | 基于区块链的交易处理方法、装置和电子设备 |
US11222011B2 (en) | 2019-06-28 | 2022-01-11 | Advanced New Technologies Co., Ltd. | Blockchain-based transaction processing |
CN111552738B (zh) * | 2020-04-20 | 2023-11-03 | 山东共智云科技发展有限公司 | 基于物联网的区块链生态系统和区块链上链方法 |
CN112488683B (zh) * | 2020-12-11 | 2024-02-23 | 深圳前海微众银行股份有限公司 | 一种区块链的链下交易方法及装置 |
Citations (4)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN107169764A (zh) * | 2017-05-10 | 2017-09-15 | 山东大学 | 基于区块链的公平数据交易方法 |
CN107730225A (zh) * | 2017-10-24 | 2018-02-23 | 广东工业大学 | 一种大数据交易方法、系统、设备及计算机存储介质 |
CN108550039A (zh) * | 2018-04-24 | 2018-09-18 | 北京罗格数据科技有限公司 | 一种基于区块链结构化数据的交易方法 |
CN108920908A (zh) * | 2018-06-28 | 2018-11-30 | 北京京东尚科信息技术有限公司 | 数据存储方法、装置和计算机可读存储介质 |
Family Cites Families (4)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US10515409B2 (en) * | 2016-03-23 | 2019-12-24 | Domus Tower, Inc. | Distributing work load of high-volume per second transactions recorded to append-only ledgers |
US20180285839A1 (en) * | 2017-04-04 | 2018-10-04 | Datient, Inc. | Providing data provenance, permissioning, compliance, and access control for data storage systems using an immutable ledger overlay network |
CN108829350B (zh) * | 2018-05-31 | 2020-02-21 | 阿里巴巴集团控股有限公司 | 基于区块链的数据迁移方法和装置 |
CN109003078B (zh) * | 2018-06-27 | 2021-08-24 | 创新先进技术有限公司 | 基于区块链的智能合约调用方法及装置、电子设备 |
-
2018
- 2018-12-29 CN CN201811639954.1A patent/CN109710617B/zh active Active
Patent Citations (4)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN107169764A (zh) * | 2017-05-10 | 2017-09-15 | 山东大学 | 基于区块链的公平数据交易方法 |
CN107730225A (zh) * | 2017-10-24 | 2018-02-23 | 广东工业大学 | 一种大数据交易方法、系统、设备及计算机存储介质 |
CN108550039A (zh) * | 2018-04-24 | 2018-09-18 | 北京罗格数据科技有限公司 | 一种基于区块链结构化数据的交易方法 |
CN108920908A (zh) * | 2018-06-28 | 2018-11-30 | 北京京东尚科信息技术有限公司 | 数据存储方法、装置和计算机可读存储介质 |
Also Published As
Publication number | Publication date |
---|---|
CN109710617A (zh) | 2019-05-03 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
CN109710617B (zh) | 一种基于默克尔证明的安全数据交易方法 | |
CN108536761B (zh) | 报表数据查询方法及服务器 | |
US11095451B2 (en) | Optimal data storage configuration in a blockchain | |
US10262140B2 (en) | Methods and apparatus to facilitate blockchain-based boot tracking | |
KR102120703B1 (ko) | 블록체인 네트워크 상에서 그룹키 기반의 이중 서명 트랜잭션 구조를 구성하는 노드 그룹 관리 장치 및 컴퓨팅 장치 | |
CN109543455B (zh) | 一种区块链的数据归档方法及装置 | |
CN111090645B (zh) | 基于云存储的数据传输方法、装置及计算机设备 | |
US20200117550A1 (en) | Method, device and computer program product for backing up data | |
CN109493061A (zh) | 一种区块链的数据的验证方法、装置、电子设备及存储介质 | |
CN111095218B (zh) | 基于纠错编码存储共享的区块链数据的方法、系统及装置 | |
CN113570479B (zh) | 一种房产交易数据的区块链传输方法、系统及存储介质 | |
CN110471982B (zh) | 基于区块链的数据处理方法和装置 | |
CN109542602B (zh) | 一种基于区块链的分布式任务处理方法、装置及系统 | |
CN110213368B (zh) | 数据处理方法、数据处理装置和计算机系统 | |
US11210003B2 (en) | Method, device and computer program product for restoring data based on replacing child node identifiers with parent node identifier | |
CN111899019A (zh) | 一种黑名单多方交叉验证和共享的方法及系统 | |
CN112488725B (zh) | 隐私授权转账方法、设备和存储介质 | |
US10268776B1 (en) | Graph store built on a distributed hash table | |
CN111033491A (zh) | 基于纠错编码存储共享的区块链数据 | |
CN109753823B (zh) | 一种区块链数据监管方法、系统及计算机存储介质 | |
CN110766403A (zh) | 基于区块链的数据处理装置、方法及存储介质 | |
CN111241069B (zh) | 一种基于区块链的数据扁平化方法及系统 | |
CN110209347B (zh) | 一种可追溯的数据存储方法 | |
CN111260364A (zh) | 一种基于区块链的可扩展快速支付方法及系统 | |
CN113159952B (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 |