CN110096551A - 基于区块链的信用数据存储方法、装置、设备及介质 - Google Patents
基于区块链的信用数据存储方法、装置、设备及介质 Download PDFInfo
- Publication number
- CN110096551A CN110096551A CN201910330402.0A CN201910330402A CN110096551A CN 110096551 A CN110096551 A CN 110096551A CN 201910330402 A CN201910330402 A CN 201910330402A CN 110096551 A CN110096551 A CN 110096551A
- Authority
- CN
- China
- Prior art keywords
- data
- chain
- credit
- alliance
- node
- 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.)
- Pending
Links
Classifications
-
- 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
-
- 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/27—Replication, distribution or synchronisation of data between databases or within a distributed database system; Distributed database system architectures therefor
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F16/00—Information retrieval; Database structures therefor; File system structures therefor
- G06F16/90—Details of database functions independent of the retrieved data types
- G06F16/903—Querying
- G06F16/90335—Query processing
- G06F16/90344—Query processing by using string matching techniques
-
- 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
- H04L67/104—Peer-to-peer [P2P] networks
-
- 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/06—Cryptographic mechanisms or cryptographic arrangements for secret or secure communications; Network security protocols the encryption apparatus using shift registers or memories for block-wise or stream coding, e.g. DES systems or RC4; Hash functions; Pseudorandom sequence generators
- H04L9/0643—Hash functions, e.g. MD5, SHA, HMAC or f9 MAC
Landscapes
- Engineering & Computer Science (AREA)
- Theoretical Computer Science (AREA)
- Databases & Information Systems (AREA)
- Physics & Mathematics (AREA)
- Data Mining & Analysis (AREA)
- General Engineering & Computer Science (AREA)
- General Physics & Mathematics (AREA)
- Signal Processing (AREA)
- Computer Networks & Wireless Communication (AREA)
- Computing Systems (AREA)
- Power Engineering (AREA)
- Computer Security & Cryptography (AREA)
- Computational Linguistics (AREA)
- Software Systems (AREA)
- Financial Or Insurance-Related Operations Such As Payment And Settlement (AREA)
Abstract
本发明涉及计算机软件的技术领域,尤其是涉及一种基于区块链的信用数据存储方法、装置、设备及介质,基于区块链的信用数据存储方法包括:S10:获取联盟链上各节点的信用数据;S20:获取数据上链模版,根据所述数据上链模版从所述信用数据中提取信用元数据;S30:使用散列算法对所述信用元数据进行计算,得到对应的数据指纹;S40:计算当前时间戳,将所述当前时间戳与所述数据指纹作为信用区块,存储至所述联盟链上。本发明具有提升征信系统数据的丰富度的效果。
Description
技术领域
本发明涉及计算机软件的技术领域,尤其是涉及一种基于区块链的信用数据存储方法、装置、设备及介质。
背景技术
目前,企业和个人征信系统,即金融信用信息基础数据库,又称企业和个人信用信息基础数据库。形成的以企业和个人信用报告为核心的征信产品体系,征信中心出具的信用报告已经成为国内企业和个人的“经济身份证”。
现有的征信系统中,仍面临以下缺陷:
1. 信息孤岛问题严重,数据缺乏共享,征信机构与机构之间没有有效共享合作,无法实现高质量数据发挥应用作用;相关机构不想共享自己数据,却需要获取第三方数据;
2. 数据源争夺耗费大量成本,传统征信机构通过自爬、合作、购买等方式,主动对接相关的部门与机构,从有限的场景中整合数据,抢占数据高地;
3. 用户数据归属权不明晰,及出于用户隐私安全的考虑,数据难以流通起来,发挥出它的最大价值;
4. 数据隐私保护也面临重要问题,传统征信系统架构对用户关注度低,无法从技术底层保证用户的数据主权;
5. 数据太少,质量太差,和信用相关度太低,难以准确判断用户信用;
6. 除了个人信贷,企业信贷更是一个严重的问题,企业的信誉问题比个人更加难以评估,企业的征信信息缺失的更为严重。
发明内容
本发明的目的是提供一种提升征信系统数据的丰富度的基于区块链的信用数据存储方法、装置、设备及介质。
本发明的上述发明目的一是通过以下技术方案得以实现的:
一种基于区块链的信用数据存储方法,所述基于区块链的信用数据存储方法包括:
S10:获取联盟链上各节点的信用数据;
S20:获取数据上链模版,根据所述数据上链模版从所述信用数据中提取信用元数据;
S30:使用散列算法对所述信用元数据进行计算,得到对应的数据指纹;
S40:计算当前时间戳,将所述当前时间戳与所述数据指纹作为信用区块,存储至所述联盟链上。
通过采用上述技术方案,通过在联盟链上获取各个节点的信用数据,并将该信用数据存储在基于区块链搭建的联盟链上,能够利用区块链的去中心化的特性,在数据共享时,无需第三方权威机构介入,提高了数据的利用率,同时也增加了征信系统中,数据的丰富程度;同时,通过数据上链模板,从信用数据中提取信用元数据,将信用元数据通过散列算法计算得到固定长度的数据指纹,一是通过将信用数据的原始数据存储至联盟链的每一节点,将该数据指纹存储至联盟链中,能够减轻联盟链的存储空间,二是利用了散列算法的不可逆性,将对应的信用数据采用散列算法进行计算后,能够保证了信用数据不会被篡改,提升了数据真实性。
本发明进一步设置为:在步骤S10之前,所述基于区块链的信用数据存储方法还包括:
S11:若获取到由节点触发的联盟链创建消息,则根据所述联盟链创建消息,搭建所述联盟链,并将触发所述联盟链创建消息的节点作为主节点;
S12:若获取到新节点加入请求,则在所述联盟链中选取其中一个节点,并通过被选取的节点向所述联盟链中发送新节点入网申请消息;
S13:所述联盟链中的节点通过所述智能合约对所述新节点入网申请消息进行投票,若所述投票的票数通过,则将根据所述新节点加入请求中的新节点通过网络连接加入所述联盟链,并将所述联盟链上的数据发送至所述新节点。
通过采用上述技术方案,通过搭建联盟链的方式,基于同一业务建立一个联盟链,即每一节点能够根据自身的业务情况,同时部署多个联盟链,使每一联盟链上的节点的数据相互独立,保证了数据的安全性;同时,在有新的节点加入该联盟链时,通过已在联盟链中投票的方式,判断该新的节点是否有权限加入该联盟链,只有在超过半数的节点允许的情况下,新的节点才能够加入该联盟链,能够保证该联盟链的安全。
本发明进一步设置为:步骤S20包括:
S21:从所述数据上链模版中获取模板字符串;
S22:根据所述模板字符串在所述信用数据中进行匹配查询,将匹配查询到的结果作为所述信用元数据。
通过采用上述技术方案,在数据上链模板中获取模板字符串,能够便于在信用数据中获取信用元数据,提升了获取数据的效率,且提取的信用元数据可作为该信用数据的唯一标识,将该信用元数据存储至联盟链,能够减轻联盟链的存储空间,保障联盟链上能存储大量数据,从而使该联盟链能够存储更多的信用数据,进一步保证了联盟链上的数据的丰富程度。
本发明进一步设置为:步骤S30包括:
S31:在所述信用元数据中获取用户唯一标识,使用散列算法对所述用户唯一标识进行计算,得到链上索引;
S32:对所述信用元数据进行计算,将计算结果与所述链上索引作为所述数据指纹。
通过采用上述技术方案,将信用元数据经过散列算法进行计算,得到链上索引,能够便于在查看信用元数据时,通过该索引调用对应的信用数据。
本发明进一步设置为:在步骤S40之后,所述基于区块链的信用存储方法还包括:
S50:若获取到数据查看消息,则获取触发所述数据查看消息的用户标识信息;
S60:将所述用户标识信息在所述联盟链上进行比对查询;
S70:若在所述联盟链上查询到所述用户标识信息,则根据所述数据查看消息和所述用户标识信息发送对应的数据信息;
S80:若在所述联盟链上查询不到所述用户标识信息,则根据所述用户标识信息发送数据查看申请消息,在所述用户标识响应所述数据查看申请后,根据所述数据查看消息和所述用户标识信息发送对应的数据信息。
通过采用上述技术方案,通过对触发数据查看消息的用户标识在该联盟链中匹配查询,对查询到的用户标识信息发送对应的数据信息,若通过匹配查询后,查询不到该用户标识信息,则向用户标识发送数据查看申请消息,在响应该数据查看申请消息后,向该用户标识发送对应的数据信息,能够保证数据不被随意查看,从而保证了数据的安全性。
本发明的上述发明目的二是通过以下技术方案得以实现的:
一种基于区块链的信用数据存储装置,所述基于区块链的信用数据存储装置包括:
数据获取模块,用于获取联盟链上各节点的信用数据;
数据提取模块,用于获取数据上链模版,根据所述数据上链模版从所述信用数据中提取信用元数据;
计算模块,用于使用散列算法对所述信用元数据进行计算,得到对应的数据指纹;
存储模块,用于计算当前时间戳,将所述当前时间戳与所述数据指纹作为信用区块,存储至所述联盟链上。
通过采用上述技术方案,通过在联盟链上获取各个节点的信用数据,并将该信用数据存储在基于区块链搭建的联盟链上,能够利用区块链的去中心化的特性,在数据共享时,无需第三方权威机构介入,提高了数据的利用率,同时也增加了征信系统中,数据的丰富程度;同时,通过数据上链模板,从信用数据中提取信用元数据,将信用元数据通过散列算法计算得到固定长度的数据指纹,一是通过将信用数据的原始数据存储至联盟链的每一节点,将该数据指纹存储至联盟链中,能够减轻联盟链的存储空间,二是利用了散列算法的不可逆性,将对应的信用数据采用散列算法进行计算后,能够保证了信用数据不会被篡改,提升了数据真实性。
本发明的上述发明目的三是通过以下技术方案得以实现的:
一种计算机设备,包括存储器、处理器以及存储在所述存储器中并可在所述处理器上运行的计算机程序,所述处理器执行所述计算机程序时实现上述基于区块链的信用数据存储方法的步骤。
本发明的上述发明目的四是通过以下技术方案得以实现的:
一种计算机可读存储介质,所述计算机可读存储介质存储有计算机程序,所述计算机程序被处理器执行时实现上述基于区块链的信用数据存储方法的步骤。
综上所述,本发明的有益技术效果为:
1.通过在联盟链上获取各个节点的信用数据,并将该信用数据存储在基于区块链搭建的联盟链上,能够利用区块链的去中心化的特性,在数据共享时,无需第三方权威机构介入,提高了数据的利用率,同时也增加了征信系统中,数据的丰富程度;
2.通过数据上链模板,从信用数据中提取信用元数据,将信用元数据通过散列算法计算得到固定长度的数据指纹,一是通过将信用数据的原始数据存储至联盟链的每一节点,将该数据指纹存储至联盟链中,能够减轻联盟链的存储空间,二是利用了散列算法的不可逆性,将对应的信用数据采用散列算法进行计算后,能够保证了信用数据不会被篡改,提升了数据真实性。
附图说明
图1是本发明一实施例中基于区块链的信用数据存储方法的一流程图;
图2是本发明一实施例中基于区块链的信用数据存储方法中的另一实现流程图;
图3是本发明一实施例中基于区块链的信用数据存储方法中步骤S20的实现流程图;
图4是本发明一实施例中基于区块链的信用数据存储方法中步骤S30的实现流程图;
图5是本发明一实施例中基于区块链的信用数据存储方法中的另一实现流程图;
图6是本发明一实施例中基于区块链的信用数据存储方法中查询信息时的数据交互示意图;
图7是本发明一实施例中基于区块链的信用数据存储装置的一原理框图;
图8是本发明一实施例中计算机设备的一示意图。
具体实施方式
以下结合附图对本发明作进一步详细说明。
实施例一:
在一实施例中,如图1所示,本发明公开了一种基于区块链的信用数据存储方法,具体包括如下步骤:
S10:获取联盟链上各节点的信用数据。
在本实施例中,联盟链是指由该联盟链发起者创建,搭建的用于提供数据进行共享的数据存储平台。信用数据是指在不同网贷、电商或其他机构中的征信评分不符合相关的规定,被列为信用的用户的数据。
在本实施例中,可以通过联盟链上每一节点中,存储有该信用数据的数据库中,例如MySQL数据库,在该数据库中,获取每一节点的信用数据。
S20:获取数据上链模版,根据数据上链模版从信用数据中提取信用元数据。
在本实施例中,数据上链模板是指从存储有信用数据的数据库中筛选数据的模板。通过该数据上链模板提取的数据用于存储至联盟链上。信用元数据是指描述信用数据的属性的信息,用来支持如指示信用数据的存储位置、历史数据、资源查找或文件记录等功能。
具体地,预先确定并设置好需要从信用数据中提取的数据内容,作为该数据上链模板,进一步地,根据该数据上链模板,从该信用数据中,提取对应的数据,作为信用元数据。
S30:使用散列算法对信用元数据进行计算,得到对应的数据指纹。
在本实施例中,数据指纹是指用于区分每一信用元数据的字符串。
具体地,采用同一个散列算法分别对每一信用元数据进行计算,将得到的结果作为数据指纹,且数据指纹与信用元数据唯一对应。
S40:计算当前时间戳,将当前时间戳与数据指纹作为信用区块,存储至联盟链上。
在本实施例中,时间戳是指格林威治时间1970年01月01日00时00分00秒(北京时间1970年01月01日08时00分00秒)起至现在的总秒数,是一个能表示一份数据在某个特定时间之前已经存在的、 完整的、 可验证的数据,通常是一个字符序列,唯一地标识某一刻的时间。当前时间戳是指将该数据指纹存储至联盟链时具体地时间的时间戳。
具体地,根据当前时间,获取当前时间戳的方式可以根据开发平台,采用对应的语句获取,例如,在MySQL环境中,采用语句SELECT unix_timestamp(now()),计算当前时间戳,例如,当前时间为2019-03-31-19:46:10,计算得到的当前时间戳为1554032770。信用区块是指在联盟链的区块链中,记录有信用元数据的区块。
进一步地,在得到该当前时间戳后,采用区块链技术,将用户的姓名和身份证号通过散列算法,得到对应的哈希值后,采用隐私合约链对数据进行加密后,得到对应的信用区块后,将该信用区块和对应的当前时间戳存储在联盟链中。
在本实施例中,通过在联盟链上获取各个节点的信用数据,并将该信用数据存储在基于区块链搭建的联盟链上,能够利用区块链的去中心化的特性,在数据共享时,无需第三方权威机构介入,提高了数据的利用率,同时也增加了征信系统中,数据的丰富程度;同时,通过数据上链模板,从信用数据中提取信用元数据,将信用元数据通过散列算法计算得到固定长度的数据指纹,一是通过将信用数据的原始数据存储至联盟链的每一节点,将该数据指纹存储至联盟链中,能够减轻联盟链的存储空间,二是利用了散列算法的不可逆性,将对应的信用数据采用散列算法进行计算后,,能够保证了信用数据不会被篡改,提升了数据真实性。
在一实施例中,如图2所示,在步骤S10之前,基于区块链的信用数据存储方法还包括如下步骤:
S11:若获取到由节点触发的联盟链创建消息,则根据联盟链创建消息,搭建联盟链,并将触发联盟链创建消息的节点作为主节点。
在本实施例中,联盟链创建消息是指有一企业或信贷机构作为主节点,基于某一业务场景,例如借贷场景,创建的联盟链。
具体地,在有节点,即企业或信贷机构希望基于某一业务场景构建联盟链时,则触发该联盟链创建消息。在服务端获取到该联盟链创建消息时,通过现有的搭建联盟链的方式,创建该联盟链,并将触发联盟链创建消息的节点作为主节点
S12:若获取到新节点加入请求,则在联盟链中选取其中一个节点,并通过被选取的节点向联盟链中发送新节点入网申请消息。
在本实施例中,新节点加入请求是指由新的企业或信贷机构触发的,请求加入一联盟链的消息。新节点入网申请是指触发该新节点加入请求的新节点申请加入联盟链的消息。
具体地,在有企业或信贷机构发送该新节点加入请求,请求加入该主节点创建的联盟链,则通过在联盟链上的其中一个节点,将该被节点,向该联盟链上发送该新节点入网申请消息。
S13:联盟链中的节点通过智能合约对新节点入网申请消息进行投票,若投票的票数通过,则将根据新节点加入请求中的新节点通过网络连接加入联盟链,并将联盟链上的数据发送至新节点。
具体地,对该新节点入网申请消息进行投票的方式,联盟链中其他成员通过智能合约对新节点入网申请消息进行投票,得票数符合约定后,新节点信息被记入成员列表。
进一步地,新节点通过网络连接当前联盟链成员节点,成员节点p2p通信模块读取智能合约成员列表信息,检查新成员节点enode url在成员列表中, 建立连接,新成员节点开始下载区块数据。
在一实施例中,如图3所示,在步骤S20中,即获取数据上链模版,根据数据上链模版从信用数据中提取信用元数据,具体包括如下步骤:
S21:从数据上链模版中获取模板字符串。
在本实施例中,模板字符串是指在数据上链模板中,用于标识获取的数据类型的字符串。
具体地,根据该数据上链模板中设置好的要获取的数据类型,将该数据类型作为该模版字符串。
S22:根据模板字符串在信用数据中进行匹配查询,将匹配查询到的结果作为信用元数据。
具体地,该模板字符串可以包括节点标识、业务类型和源数据连接等,将该模板字符串作为匹配字符串,在每一份信用数据中进行匹配查询,将查询的结果对应的数据作为该份信用数据对应的信用源数据。
在一实施例中,如图4所示,在步骤S30中,即使用散列算法对信用元数据进行计算,得到对应的数据指纹,具体包括如下步骤:
S31:在信用元数据中获取用户唯一标识,使用散列算法对用户唯一标识进行计算,得到链上索引。
在本实施例中,用户唯一标识是指用于区分每一信用数据对应的用户的标识。该用户唯一标识包括但不限于用户的姓名和身份证的组合。链上索引是指在联盟链中一列或多列的值进行排序的一种结构,使用链上索引可快速访问联盟链中的信用数据的信息。
具体地,采用固定的散列算法,对用户唯一标识进行计算,得到链上索引,保障了链上数据当匿名性,当机构查询该用户当数据时,需要知道用户姓名和身份证号,才能与链上数据进行匹配。
S32:对信用元数据进行计算,将计算结果与链上索引作为数据指纹。
具体地,对信用元数据进行计算,将计算结果与链上索引作为数据指纹,由于计算的方式为固定的散列算法,当链下的信用数据被修改之后,重新生成的数据指纹和链上的数据指纹不匹配,保障了链下数据不被篡改的可能性。
在一实施例中,如图5所示,在步骤步骤S40之后,基于区块链的信用数据存储方法还包括如下步骤:
S50:若获取到数据查看消息,则获取触发数据查看消息的用户标识信息。
在本实施例中,数据查看消息是指由某一用户或者机构触发,请求查看该联盟链上的数据的消息。
具体地,在该联盟链对应的客户端获取到该数据查看消息时,从客户端中获取用户标识信息。
S60:将用户标识信息在联盟链上进行比对查询。
具体地,将该用户标识信息在联盟链中,存储有已注册的用户的信息的数据库中进行比对查询,用于校验该用户标识信息是否存在该存储有已注册的用户的信息的数据库中。
S70:若在联盟链上查询到用户标识信息,则根据数据查看消息和用户标识信息发送对应的数据信息。
具体地,若能够在步骤S60提及的数据库中查询到对应的用户标识信息,则可认定该用户标识信息时该联盟链上已注册的用户,则根据该数据查看消息,从联盟链上获取对应的数据区块,作为该数据信息。
进一步地,将该数据信息发送至用户标识信息的客户端中。优选地,参考图6,获取该数据信息的过程可以是按照如下步骤获取:
通过区块链预言机获取到该数据查看请求,并将该数据查看请求发送至TEE隐私合约链。TEE(Trusted Execution Environment),可信执行环境,该环境可以保证不被常规操作系统干扰的计算,因此称为”可信”;
TEE隐私合约链从该数据查看请求中提取用户标识信息和元数据,发送至区块链预言机;
区块链预言机向隐私计算服务器分配查询任务,在隐私计算服务器响应该查询任务后,向区块链预言机发送数据采集请求;
区块链预言机在获取到该数据采集请求后,将该数据采集请求发送至联盟链中每一成员的应用端;
联盟链中每一成员的应用端在获取到数据采集请求后,向TEE隐私合约链验证请求;
若TEE隐私合约链响应该验证请求后,联盟链中每一成员的应用端根据数据查看请求中需要查看的数据,向业务服务器发送请求原始数据报告,在该业务服务器响应该请求原始数据报告后,向联盟链中每一成员的应用端发送该原始数据报告;
联盟链中每一成员的应用端通过TEE公钥对原始数据报告进行加密后,通过区块链预言机将该加密后的原始数据报告发送至隐私计算服务器;
隐私计算服务器通过TEE私钥对加密后的原始数据报告进行解密,并将该数据查看请求和原始数据报告按照预设的格式进行处理后,得到报告指纹,并将该报告指纹通过区块链预言机发送至TEE隐私合约链进行存储;
隐私计算服务器通过区块链预言机获取到TEE隐私合约链的响应消息后,使用该用户标识的公钥对该原始数据报告进行加密,并将该使用用户标识的公钥进行加密的原始数据报告通过区块链预言机发送至客户端,并通过用户标识的私钥对原始数据报告进行解密,使用户获取到与数据查看消息对应的原始数据报告。
可理解的,联盟链的预言机,即是通过相应的网络通信协议,用于在客户端、隐私计算服务器、TEE隐私合约链以及联盟链之间接收以及发送数据的网络通信节点,即为联盟链提供了接收外部信息以及数据的平台。
S80:若在联盟链上查询不到用户标识信息,则根据用户标识信息发送数据查看申请消息,在用户标识响应数据查看申请后,根据数据查看消息和用户标识信息发送对应的数据信息。
在本实施例中,数据查看申请消息是指用于申请查看联盟链上的数据的消息。
具体地,若在步骤S60提及的数据库中查询不到该用户标识信息,则说明该用户表示信息尚未在该联盟链中注册,即该用户标识信息为在联盟链的客户端上传过信息,则向该用户标识信息所在的客户端发送数据查看申请消息。
进一步地,若该用户标识信息所在的客户端根据该数据查看申请消息进行注册、付费等步骤后,响应了数据查看申请消息后,将该数据信息发送至用户标识信息的客户端中。优选地,该用户标识信息对应的客户端通过对该数据信息进行解密,得到源数据的链接,通过该源数据的连接,获取对应的信用数据。
应理解,上述实施例中各步骤的序号的大小并不意味着执行顺序的先后,各过程的执行顺序应以其功能和内在逻辑确定,而不应对本发明实施例的实施过程构成任何限定。
实施例二:
在一实施例中,提供一种基于区块链的信用数据存储装置,该基于区块链的信用数据存储装置与上述实施例中基于区块链的信用数据存储方法一一对应。如图7所示,该基于区块链的信用数据存储装置包括数据获取模块10、数据提取模块20、计算模块30和存储模块40。各功能模块详细说明如下:
数据获取模块10,用于获取联盟链上各节点的信用数据;
数据提取模块20,用于获取数据上链模版,根据数据上链模版从信用数据中提取信用元数据;
计算模块30,用于使用散列算法对信用元数据进行计算,得到对应的数据指纹;
存储模块40,用于计算当前时间戳,将当前时间戳与数据指纹作为信用区块,存储至联盟链上。
优选地,基于区块链的信用存储装置还包括:
联盟链创建模块11,用于若获取到由节点触发的联盟链创建消息,则根据联盟链创建消息,搭建联盟链,并将触发联盟链创建消息的节点作为主节点;
申请消息发送模块12,用于若获取到新节点加入请求,则在联盟链中选取其中一个节点,并通过被选取的节点向联盟链中发送新节点入网申请消息;
投票模块13,用于联盟链中的节点通过智能合约对新节点入网申请消息进行投票,若投票的票数通过,则将根据新节点加入请求中的新节点通过网络连接加入联盟链,并将联盟链上的数据发送至新节点。
优选地,数据提取模块20包括:
字符串获取子模块21,用于从数据上链模版中获取模板字符串;
匹配查询子模块22,用于根据模板字符串在信用数据中进行匹配查询,将匹配查询到的结果作为信用元数据。
优选地,计算模块30包括:
索引计算子模块31,用于在信用元数据中获取用户唯一标识,使用散列算法对用户唯一标识进行计算,得到链上索引;
数据指纹计算子模块32,用于对信用元数据进行计算,将计算结果与链上索引作为数据指纹。
优选地,基于区块链的信用存储装置还包括:
查看消息获取子模块50,用于若获取到数据查看消息,则获取触发数据查看消息的用户标识信息;
比对查询模块60,用于将用户标识信息在联盟链上进行比对查询;
第一发送模块70,用于若在联盟链上查询到用户标识信息,则根据数据查看消息和用户标识信息发送对应的数据信息;
第二发送模块80,用于若在联盟链上查询不到用户标识信息,则根据用户标识信息发送数据查看申请消息,在用户标识响应数据查看申请后,根据数据查看消息和用户标识信息发送对应的数据信息。
关于基于区块链的信用数据存储装置的具体限定可以参见上文中对于基于区块链的信用数据存储方法的限定,在此不再赘述。上述基于区块链的信用数据存储装置中的各个模块可全部或部分通过软件、硬件及其组合来实现。上述各模块可以硬件形式内嵌于或独立于计算机设备中的处理器中,也可以以软件形式存储于计算机设备中的存储器中,以便于处理器调用执行以上各个模块对应的操作。
实施例三:
在一个实施例中,提供了一种计算机设备,该计算机设备可以是服务器,其内部结构图可以如图8所示。该计算机设备包括通过系统总线连接的处理器、存储器、网络接口和数据库。其中,该计算机设备的处理器用于提供计算和控制能力。该计算机设备的存储器包括非易失性存储介质、内存储器。该非易失性存储介质存储有操作系统、计算机程序和数据库。该内存储器为非易失性存储介质中的操作系统和计算机程序的运行提供环境。该计算机设备的数据库用于存储联盟链中每一节点的信用数据。该计算机设备的网络接口用于与外部的终端通过网络连接通信。该计算机程序被处理器执行时以实现一种基于区块链的信用数据存储方法。
在一个实施例中,提供了一种计算机设备,包括存储器、处理器及存储在存储器上并可在处理器上运行的计算机程序,处理器执行计算机程序时实现以下步骤:
S10:获取联盟链上各节点的信用数据;
S20:获取数据上链模版,根据数据上链模版从信用数据中提取信用元数据;
S30:使用散列算法对信用元数据进行计算,得到对应的数据指纹;
S40:计算当前时间戳,将当前时间戳与数据指纹作为信用区块,存储至联盟链上。
实施例四:
在一个实施例中,提供了一种计算机可读存储介质,其上存储有计算机程序,计算机程序被处理器执行时实现以下步骤:
S10:获取联盟链上各节点的信用数据;
S20:获取数据上链模版,根据数据上链模版从信用数据中提取信用元数据;
S30:使用散列算法对信用元数据进行计算,得到对应的数据指纹;
S40:计算当前时间戳,将当前时间戳与数据指纹作为信用区块,存储至联盟链上。
本领域普通技术人员可以理解实现上述实施例方法中的全部或部分流程,是可以通过计算机程序来指令相关的硬件来完成,所述的计算机程序可存储于一非易失性计算机可读取存储介质中,该计算机程序在执行时,可包括如上述各方法的实施例的流程。其中,本申请所提供的各实施例中所使用的对存储器、存储、数据库或其它介质的任何引用,均可包括非易失性和/或易失性存储器。非易失性存储器可包括只读存储器(ROM)、可编程ROM(PROM)、电可编程ROM(EPROM)、电可擦除可编程ROM(EEPROM)或闪存。易失性存储器可包括随机存取存储器(RAM)或者外部高速缓冲存储器。作为说明而非局限,RAM以多种形式可得,诸如静态RAM(SRAM)、动态RAM(DRAM)、同步DRAM(SDRAM)、双数据率SDRAM(DDRSDRAM)、增强型SDRAM(ESDRAM)、同步链路(Synchlink) DRAM(SLDRAM)、存储器总线(Rambus)直接RAM(RDRAM)、直接存储器总线动态RAM(DRDRAM)、以及存储器总线动态RAM(RDRAM)等。
所属领域的技术人员可以清楚地了解到,为了描述的方便和简洁,仅以上述各功能单元、模块的划分进行举例说明,实际应用中,可以根据需要而将上述功能分配由不同的功能单元、模块完成,即将所述装置的内部结构划分成不同的功能单元或模块,以完成以上描述的全部或者部分功能。
以上所述实施例仅用以说明本发明的技术方案,而非对其限制;尽管参照前述实施例对本发明进行了详细的说明,本领域的普通技术人员应当理解:其依然可以对前述各实施例所记载的技术方案进行修改,或者对其中部分技术特征进行等同替换;而这些修改或者替换,并不使相应技术方案的本质脱离本发明各实施例技术方案的精神和范围,均应包含在本发明的保护范围之内。
Claims (10)
1.一种基于区块链的信用数据存储方法,其特征在于,所述基于区块链的信用数据存储方法包括:
S10:获取联盟链上各节点的信用数据;
S20:获取数据上链模版,根据所述数据上链模版从所述信用数据中提取信用元数据;
S30:使用散列算法对所述信用元数据进行计算,得到对应的数据指纹;
S40:计算当前时间戳,将所述当前时间戳与所述数据指纹作为信用区块,存储至所述联盟链上。
2.如权利要求1所述的基于区块链的信用数据存储方法,其特征在于,在步骤S10之前,所述基于区块链的信用数据存储方法还包括:
S11:若获取到由节点触发的联盟链创建消息,则根据所述联盟链创建消息,搭建所述联盟链,并将触发所述联盟链创建消息的节点作为主节点;
S12:若获取到新节点加入请求,则在所述联盟链中选取其中一个节点,并通过被选取的节点向所述联盟链中发送新节点入网申请消息;
S13:所述联盟链中的节点通过所述智能合约对所述新节点入网申请消息进行投票,若所述投票的票数通过,则将根据所述新节点加入请求中的新节点通过网络连接加入所述联盟链,并将所述联盟链上的数据发送至所述新节点。
3.如权利要求1所述的基于区块链的信用数据存储方法,其特征在于,步骤S20包括:
S21:从所述数据上链模版中获取模板字符串;
S22:根据所述模板字符串在所述信用数据中进行匹配查询,将匹配查询到的结果作为所述信用元数据。
4.如权利要求1所述的基于区块链的信用数据存储方法,其特征在于,步骤S30包括:
S31:在所述信用元数据中获取用户唯一标识,使用散列算法对所述用户唯一标识进行计算,得到链上索引;
S32:对所述信用元数据进行计算,将计算结果与所述链上索引作为所述数据指纹。
5.如权利要求1所述的基于区块链的信用数据存储方法,其特征在于,在步骤S40之后,所述基于区块链的信用数据存储方法还包括:
S50:若获取到数据查看消息,则获取触发所述数据查看消息的用户标识信息;
S60:将所述用户标识信息在所述联盟链上进行比对查询;
S70:若在所述联盟链上查询到所述用户标识信息,则根据所述数据查看消息和所述用户标识信息发送对应的数据信息;
S80:若在所述联盟链上查询不到所述用户标识信息,则根据所述用户标识信息发送数据查看申请消息,在所述用户标识响应所述数据查看申请后,根据所述数据查看消息和所述用户标识信息发送对应的数据信息。
6.一种基于区块链的信用数据存储装置,其特征在于,所述基于区块链的信用数据存储装置包括:
数据获取模块,用于获取联盟链上各节点的信用数据;
数据提取模块,用于获取数据上链模版,根据所述数据上链模版从所述信用数据中提取信用元数据;
计算模块,用于使用散列算法对所述信用元数据进行计算,得到对应的数据指纹;
存储模块,用于计算当前时间戳,将所述当前时间戳与所述数据指纹作为信用区块,存储至所述联盟链上。
7.如权利要求6所述的基于区块链的信用数据存储装置,其特征在于,所述基于区块链的信用数据存储装置还包括:
联盟链创建模块,用于若获取到由节点触发的联盟链创建消息,则根据所述联盟链创建消息,搭建所述联盟链,并将触发所述联盟链创建消息的节点作为主节点;
申请消息发送模块,用于若获取到新节点加入请求,则在所述联盟链中选取其中一个节点,并通过被选取的节点向所述联盟链中发送新节点入网申请消息;
投票模块,用于所述联盟链中的节点通过所述智能合约对所述新节点入网申请消息进行投票,若所述投票的票数通过,则将根据所述新节点加入请求中的新节点通过网络连接加入所述联盟链,并将所述联盟链上的数据发送至所述新节点。
8.如权利要求6所述的基于区块链的信用数据存储装置,其特征在于,所述数据提取模块包括:
字符串获取子模块,用于从所述数据上链模版中获取模板字符串;
匹配查询子模块,用于根据所述模板字符串在所述信用数据中进行匹配查询,将匹配查询到的结果作为所述信用元数据。
9.一种计算机设备,包括存储器、处理器以及存储在所述存储器中并可在所述处理器上运行的计算机程序,其特征在于,所述处理器执行所述计算机程序时实现如权利要求1至5任一项所述基于区块链的信用数据存储方法的步骤。
10.一种计算机可读存储介质,所述计算机可读存储介质存储有计算机程序,其特征在于,所述计算机程序被处理器执行时实现如权利要求1至5任一项所述基于区块链的信用数据存储方法的步骤。
Priority Applications (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN201910330402.0A CN110096551A (zh) | 2019-04-23 | 2019-04-23 | 基于区块链的信用数据存储方法、装置、设备及介质 |
Applications Claiming Priority (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN201910330402.0A CN110096551A (zh) | 2019-04-23 | 2019-04-23 | 基于区块链的信用数据存储方法、装置、设备及介质 |
Publications (1)
Publication Number | Publication Date |
---|---|
CN110096551A true CN110096551A (zh) | 2019-08-06 |
Family
ID=67445643
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
CN201910330402.0A Pending CN110096551A (zh) | 2019-04-23 | 2019-04-23 | 基于区块链的信用数据存储方法、装置、设备及介质 |
Country Status (1)
Country | Link |
---|---|
CN (1) | CN110096551A (zh) |
Cited By (11)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN110458995A (zh) * | 2019-09-12 | 2019-11-15 | 北京笔新互联网科技有限公司 | 基于可信执行环境的匿名投票系统和投票方法 |
CN110543502A (zh) * | 2019-09-05 | 2019-12-06 | 腾讯科技(深圳)有限公司 | 基于区块链的信用数据处理方法、装置、设备及存储介质 |
CN110602233A (zh) * | 2019-09-20 | 2019-12-20 | 腾讯科技(深圳)有限公司 | 一种信息监控方法、装置以及计算机存储介质 |
CN110619223A (zh) * | 2019-08-27 | 2019-12-27 | 复旦大学 | 基于区块链的个人征信体系中信用数据安全共享方法 |
WO2020038105A1 (zh) * | 2018-08-24 | 2020-02-27 | 阿里巴巴集团控股有限公司 | 基于区块链的数据存证方法和装置 |
CN110851858A (zh) * | 2019-10-16 | 2020-02-28 | 上海源庐加佳信息科技有限公司 | 基于零知识证明的酒店个人隐私数据保护方法 |
CN111047450A (zh) * | 2020-03-18 | 2020-04-21 | 支付宝(杭州)信息技术有限公司 | 链上数据的链下隐私计算方法及装置 |
CN111090876A (zh) * | 2020-03-18 | 2020-05-01 | 支付宝(杭州)信息技术有限公司 | 调用合约的方法及装置 |
CN111489250A (zh) * | 2020-03-16 | 2020-08-04 | 天元大数据信用管理有限公司 | 一种基于区块链的征信报告共享方法、设备、介质及系统 |
CN111538786A (zh) * | 2020-04-24 | 2020-08-14 | 上海简苏网络科技有限公司 | 区块链数据脱敏与溯源的存储方法与装置 |
CN112527883A (zh) * | 2020-12-17 | 2021-03-19 | 山大地纬软件股份有限公司 | 基于区块链的数据资产可视化方法、系统及介质及设备 |
Citations (12)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN106230851A (zh) * | 2016-08-29 | 2016-12-14 | 中金云金融(北京)大数据科技股份有限公司 | 基于区块链的数据保全方法及系统 |
CN106296359A (zh) * | 2016-08-13 | 2017-01-04 | 深圳市樊溪电子有限公司 | 基于区块链技术的可信电力网络交易平台 |
CN106534273A (zh) * | 2016-10-31 | 2017-03-22 | 中金云金融(北京)大数据科技股份有限公司 | 区块链元数据存储系统及其存储方法与检索方法 |
US20170270721A1 (en) * | 2016-03-18 | 2017-09-21 | Dangerous Things LLC. | In vivo identity and security application implant and method |
CN107194666A (zh) * | 2017-05-19 | 2017-09-22 | 中链科技有限公司 | 基于区块链技术的报表管理方法和终端设备 |
US20170366347A1 (en) * | 2016-06-20 | 2017-12-21 | Ned M. Smith | Technologies for data broker assisted transfer of device ownership |
CN107944887A (zh) * | 2017-12-14 | 2018-04-20 | 法信公证云(厦门)科技有限公司 | 一种基于区块链的民间借贷风险预控方法 |
US20180316502A1 (en) * | 2017-04-27 | 2018-11-01 | Factom | Data Reproducibility Using Blockchains |
CN109039641A (zh) * | 2018-06-15 | 2018-12-18 | 思力科(深圳)电子科技有限公司 | 区块链应用系统 |
CN109089428A (zh) * | 2015-11-30 | 2018-12-25 | 舍普施福特股份公司 | 用于改善区块链资产交易中的安全性的系统以及方法 |
CN109118355A (zh) * | 2018-08-09 | 2019-01-01 | 南京安链数据科技有限公司 | 一种基于区块链的信用数据、模型的保固和校验方法 |
CN109347943A (zh) * | 2018-10-10 | 2019-02-15 | 百洲集团 | 一种基于区块链一键上链的方法及设备 |
-
2019
- 2019-04-23 CN CN201910330402.0A patent/CN110096551A/zh active Pending
Patent Citations (12)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN109089428A (zh) * | 2015-11-30 | 2018-12-25 | 舍普施福特股份公司 | 用于改善区块链资产交易中的安全性的系统以及方法 |
US20170270721A1 (en) * | 2016-03-18 | 2017-09-21 | Dangerous Things LLC. | In vivo identity and security application implant and method |
US20170366347A1 (en) * | 2016-06-20 | 2017-12-21 | Ned M. Smith | Technologies for data broker assisted transfer of device ownership |
CN106296359A (zh) * | 2016-08-13 | 2017-01-04 | 深圳市樊溪电子有限公司 | 基于区块链技术的可信电力网络交易平台 |
CN106230851A (zh) * | 2016-08-29 | 2016-12-14 | 中金云金融(北京)大数据科技股份有限公司 | 基于区块链的数据保全方法及系统 |
CN106534273A (zh) * | 2016-10-31 | 2017-03-22 | 中金云金融(北京)大数据科技股份有限公司 | 区块链元数据存储系统及其存储方法与检索方法 |
US20180316502A1 (en) * | 2017-04-27 | 2018-11-01 | Factom | Data Reproducibility Using Blockchains |
CN107194666A (zh) * | 2017-05-19 | 2017-09-22 | 中链科技有限公司 | 基于区块链技术的报表管理方法和终端设备 |
CN107944887A (zh) * | 2017-12-14 | 2018-04-20 | 法信公证云(厦门)科技有限公司 | 一种基于区块链的民间借贷风险预控方法 |
CN109039641A (zh) * | 2018-06-15 | 2018-12-18 | 思力科(深圳)电子科技有限公司 | 区块链应用系统 |
CN109118355A (zh) * | 2018-08-09 | 2019-01-01 | 南京安链数据科技有限公司 | 一种基于区块链的信用数据、模型的保固和校验方法 |
CN109347943A (zh) * | 2018-10-10 | 2019-02-15 | 百洲集团 | 一种基于区块链一键上链的方法及设备 |
Non-Patent Citations (1)
Title |
---|
李天乐: "基于可信区块链的数据完整性验证模型", 《中国优秀硕士学位论文全文数据库 信息科技辑》 * |
Cited By (19)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
WO2020038105A1 (zh) * | 2018-08-24 | 2020-02-27 | 阿里巴巴集团控股有限公司 | 基于区块链的数据存证方法和装置 |
CN110619223A (zh) * | 2019-08-27 | 2019-12-27 | 复旦大学 | 基于区块链的个人征信体系中信用数据安全共享方法 |
CN110543502A (zh) * | 2019-09-05 | 2019-12-06 | 腾讯科技(深圳)有限公司 | 基于区块链的信用数据处理方法、装置、设备及存储介质 |
CN110543502B (zh) * | 2019-09-05 | 2024-05-31 | 腾讯科技(深圳)有限公司 | 基于区块链的信用数据处理方法、装置、设备及存储介质 |
CN110458995B (zh) * | 2019-09-12 | 2021-08-31 | 北京笔新互联网科技有限公司 | 基于可信执行环境的匿名投票系统和投票方法 |
CN110458995A (zh) * | 2019-09-12 | 2019-11-15 | 北京笔新互联网科技有限公司 | 基于可信执行环境的匿名投票系统和投票方法 |
CN110602233A (zh) * | 2019-09-20 | 2019-12-20 | 腾讯科技(深圳)有限公司 | 一种信息监控方法、装置以及计算机存储介质 |
CN110602233B (zh) * | 2019-09-20 | 2022-04-15 | 腾讯科技(深圳)有限公司 | 一种信息监控方法、装置以及计算机存储介质 |
CN110851858A (zh) * | 2019-10-16 | 2020-02-28 | 上海源庐加佳信息科技有限公司 | 基于零知识证明的酒店个人隐私数据保护方法 |
CN110851858B (zh) * | 2019-10-16 | 2023-09-05 | 上海源庐加佳信息科技有限公司 | 基于零知识证明的酒店个人隐私数据保护方法 |
CN111489250A (zh) * | 2020-03-16 | 2020-08-04 | 天元大数据信用管理有限公司 | 一种基于区块链的征信报告共享方法、设备、介质及系统 |
CN111898153A (zh) * | 2020-03-18 | 2020-11-06 | 支付宝(杭州)信息技术有限公司 | 调用合约的方法及装置 |
WO2021184963A1 (zh) * | 2020-03-18 | 2021-09-23 | 支付宝(杭州)信息技术有限公司 | 调用合约的方法及装置 |
CN111090876A (zh) * | 2020-03-18 | 2020-05-01 | 支付宝(杭州)信息技术有限公司 | 调用合约的方法及装置 |
CN111898153B (zh) * | 2020-03-18 | 2024-05-03 | 支付宝(杭州)信息技术有限公司 | 调用合约的方法及装置 |
CN111047450A (zh) * | 2020-03-18 | 2020-04-21 | 支付宝(杭州)信息技术有限公司 | 链上数据的链下隐私计算方法及装置 |
CN111538786B (zh) * | 2020-04-24 | 2021-01-05 | 上海简苏网络科技有限公司 | 区块链数据脱敏与溯源的存储方法与装置 |
CN111538786A (zh) * | 2020-04-24 | 2020-08-14 | 上海简苏网络科技有限公司 | 区块链数据脱敏与溯源的存储方法与装置 |
CN112527883A (zh) * | 2020-12-17 | 2021-03-19 | 山大地纬软件股份有限公司 | 基于区块链的数据资产可视化方法、系统及介质及设备 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
CN110096551A (zh) | 基于区块链的信用数据存储方法、装置、设备及介质 | |
US9635000B1 (en) | Blockchain identity management system based on public identities ledger | |
CN108734028B (zh) | 基于区块链的数据管理方法、区块链节点及存储介质 | |
CN110535971B (zh) | 基于区块链的接口配置处理方法、装置、设备及存储介质 | |
CN113297625B (zh) | 基于区块链的数据共享系统、方法和电子设备 | |
CN112003858B (zh) | 基于区块链的平台对接的方法、电子装置和存储介质 | |
KR20190085106A (ko) | 데이터 액세스를 위한 방법, 시스템 및 장치 | |
CN109359601A (zh) | 身份验证识别方法、电子装置及计算机可读存储介质 | |
CN108923932A (zh) | 一种去中心化协同验证模型及验证算法 | |
CN107423632A (zh) | 可定制的敏感数据脱敏方法和系统 | |
CN111291394B (zh) | 一种虚假信息管理方法、装置和存储介质 | |
CN110430288A (zh) | 节点访问方法、装置、计算机设备和存储介质 | |
CN112308561A (zh) | 基于区块链的存证方法、系统、计算机设备和存储介质 | |
CN108769186A (zh) | 业务权限控制方法及装置 | |
US20190081794A1 (en) | Systems and methods for user identity | |
CN110852648A (zh) | 一种数据处理方法、装置及计算机存储介质 | |
CN112231755B (zh) | 一种基于区块链的数据授权方法、装置及系统 | |
CN113704357A (zh) | 一种基于区块链的智慧城市数据共享方法及系统 | |
CN114629713B (zh) | 身份验证方法、装置及系统 | |
CN110807209B (zh) | 一种数据处理方法、设备及存储介质 | |
CN104182525A (zh) | 应用有版权保护功能的多媒体文件和国密算法的电子档案管理装置 | |
CN110138558A (zh) | 会话密钥的传输方法、设备及计算机可读存储介质 | |
CN109918451A (zh) | 基于区块链的数据库管理方法及系统 | |
CN113688430A (zh) | 基于区块链的数据访问授权方法、装置、设备及存储介质 | |
US20230325833A1 (en) | Blockchain-based data processing method and apparatus, device, storage medium, and program product |
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 | ||
AD01 | Patent right deemed abandoned | ||
AD01 | Patent right deemed abandoned |
Effective date of abandoning: 20220311 |