CN111488357A - 业务数据区块链的数字账户实现方法及装置 - Google Patents
业务数据区块链的数字账户实现方法及装置 Download PDFInfo
- Publication number
- CN111488357A CN111488357A CN202010271070.6A CN202010271070A CN111488357A CN 111488357 A CN111488357 A CN 111488357A CN 202010271070 A CN202010271070 A CN 202010271070A CN 111488357 A CN111488357 A CN 111488357A
- Authority
- CN
- China
- Prior art keywords
- state
- user
- tree
- status
- entity
- 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.)
- Withdrawn
Links
Images
Classifications
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06Q—INFORMATION AND COMMUNICATION TECHNOLOGY [ICT] SPECIALLY ADAPTED FOR ADMINISTRATIVE, COMMERCIAL, FINANCIAL, MANAGERIAL OR SUPERVISORY PURPOSES; SYSTEMS OR METHODS SPECIALLY ADAPTED FOR ADMINISTRATIVE, COMMERCIAL, FINANCIAL, MANAGERIAL OR SUPERVISORY PURPOSES, NOT OTHERWISE PROVIDED FOR
- G06Q40/00—Finance; Insurance; Tax strategies; Processing of corporate or income taxes
- G06Q40/04—Trading; Exchange, e.g. stocks, commodities, derivatives or currency exchange
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F16/00—Information retrieval; Database structures therefor; File system structures therefor
- G06F16/20—Information retrieval; Database structures therefor; File system structures therefor of structured data, e.g. relational data
- G06F16/22—Indexing; Data structures therefor; Storage structures
- G06F16/2228—Indexing structures
- G06F16/2246—Trees, e.g. B+trees
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F16/00—Information retrieval; Database structures therefor; File system structures therefor
- G06F16/20—Information retrieval; Database structures therefor; File system structures therefor of structured data, e.g. relational data
- G06F16/22—Indexing; Data structures therefor; Storage structures
- G06F16/2228—Indexing structures
- G06F16/2255—Hash tables
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F16/00—Information retrieval; Database structures therefor; File system structures therefor
- G06F16/20—Information retrieval; Database structures therefor; File system structures therefor of structured data, e.g. relational data
- G06F16/24—Querying
- G06F16/245—Query processing
- G06F16/2455—Query execution
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F21/00—Security arrangements for protecting computers, components thereof, programs or data against unauthorised activity
- G06F21/60—Protecting data
- G06F21/62—Protecting access to data via a platform, e.g. using keys or access control rules
- G06F21/6218—Protecting access to data via a platform, e.g. using keys or access control rules to a system of files or objects, e.g. local or distributed file system or database
- G06F21/6227—Protecting access to data via a platform, e.g. using keys or access control rules to a system of files or objects, e.g. local or distributed file system or database where protection concerns the structure of data, e.g. records, types, queries
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F21/00—Security arrangements for protecting computers, components thereof, programs or data against unauthorised activity
- G06F21/60—Protecting data
- G06F21/64—Protecting data integrity, e.g. using checksums, certificates or signatures
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06Q—INFORMATION AND COMMUNICATION TECHNOLOGY [ICT] SPECIALLY ADAPTED FOR ADMINISTRATIVE, COMMERCIAL, FINANCIAL, MANAGERIAL OR SUPERVISORY PURPOSES; SYSTEMS OR METHODS SPECIALLY ADAPTED FOR ADMINISTRATIVE, COMMERCIAL, FINANCIAL, MANAGERIAL OR SUPERVISORY PURPOSES, NOT OTHERWISE PROVIDED FOR
- G06Q20/00—Payment architectures, schemes or protocols
- G06Q20/04—Payment circuits
- G06Q20/06—Private payment circuits, e.g. involving electronic currency used among participants of a common payment scheme
- G06Q20/065—Private payment circuits, e.g. involving electronic currency used among participants of a common payment scheme using e-cash
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04L—TRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
- H04L67/00—Network arrangements or protocols for supporting network services or applications
- H04L67/01—Protocols
- H04L67/10—Protocols in which an application is distributed across nodes in the network
Landscapes
- Engineering & Computer Science (AREA)
- Theoretical Computer Science (AREA)
- Physics & Mathematics (AREA)
- General Physics & Mathematics (AREA)
- Business, Economics & Management (AREA)
- General Engineering & Computer Science (AREA)
- Databases & Information Systems (AREA)
- Accounting & Taxation (AREA)
- Software Systems (AREA)
- Data Mining & Analysis (AREA)
- Finance (AREA)
- Computer Security & Cryptography (AREA)
- Health & Medical Sciences (AREA)
- General Health & Medical Sciences (AREA)
- Bioethics (AREA)
- General Business, Economics & Management (AREA)
- Strategic Management (AREA)
- Computer Hardware Design (AREA)
- Computational Linguistics (AREA)
- Development Economics (AREA)
- Technology Law (AREA)
- Marketing (AREA)
- Economics (AREA)
- Computer Networks & Wireless Communication (AREA)
- Signal Processing (AREA)
- Management, Administration, Business Operations System, And Electronic Commerce (AREA)
Abstract
本申请公开了一种业务数据区块链的数字账户实现方法及装置,所述方法包括:区块链节点通过树形结构的方式,存储用户操作后的状态;所述树形结构包括状态树和关系树,所述状态树存储用户操作后的状态,所述关系树存储用户操作后状态之间的关联关系。本申请中业务数据区块链上设置用户数字账户,业务数据上链之后,用户能够通过数字账户来管理区块链上的数字资产,提升用户的业务数据区块链***使用体验。
Description
技术领域
本发明涉及互联网大数据技术领域,公开一种业务数据区块链的数字账户实现方法及装置。
背景技术
目前,区块链技术是运用加密算法、共识机制等技术的分布式存储账本。随着区块链技术的运用,越来越多的互联网数据会存储在区块链上。
现有的区块链中,只能存储交易数据,交易数据包括转账方地址、接收方地址以及转账金额;针对各种业务数据(例如:存证数据、溯源数据、金融数据、旅游数据、搜索数据、自媒体数据、调研数据、广告数据、电商数据、社区数据、知识问答数据、知识付费数据、共享单车数据、招聘数据、生活服务数据、租房数据、投票数据、OTO数据(也称为线上到线下数据)、社交数据、点赞数据、评价数据、网约车数据等互联网相关数据)而言,不仅需要在区块链上表达出数据本身,还需要在区块链上表达出数据之间的关联关系。
此外,目前的区块链账户,主要表达用户资产,也就是用户拥有的各种积分余额;针对上述业务数据上链之后,用户的资产不仅仅是积分余额。
以上描述仅仅为了方便理解,并不应限定为本申请的现有技术。
发明内容
基于上述问题,本申请公开业务数据区块链的数字账户实现方法及装置,该方法中业务数据区块链上设置用户数字账户,业务数据上链之后,用户能够通过数字账户来管理区块链上的数字资产,提升用户的业务数据区块链***使用体验。
本申请第一方面公开了一种业务数据区块链的数字账户实现方法,所述方法包括:
区块链节点通过树形结构的方式,存储用户操作后的状态;
所述树形结构包括状态树和关系树,所述状态树存储用户操作后的状态,所述关系树存储用户操作后状态之间的关联关系。
在一种可能的实现方式中,所述状态树中叶子节点的value存储积分状态、实体状态、用户状态以及消息状态中的一种或多种。
在一种可能的实现方式中,所述关系树中叶子节点存储关系子树的树根,所述关系子树叶子节点的value存储用户状态-用户操作状态、用户状态-积分状态、用户状态-实体状态以及用户状态-消息状态中一种或多种;或
所述关系树中叶子节点的value以数组或哈希表的方式存储用户状态-用户操作状态、用户状态-积分状态、用户状态-实体状态以及用户状态-消息状态中一种或多种。
在一种可能的实现方式中,所述用户状态、所述实体状态、所述积分状态、用户状态-用户操作状态、用户状态-积分状态、用户状态-实体状态以及用户状态-消息状态中任意一种信息以数据表的形式存储在支持属性查询的数据库中,以便于用户根据所述数据表中的属性字段进行查询;其中,一种信息对应一种数据表,任意一种数据表中的任意一行对应一条状态信息,一种信息包括多行状态信息;所述支持属性查询的数据库包括关系数据库和内存数据库;或
所述用户状态、所述实体状态、所述积分状态、用户状态-用户操作状态、用户状态-积分状态、用户状态-实体状态以及用户状态-消息状态中的任意一种信息采用KV数据库存储,以键值对的方式进行存储。
在一种可能的实现方式中,所述用户状态-所述消息状态的关系树中,所述消息状态包括广告消息和商品优惠卷中的一种或两种;其中,
所述广告消息响应于用户的点击操作,所述用户状态-所述积分状态的关系树存储所述广告消息对应的积分状态;
所述商品优惠卷响应于用户的领取操作,所述用户状态-所述实体状态的关系树存储所述商品优惠卷对应的实体状态。
在一种可能的实现方式中,所述关系树和所述状态树采用默克尔树或MPT树,所述MPT树是融合了前缀树的树形结构的默克尔树变种,所述默克尔树为Merkle PatriciaTree树。
本申请第二方面公开了一种业务数据区块链的数字账户实现装置,其特征在于,所述装置为区块链节点;其中,
区块链节点通过树形结构的方式,存储用户操作后的状态;所述树形结构包括状态树和关系树,所述状态树存储用户操作后的状态,所述关系树存储用户操作后状态之间的关联关系。
在一种可能的实现方式中,所述状态树中叶子节点的value存储积分状态、实体状态、用户状态以及消息状态中的一种或多种。
在一种可能的实现方式中,所述关系树中叶子节点存储关系子树的树根,所述关系子树叶子节点的value存储用户状态-用户操作状态、用户状态-积分状态、用户状态-实体状态以及用户状态-消息状态中一种或多种;或
所述关系树中叶子节点的value以数组或哈希表的方式存储用户状态-用户操作状态、用户状态-积分状态、用户状态-实体状态以及用户状态-消息状态中一种或多种。
在一种可能的实现方式中,所述用户状态、所述实体状态、所述积分状态、用户状态-用户操作状态、用户状态-积分状态、用户状态-实体状态以及用户状态-消息状态中任意一种信息以数据表的形式存储在支持属性查询的数据库中,以便于用户根据所述数据表中的属性字段进行查询;其中,一种信息对应一种数据表,任意一种数据表中的任意一行对应一条状态信息,一种信息包括多行状态信息;所述支持属性查询的数据库包括关系数据库和内存数据库;或
所述用户状态、所述实体状态、所述积分状态、用户状态-用户操作状态、用户状态-积分状态、用户状态-实体状态以及用户状态-消息状态中的任意一种信息采用KV数据库存储,以键值对的方式进行存储。
在一种可能的实现方式中,所述用户状态-所述消息状态的关系树中,所述消息状态包括广告消息和商品优惠卷中的一种或两种;其中,
所述广告消息响应于用户的点击操作,所述用户状态-所述积分状态的关系树存储所述广告消息对应的积分状态;
所述商品优惠卷响应于用户的领取操作,所述用户状态-所述实体状态的关系树存储所述商品优惠卷对应的实体状态。
在一种可能的实现方式中,所述关系树和所述状态树采用默克尔树或MPT树,所述MPT树是融合了前缀树的树形结构的默克尔树变种,所述默克尔树为Merkle PatriciaTree树。
在一种可能的实现方式中,所述用户操作数据为用户在互联网上的操作数据,所述用户操作数据包括存证数据、溯源数据、金融数据、旅游数据、搜索数据、自媒体数据、调研数据、广告数据、电商数据、社区数据、知识问答数据、知识付费数据、共享单车数据、招聘数据、生活服务数据、租房数据、投票数据、线上到线下数据、社交数据、点赞数据、评价数据以及网约车数据中的一种或多种。
在一种可能的实现方式中,所述用户操作数据包括时间戳、操作用户地址、***作地址、操作类型、操作的值、积分地址、用户对用户操作数据的签名以及用户操作数据的哈希值中的一种或多种;其中,所述操作类型包括用户对实体的操作和对积分的操作,所述***作地址包括对实体的操作地址和其他操作用户的地址。
在一种可能的实现方式中,用户操作数据的属性包括关联属性和非关联属性;其中,该关联属性的属性值根据用户操作后的数据状态自动增减。
本申请第三方面提供一种计算机可读存储介质,该存储介质存储有计算机指令,该计算机指令被处理器执行时,实现如上所述任意一项技术方案。
本申请第四方面提供一种电子设备,该电子设备包括处理器,所述处理器用于执行如上所述任意一项技术方案。
本申请中业务数据区块链上设置用户数字账户,业务数据上链之后,用户能够通过数字账户来管理区块链上的数字资产,提升用户的业务数据区块链***使用体验。
附图说明
为了更清楚地说明本发明实施例的技术方案,下面将对实施例描述中所需要使用的附图作简单地介绍,显而易见地,下面描述中的附图仅仅是发明的一些实施例,对于本领域普通技术人员来讲,在不付出创造性劳动的前提下,还可以根据这些附图获得其他的附图。
图1为本申请公开了业务数据区块链的数字账户实现方法流程示意图;
图2为本申请公开了一种业务数据区块链的区块头结构示意图;
图3为本申请公开了业务数据区块链的数字账户实现设备结构示意图。
具体实施方式
为使本发明实施例的目的、技术方案和优点更加清楚,下面将结合本发明实施例中的附图,对本发明实施例中的技术方案进行清楚、完整地描述,显然,所描述的实施例是本发明一部分实施例,而不是全部的实施例。基于本发明中的实施例,本领域普通技术人员在没有做出创造性劳动前提下所获得的所有其他实施例,都属于本发明保护的范围。
本申请中的“第一”“第二”仅仅是便于理解,给技术词做区分,并不理解为先后,或作为限制性的理解。
为便于对本发明实施例的理解,下面将结合附图以具体实施例作进一步的解释说明,实施例并不构成对本发明实施例的限定。
区块链一般被划分为三种类型:公有链(Public Blockchain),私有链(PrivateBlockchain)和联盟链(Consortium Blockchain)。此外,还有多种类型的结合,比如私有链+联盟链、联盟链+公有链等不同组合形式。其中去中心化程度最高的是公有链。公有链以比特币、以太坊为代表,加入公有链的参与者可以读取链上的数据记录、参与交易以及竞争新区块的记账权等。
而且,各参与者(即节点)可自由加入以及退出网络,并进行相关操作。私有链则相反,该网络的写入权限由某个组织或者机构控制,数据读取权限受组织规定。简单来说,私有链可以为一个弱中心化***,参与节点具有严格限制且少。这种类型的区块链更适合于特定机构内部使用。
基于区块链的基本特性,区块链通常是由若干个区块构成。在这些区块中分别记录有与该区块的创建时刻对应的时间戳,所有的区块严格按照区块中记录的时间戳,构成一条在时间上有序的数据链条。
对于物理世界产生的真实数据,可以将其构建成区块链所支持的标准的交易(transaction)格式,然后发布至区块链,由区块链中的节点设备进行共识,并在达成共识后,由区块链中作为记账节点的节点设备,将这笔交易打包进区块,在区块链中进行持久化存证。
在区块链领域,有一个重要的概念就是账户(Account);以以太坊为例,以太坊通常将账户划分为外部账户和合约账户两类;外部账户就是由用户直接控制的账户;而合约账户则是由用户通过外部账户创建的,包含合约代码的账户(即智能合约)。
当然,对于一些基于以太坊的架构而衍生出的区块链项目,还可以对区块链支持的账户类型,进行进一步的扩展,在本说明书中不进行特别限定。
对于区块链中的账户而言,通常会通过一个结构体,来维护账户的账户状态。当区块中的交易被执行后,区块链中与该交易相关的账户的状态通常也会发生变化。
以以太坊为例,账户的结构体通常包括Balance,Nonce,Code和storage等字段。其中:
Balance字段,用于维护账户目前的账户余额;
Nonce字段,用于该账户的交易次数;它是用于保障每笔交易能且只能被处理一次的计数器,有效避免重放攻击。
code字段,用于维护该账户的合约代码;在实际应用中,code字段中通常仅维护合约代码的hash值;因而,code字段通常也称之为codehash字段。对于外部账户而言,该字段为空值。
storage字段,用于维护该账户的存储(默认为空)。在实际应用中,storage字段仅维护基于账户的存储内容构建的MPT(Merkle Patricia Trie)树的根节点;因此,storage字段通常也称之为storageRoot字段。
其中,对于外部账户而言,以上示出的code字段和storage字段为空值。
而大多数区块链项目,通常都会使用Merkle树;或者,基于Merkle树的数据结构,来存储和维护数据。以以太坊为例,以太坊使用了MPT树(一种Merkle树变种),作为数据组织形式,用来组织和管理账户状态、交易信息等重要数据。
以太坊针对区块链中需要存储和维护的数据,设计了三颗MPT树,分别是MPT状态树、MPT交易树和MPT收据树。
MPT状态树,是区块链中所有账户的账户状态数据(state),组织成的MPT树;MPT交易树是区块中的交易数据(transaction),组织成的MPT树;MPT收据树,是区块中的交易执行完毕后生成的与每笔交易对应的交易收据(receipt),组织成的MPT树。以上示出的MPT状态树、MPT交易树和MPT收据树的根节点的hash值,都会被添加至区块头中。
其中,MPT交易树和MPT收据树,与区块相对应,每一个区块都有自己的MPT交易树和MPT收据树。而MPT状态树是一个全局的MPT树,并不与某一个特定的区块相对应,而是涵盖了区块链中所有账户的账户状态数据。
本说明书公开了业务数据区块链的数字账户实现方法,如图1所示,所述业务数据区块链***包括多个区块链节点;该方法包括S101-S102。
本说明书中的实体信息是指对客观事物的抽象,也指具体的客观事物,实体信息包括关联属性和非关联属性,关联属性是指属性值能够增减;用户信息是指用户的描述信息,用户信息包括用户地址;积分信息指用户发行的积分,是除了区块链上原生积分以外的积分信息,积分信息包括积分的名称、总量。
S101、区块链节点通过树形结构的方式,存储用户操作后的状态。
S102、所述树形结构包括状态树和关系树,所述状态树存储用户操作后的状态,所述关系树存储用户操作后状态之间的关联关系。
在一个示例中,所述状态树中叶子节点的value存储积分状态、实体状态、用户状态以及消息状态中的一种或多种。
举例来说,实体是互联网电子商务平台的商品,用户可以发起购买该商品的操作,就是针对该商品实体对应积分的积分转移操作(积分从操作用户地址转移到***作用户的地址上);用户也可以发起针对该商品的评论或点赞操作,就是针对该商品实体的用户操作。
属性类型中关联属性,例如:点赞的数量,针对同一商品或者自媒体(例如:微信朋友圈发的图、文、小视频),不同的用户点赞后,该商品或自媒体的点赞数会自动增加。非关联属性,例如:评论的内容,不同的用户评论后,用户在区块链上搜索该商品,能够看到不同用户的评论。
该积分是用户发行的积分,例如:用户可以通过公证后,将房子证券化后,在区块链上发行一个积分,这个积分在区块链上唯一表示该房产;也可以是,将房子证券化,发行预定数量的积分,拥有该积分即拥有该房子的所有权,享有该房子租赁或者变卖的对等所有权。除此之外,区块链上拥有原生积分,该原生积分可以用于约束用户在区块链上的操作,避免用户无限制的使用区块链***的资源;例如:区块链上的用户注册后,在区块链上进行操作,需要抵押原生积分,才能将用户操作数据上链。
对消息状态来说,消息是用户B发送给A,消息可以是商品优惠卷、广告、积分红包等。商品优惠卷就是用户A点击后,就表明用户A获取了该商品实体;用户A点击广告后,根据用户B对广告的设置,用户A可以获得广告观看的积分奖励,也可以获得广告观看的实体奖励;积分红包,用户A点击该积分红包后,用户A可以获得该积分红包中的积分。
在本说明书的业务数据区块链中,用户所拥有的数字资产包括实体资产、积分资产、消息资产以及用户操作数据资产。
在一个示例中,所述关系树中叶子节点存储关系子树的树根,所述关系子树叶子节点的value存储用户状态-用户操作状态、用户状态-积分状态、用户状态-实体状态以及用户状态-消息状态中一种或多种。
在一个示例中,所述关系树中叶子节点的value以数组或哈希表的方式存储用户状态-用户操作状态、用户状态-积分状态、用户状态-实体状态以及用户状态-消息状态中一种或多种。
此时,对于用户状态与积分状态之间的关系。一位用户有可能拥有多种积分,例如:一位用户既拥有区块链上的原生积分,还拥有其他类型的积分。上述关联关系能够描述该用户与积分之间的一对多关系,同时也方便该用户查询。需要说明的是,在区块链***中的用户,至少会拥有该区块链***的原生积分;有可能拥有其他用户发行或者自己发行的积分。同一种类的积分也能被多位用户拥有。
对于用户状态-用户操作状态之间的关系。同一用户,会在业务数据区块链上进行多次操作;例如:用户A,进行了调研操作a;又进行了广告点击操作c;在另外的时刻,进行了电商购买操作b,进行了自媒体点赞d;用户A的这些用户操作的数据权属都是属于A,因此需要一组对应关系存储这些用户操作。这些用户操作都是用户的用户操作资产。
对于用户状态-实体状态之间的关系。一位用户可以拥有多种实体,同一种实体也可以被不同的用户拥有。对单个的用户来说,可以拥有不同类型的电商店铺实体,也可以拥有购买过的多个商品实体,也可以是回答的多个调研问卷实体,多个发布的自媒体实体等:这些实体都是用户的实体数据资产。
对于用户状态-消息状态之间的关系。同上,一位用户可以拥有多个消息,某种消息也可以被多位用户拥有。对个体用户来说,其他商家用户会给他推送商品优惠卷、广告、积分红包等消息,这些消息属于该个体用户的消息资产,需要存储用户与消息状态之间的关系。
由上述可知,用户的数字账户包括用户状态-消息状态、用户状态-实体状态、用户状态-积分状态、用户状态-用户操作状态中的一种或多种。
在一个示例中,所述用户状态-所述消息状态的关系树中,所述消息状态包括广告消息和商品优惠卷中的一种或两种。
所述广告消息响应于用户的点击操作,所述用户状态-所述积分状态的关系树存储所述广告消息对应的积分状态;
所述商品优惠卷响应于用户的领取操作,所述用户状态-所述实体状态的关系树存储所述商品优惠卷对应的实体状态。
在一个示例中,所述用户状态、所述实体状态、所述积分状态、用户状态-用户操作状态、用户状态-积分状态、用户状态-实体状态以及用户状态-消息状态中任意一种信息以数据表的形式存储在支持属性查询的数据库中,以便于用户根据所述数据表中的属性字段进行查询;其中,一种信息对应一种数据表,任意一种数据表中的任意一行对应一条状态信息,一种信息包括多行状态信息;所述支持属性查询的数据库包括关系数据库和内存数据库。
关系数据库可以采用MySql,内存数据库采用MongoDB数据库。
在一个示例中,所述用户状态、所述实体状态、所述积分状态、用户状态-用户操作状态、用户状态-积分状态、用户状态-实体状态以及用户状态-消息状态中的任意一种信息采用KV数据库存储,以键值对的方式进行存储。
在一个示例中,所述状态树或所述关系树采用默克尔树或者MPT树,默克尔树或MPT树的树根存储在区块头中;其中,所述MPT树是融合了前缀树的树形结构的默克尔树变种,所述默克尔树为Merkle Patricia Tree树。
在一个示例中,所述用户操作数据为用户在互联网上的操作数据,所述用户操作数据包括存证数据、溯源数据、金融数据、旅游数据、搜索数据、自媒体数据、调研数据、广告数据、电商数据、社区数据、知识问答数据、知识付费数据、共享单车数据、招聘数据、生活服务数据、租房数据、投票数据、线上到线下数据、社交数据、点赞数据、评价数据以及网约车数据中的一种或多种。
在一个示例中,所述用户操作数据包括时间戳、操作用户地址、***作地址、操作类型、操作的值、积分地址、用户对用户操作数据的签名以及用户操作数据的哈希值中的一种或多种;其中,所述操作类型包括用户对实体的操作和对积分的操作,所述***作地址包括对实体的操作地址和其他操作用户的地址。
如上所述,用户状态(如:Account字段)、积分状态(如:Asset字段)、实体状态(如:Object字段)、用户状态-实体状态(如:Account-Object字段)、用户状态-积分状态(如:Account-Asset字段)、用户状态-消息状态(如:Account-Message字段)、用户状态-用户操作状态(如:Account-Action)中任意一种状态状态都可以采用MPT状态树或默克尔树来实现,各种MPT状态树的树根存储在区块头中。如图2所示,区块存储的用户操作(如:Action字段),和链上数据库存储的收据状态(如:Receipt字段)的MPT状态树的树根也存储在区块头中。
上述中,采用MPT状态树的方式存储这些状态,用户可以通过地址信息进行查询;针对用户状态、积分状态和实体状态,直接采用用户地址、积分地址以及实体地址信进行状态查询;针对用户状态-实体状态、用户状态-用户操作状态、用户状态-积分状态以及用户状态-消息状态,采用用户地址进行状态查询。
此外,用户地址可以根据用户公钥进行多次哈希运算得到;积分地址或实体地址,可以由创建积分或实体的用户操作来得到,例如:对该用户操作进行多次哈希运算,从得到的哈希值中选取预设位数的字符作为积分地址或实体地址。
本申请中业务数据区块链上设置用户数字账户,业务数据上链之后,用户能够通过数字账户来管理区块链上的数字资产,提升用户的业务数据区块链***使用体验;数字账户中的各种状态数据采用支持属性查询的数据库,也方便用户进行访问,提升查询效率。
此外,本说明书公开了业务数据区块链的数字账户实现装置,业务数据区块链***包括多个区块链节点,所述装置为区块链节点。
区块链节点通过树形结构的方式,存储用户操作后的状态。
所述树形结构包括状态树和关系树,所述状态树存储用户操作后的状态,所述关系树存储用户操作后状态之间的关联关系。
在一个示例中,所述状态树中叶子节点的value存储积分状态、实体状态、用户状态以及消息状态中的一种或多种。
在一个示例中,所述关系树中叶子节点存储关系子树的树根,所述关系子树叶子节点的value存储用户状态-用户操作状态、用户状态-积分状态、用户状态-实体状态以及用户状态-消息状态中一种或多种;或
所述关系树中叶子节点的value以数组或哈希表的方式存储用户状态-用户操作状态、用户状态-积分状态、用户状态-实体状态以及用户状态-消息状态中一种或多种。
在一个示例中,所述用户状态、所述实体状态、所述积分状态、用户状态-用户操作状态、用户状态-积分状态、用户状态-实体状态以及用户状态-消息状态中任意一种信息以数据表的形式存储在支持属性查询的数据库中,以便于用户根据所述数据表中的属性字段进行查询;其中,一种信息对应一种数据表,任意一种数据表中的任意一行对应一条状态信息,一种信息包括多行状态信息;所述支持属性查询的数据库包括关系数据库和内存数据库;或
所述用户状态、所述实体状态、所述积分状态、用户状态-用户操作状态、用户状态-积分状态、用户状态-实体状态以及用户状态-消息状态中的任意一种信息采用KV数据库存储,以键值对的方式进行存储。
在一个示例中,所述用户操作数据为用户在互联网上的操作数据,所述用户操作数据包括存证数据、溯源数据、金融数据、旅游数据、搜索数据、自媒体数据、调研数据、广告数据、电商数据、社区数据、知识问答数据、知识付费数据、共享单车数据、招聘数据、生活服务数据、租房数据、投票数据、线上到线下数据、社交数据、点赞数据、评价数据以及网约车数据中的一种或多种。
在一个示例中,所述用户操作数据包括时间戳、操作用户地址、***作地址、操作类型、操作的值、积分地址、用户对用户操作数据的签名以及用户操作数据的哈希值中的一种或多种;其中,所述操作类型包括用户对实体的操作和对积分的操作,所述***作地址包括对实体的操作地址和其他操作用户的地址。
在一个示例中,用户操作数据的属性包括关联属性和非关联属性;其中,该关联属性的属性值根据用户操作后的数据状态自动增减。
上述装置实施例中与上述方法实施例中相同或相近之处可相互参见,在此不再赘述。
本申请中业务数据区块链上设置用户数字账户,业务数据上链之后,用户能够通过数字账户来管理区块链上的数字资产,提升用户的业务数据区块链***使用体验;数字账户中的各种状态数据采用支持属性查询的数据库,也方便用户进行访问,提升查询效率。
本说明书还公开了一种计算机可读存储介质,该存储介质存储有计算机指令,该计算机指令被处理器执行时,实现如上所述任意一项技术方案。
本说明书还公开了一种电子设备,该电子设备包括处理器,所述处理器用于执行如上所述任意一项技术方案。
与此同时,本申请还提供一种实体装置的实施例。
图3示出了一种计算机设备结构示意图,该计算机设备可以包括:处理器310、存储器320、输入/输出接口330、通信接口340和总线350。其中处理器340、存储器320、输入/输出接口330和通信接口340通过总线350实现彼此之间在设备内部的通信连接。
处理器310可以采用通用的CPU(Central Processing Unit,中央处理器)、微处理器、应用专用集成电路(Application Specific Integrated Circuit,ASIC)、或者一个或多个集成电路等方式实现,用于执行相关程序,以实现本说明书实施例所提供的技术方案。
存储器320可以采用ROM(Read Only Memory,只读存储器)、RAM(Random AccessMemory,随机存取存储器)、静态存储设备,动态存储设备等形式实现。存储器320可以存储操作***和其他应用程序,在通过软件或者固件来实现本说明书实施例所提供的技术方案时,相关的程序代码保存在存储器320中,并由处理器310来调用执行。
输入/输出接口330用于连接输入/输出模块,以实现信息输入及输出。输入输出/模块可以作为组件配置在设备中(图中未示出),也可以外接于设备以提供相应功能。其中输入设备可以包括键盘、鼠标、触摸屏、麦克风、各类传感器等,输出设备可以包括显示器、扬声器、振动器、指示灯等。
通信接口340用于连接通信模块(图中未示出),以实现本设备与其他设备的通信交互。其中通信模块可以通过有线方式(例如USB、网线等)实现通信,也可以通过无线方式(例如移动网络、WIFI、蓝牙等)实现通信。
总线350包括一通路,在设备的各个组件(例如处理器310、存储器320、输入/输出接口330和通信接口340)之间传输信息。
需要说明的是,尽管上述设备仅示出了处理器310、存储器320、输入/输出接口330、通信接口340以及总线350,但是在具体实施过程中,该设备还可以包括实现正常运行所必需的其他组件。此外,本领域的技术人员可以理解的是,上述设备中也可以仅包含实现本说明书实施例方案所必需的组件,而不必包含图中所示的全部组件。
专业人员应该还可以进一步意识到,结合本文中所公开的实施例描述的各示例的单元及算法步骤,能够以电子硬件、计算机软件或者二者的结合来实现,为了清楚地说明硬件和软件的可互换性,在上述说明中已经按照功能一般性地描述了各示例的组成及步骤。这些功能究竟以硬件还是软件方式来执行,取决于技术方案的特定应用和设计约束条件。专业技术人员可以对每个特定的应用来使用不同方法来实现所描述的功能,但是这种实现不应认为超出本发明的范围。
结合本文中所公开的实施例描述的方法或算法的步骤可以用硬件、处理器执行的软件模块,或者二者的结合来实施。软件模块可以置于随机存储器(RAM)、内存、只读存储器(ROM)、电可编程ROM、电可擦除可编程ROM、寄存器、硬盘、可移动磁盘、CD-ROM、或技术领域内所公知的任意其它形式的存储介质中。
以上所述的具体实施方式,对本发明的目的、技术方案和有益效果进行了进一步详细说明,所应理解的是,以上所述仅为本发明的具体实施方式而已,并不用于限定本发明的保护范围,凡在本发明的范围之内,所做的任何修改、等同替换、改进等,均应包含在本发明的保护范围之内。
Claims (10)
1.业务数据区块链的数字账户实现方法,其特征在于,所述方法包括:
区块链节点通过树形结构的方式,存储用户操作后的状态;
所述树形结构包括状态树和关系树,所述状态树存储用户操作后的状态,所述关系树存储用户操作后状态之间的关联关系。
2.根据权利要求1的数字账户实现方法,其特征在于,所述状态树中叶子节点的value存储积分状态、实体状态、用户状态以及消息状态中的一种或多种。
3.根据权利要求1或2的数字账户实现方法,其特征在于,所述关系树中叶子节点存储关系子树的树根,所述关系子树叶子节点的value存储用户状态-用户操作状态、用户状态-积分状态、用户状态-实体状态以及用户状态-消息状态中一种或多种;或
所述关系树中叶子节点的value以数组或哈希表的方式存储用户状态-用户操作状态、用户状态-积分状态、用户状态-实体状态以及用户状态-消息状态中一种或多种。
4.根据权利要求3的数字账户实现方法,其特征在于,所述用户状态、所述实体状态、所述积分状态、用户状态-用户操作状态、用户状态-积分状态、用户状态-实体状态以及用户状态-消息状态中任意一种信息以数据表的形式存储在支持属性查询的数据库中,以便于用户根据所述数据表中的属性字段进行查询;其中,一种信息对应一种数据表,任意一种数据表中的任意一行对应一条状态信息,一种信息包括多行状态信息;所述支持属性查询的数据库包括关系数据库和内存数据库;或
所述用户状态、所述实体状态、所述积分状态、用户状态-用户操作状态、用户状态-积分状态、用户状态-实体状态以及用户状态-消息状态中的任意一种信息采用KV数据库存储,以键值对的方式进行存储。
5.根据权利要求3的数字账户实现方法,其特征在于,所述用户状态-所述消息状态的关系树中,所述消息状态包括广告消息和商品优惠卷中的一种或两种;其中,
所述广告消息响应于用户的点击操作,所述用户状态-所述积分状态的关系树存储所述广告消息对应的积分状态;
所述商品优惠卷响应于用户的领取操作,所述用户状态-所述实体状态的关系树存储所述商品优惠卷对应的实体状态。
6.根据权利要求1的数字账户实现方法,其特征在于,所述关系树和所述状态树采用默克尔树或MPT树,所述MPT树是融合了前缀树的树形结构的默克尔树变种,所述默克尔树为MerklePatriciaTree树。
7.业务数据区块链的数字账户实现装置,其特征在于,所述装置为区块链节点;其中,
区块链节点通过树形结构的方式,存储用户操作后的状态;所述树形结构包括状态树和关系树,所述状态树存储用户操作后的状态,所述关系树存储用户操作后状态之间的关联关系。
8.根据权利要求7的数字账户实现装置,其特征在于,所述状态树中叶子节点的value存储积分状态、实体状态、用户状态以及消息状态中的一种或多种。
9.根据权利要求7或8的数字账户实现装置,其特征在于,所述关系树中叶子节点存储关系子树的树根,所述关系子树叶子节点的value存储用户状态-用户操作状态、用户状态-积分状态、用户状态-实体状态以及用户状态-消息状态中一种或多种;或
所述关系树中叶子节点的value以数组或哈希表的方式存储用户状态-用户操作状态、用户状态-积分状态、用户状态-实体状态以及用户状态-消息状态中一种或多种。
10.根据权利要求9的数字账户实现装置,其特征在于,所述用户状态、所述实体状态、所述积分状态、用户状态-用户操作状态、用户状态-积分状态、用户状态-实体状态以及用户状态-消息状态中任意一种信息以数据表的形式存储在支持属性查询的数据库中,以便于用户根据所述数据表中的属性字段进行查询;其中,一种信息对应一种数据表,任意一种数据表中的任意一行对应一条状态信息,一种信息包括多行状态信息;所述支持属性查询的数据库包括关系数据库和内存数据库;或
所述用户状态、所述实体状态、所述积分状态、用户状态-用户操作状态、用户状态-积分状态、用户状态-实体状态以及用户状态-消息状态中的任意一种信息采用KV数据库存储,以键值对的方式进行存储。
Priority Applications (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN202010271070.6A CN111488357A (zh) | 2020-04-08 | 2020-04-08 | 业务数据区块链的数字账户实现方法及装置 |
Applications Claiming Priority (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN202010271070.6A CN111488357A (zh) | 2020-04-08 | 2020-04-08 | 业务数据区块链的数字账户实现方法及装置 |
Publications (1)
Publication Number | Publication Date |
---|---|
CN111488357A true CN111488357A (zh) | 2020-08-04 |
Family
ID=71794745
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
CN202010271070.6A Withdrawn CN111488357A (zh) | 2020-04-08 | 2020-04-08 | 业务数据区块链的数字账户实现方法及装置 |
Country Status (1)
Country | Link |
---|---|
CN (1) | CN111488357A (zh) |
Citations (4)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN110175844A (zh) * | 2019-05-07 | 2019-08-27 | 深圳前海微众银行股份有限公司 | 一种区块链中智能合约的发布方法及装置 |
CN110324363A (zh) * | 2019-08-07 | 2019-10-11 | 北京艾摩瑞策科技有限公司 | 互联网电商关联数据的上链方法及其装置 |
CN110493325A (zh) * | 2019-07-31 | 2019-11-22 | 阿里巴巴集团控股有限公司 | 区块链状态数据同步方法及装置、电子设备 |
CN110688377A (zh) * | 2019-08-30 | 2020-01-14 | 阿里巴巴集团控股有限公司 | 一种更新状态默克树的方法及装置 |
-
2020
- 2020-04-08 CN CN202010271070.6A patent/CN111488357A/zh not_active Withdrawn
Patent Citations (4)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN110175844A (zh) * | 2019-05-07 | 2019-08-27 | 深圳前海微众银行股份有限公司 | 一种区块链中智能合约的发布方法及装置 |
CN110493325A (zh) * | 2019-07-31 | 2019-11-22 | 阿里巴巴集团控股有限公司 | 区块链状态数据同步方法及装置、电子设备 |
CN110324363A (zh) * | 2019-08-07 | 2019-10-11 | 北京艾摩瑞策科技有限公司 | 互联网电商关联数据的上链方法及其装置 |
CN110688377A (zh) * | 2019-08-30 | 2020-01-14 | 阿里巴巴集团控股有限公司 | 一种更新状态默克树的方法及装置 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
Nuseir | Potential impacts of blockchain technology on business practices of bricks and mortar (B&M) grocery stores | |
US20220245626A1 (en) | Computer-implemented system and method for generating and extracting user related data stored on a blockchain | |
CN102360480B (zh) | 一种链接网上支付及记录链接的方法和*** | |
CN111488616A (zh) | 业务数据区块链的预言机实现方法及装置 | |
CN111488615A (zh) | 业务数据区块链的跨链实现方法及装置 | |
CN111488608A (zh) | 业务数据区块链的数据验证方法及装置 | |
Chukleang et al. | Security enhancement in smart logistics with blockchain technology: A home delivery use case | |
CN111488353B (zh) | 业务数据区块链的智能合约实现方法及装置 | |
CN111488356A (zh) | 业务数据区块链的数据存储方法及其装置 | |
CN111488349A (zh) | 基于业务数据区块链的数据查询方法及装置 | |
CN111488344A (zh) | 基于业务数据区块链的用户操作数据上链方法及*** | |
Gómez et al. | Blockverse: A cloud blockchain-based platform for tracking in affiliate systems | |
CN111488613A (zh) | 业务数据区块链的数据高效查询方法及装置 | |
CN111488345A (zh) | 业务数据区块链的存储优化方法及装置 | |
CN111737729A (zh) | 基于业务数据区块链的评价数据存储方法及*** | |
CN111488357A (zh) | 业务数据区块链的数字账户实现方法及装置 | |
CN111488611B (zh) | 业务数据区块链的关系数据存储方法及装置 | |
CN111695132A (zh) | 基于业务数据区块链的投票数据存储方法及*** | |
CN111488343A (zh) | 基于业务数据区块链的电商数据上链方法及装置 | |
JP7253344B2 (ja) | 情報処理装置、情報処理方法およびプログラム | |
CN111488352A (zh) | 基于业务数据区块链的积分兑换方法及装置 | |
KR102169311B1 (ko) | 블록 체인 기반 스마트 컨트랙트를 이용한 구독서비스 방법 | |
CN111523137A (zh) | 基于业务数据区块链的数据推荐方法及装置 | |
CN111488355A (zh) | 业务数据区块链的用户关系存储方法及装置 | |
CN111488354A (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 | ||
WW01 | Invention patent application withdrawn after publication | ||
WW01 | Invention patent application withdrawn after publication |
Application publication date: 20200804 |