CN117454439A - 基于区块链的抽奖数据处理方法、装置、电子设备及介质 - Google Patents

基于区块链的抽奖数据处理方法、装置、电子设备及介质 Download PDF

Info

Publication number
CN117454439A
CN117454439A CN202311103061.6A CN202311103061A CN117454439A CN 117454439 A CN117454439 A CN 117454439A CN 202311103061 A CN202311103061 A CN 202311103061A CN 117454439 A CN117454439 A CN 117454439A
Authority
CN
China
Prior art keywords
data
lottery
node
verification
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.)
Pending
Application number
CN202311103061.6A
Other languages
English (en)
Inventor
刘渊渊
包岩
周晓阳
卫俊俊
应葆华
赵丹怀
樊期光
薛亮
孙焱
施晓晨
Current Assignee (The listed assignees may be inaccurate. Google has not performed a legal analysis and makes no representation or warranty as to the accuracy of the list.)
China Mobile Zijin Jiangsu Innovation Research Institute Co ltd
China Mobile Communications Group Co Ltd
China Mobile Group Jiangsu Co Ltd
China Mobile Communications Ltd Research Institute
Original Assignee
China Mobile Zijin Jiangsu Innovation Research Institute Co ltd
China Mobile Communications Group Co Ltd
China Mobile Group Jiangsu Co Ltd
China Mobile Communications Ltd Research Institute
Priority date (The priority date 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 date listed.)
Filing date
Publication date
Application filed by China Mobile Zijin Jiangsu Innovation Research Institute Co ltd, China Mobile Communications Group Co Ltd, China Mobile Group Jiangsu Co Ltd, China Mobile Communications Ltd Research Institute filed Critical China Mobile Zijin Jiangsu Innovation Research Institute Co ltd
Priority to CN202311103061.6A priority Critical patent/CN117454439A/zh
Publication of CN117454439A publication Critical patent/CN117454439A/zh
Pending legal-status Critical Current

Links

Classifications

    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F21/00Security arrangements for protecting computers, components thereof, programs or data against unauthorised activity
    • G06F21/60Protecting data
    • G06F21/64Protecting data integrity, e.g. using checksums, certificates or signatures
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F16/00Information retrieval; Database structures therefor; File system structures therefor
    • G06F16/20Information retrieval; Database structures therefor; File system structures therefor of structured data, e.g. relational data
    • G06F16/23Updating
    • G06F16/2365Ensuring data consistency and integrity
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F16/00Information retrieval; Database structures therefor; File system structures therefor
    • G06F16/20Information retrieval; Database structures therefor; File system structures therefor of structured data, e.g. relational data
    • G06F16/27Replication, distribution or synchronisation of data between databases or within a distributed database system; Distributed database system architectures therefor
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F21/00Security arrangements for protecting computers, components thereof, programs or data against unauthorised activity
    • G06F21/60Protecting data
    • G06F21/602Providing cryptographic facilities or services
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F21/00Security arrangements for protecting computers, components thereof, programs or data against unauthorised activity
    • G06F21/60Protecting data
    • G06F21/62Protecting access to data via a platform, e.g. using keys or access control rules
    • G06F21/6218Protecting 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/6245Protecting personal data, e.g. for financial or medical purposes
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06QINFORMATION 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
    • G06Q30/00Commerce
    • G06Q30/02Marketing; Price estimation or determination; Fundraising
    • G06Q30/0207Discounts or incentives, e.g. coupons or rebates
    • G06Q30/0211Determining the effectiveness of discounts or incentives
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06QINFORMATION 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
    • G06Q30/00Commerce
    • G06Q30/02Marketing; Price estimation or determination; Fundraising
    • G06Q30/0207Discounts or incentives, e.g. coupons or rebates
    • G06Q30/0212Chance discounts or incentives

Landscapes

  • Engineering & Computer Science (AREA)
  • Theoretical Computer Science (AREA)
  • General Physics & Mathematics (AREA)
  • Physics & Mathematics (AREA)
  • Business, Economics & Management (AREA)
  • General Engineering & Computer Science (AREA)
  • Computer Security & Cryptography (AREA)
  • Bioethics (AREA)
  • General Health & Medical Sciences (AREA)
  • Strategic Management (AREA)
  • Health & Medical Sciences (AREA)
  • Finance (AREA)
  • Databases & Information Systems (AREA)
  • Development Economics (AREA)
  • Accounting & Taxation (AREA)
  • Software Systems (AREA)
  • Computer Hardware Design (AREA)
  • Data Mining & Analysis (AREA)
  • Entrepreneurship & Innovation (AREA)
  • Game Theory and Decision Science (AREA)
  • Economics (AREA)
  • Marketing (AREA)
  • General Business, Economics & Management (AREA)
  • Computing Systems (AREA)
  • Medical Informatics (AREA)
  • Management, Administration, Business Operations System, And Electronic Commerce (AREA)

Abstract

本申请公开了一种基于区块链的抽奖数据处理方法、装置、电子设备及介质,涉及区块链技术领域,所述基于区块链的抽奖数据处理方法包括:对抽奖数据进行加密,得到加密抽奖数据,并通过区块链中的核验节点对所述加密抽奖数据进行核验,其中,所述区块链至少包括抽奖用户网络、抽奖活动数据网络以及抽奖结果公开网络,所述抽奖数据至少包括用户数据和抽奖活动数据;将通过核验的加密抽奖数据存储至所述区块链;获取抽奖结果数据对应的用户输入的身份信息,通过所述核验节点对所述身份信息进行身份验证;将通过身份验证的身份信息对应的用户数据上传至所述抽奖结果公开网络。本申请解决了当前的抽奖活动方案的透明性和可信度偏低的技术问题。

Description

基于区块链的抽奖数据处理方法、装置、电子设备及介质
技术领域
本申请涉及区块链技术领域,尤其涉及一种基于区块链的抽奖数据处理方法、装置、电子设备及介质。
背景技术
目前,各种抽奖平台内的开售、停售、用户信息获取存储、统计核对购买情况等逻辑,均通过中心化的系统集中处理,对于封闭的中心化系统,数据是统一管控的,如果管理侧的修改不公开,中心化平台完全可以做到私自修改数据,并没有任何记录流程,所以难以取得公众信任。所以当前业界通常会结合区块链技术的去中心化和公开化的特质,将区块链技术与抽奖活动结合起来,从而保证了抽奖活动数据的可信度和不可篡改性。
但是目前的基于区块链的抽奖活动方案仅将抽奖活动的阶段性过程数据上传至链上以完成存证,如由活动发起方将发布抽奖活动、停止抽奖活动、抽奖结果等信息进行链上存储,没有将区块链技术融合到抽奖的每个流程中。
因此目前基于区块链的抽奖活动方案仍然存在抽奖活动中包括开售、用户信息存储、开奖、中奖用户信息核对在内的多个步骤的机制不透明的技术缺陷,从而导致当前的抽奖活动方案的透明性和可信度偏低。
发明内容
本申请的主要目的在于提供一种基于区块链的抽奖数据处理方法、装置、电子设备及介质,旨在解决当前的抽奖活动方案的透明性和可信度偏低的技术问题。
为实现上述目的,本申请提供一种基于区块链的抽奖数据处理方法,所述基于区块链的抽奖数据处理方法包括:
响应于区块链上各节点的抽奖数据上传请求,对抽奖数据进行加密,得到加密抽奖数据,其中,所述区块链至少包括抽奖用户网络、抽奖活动数据网络以及抽奖结果公开网络,所述抽奖数据至少包括所述抽奖用户网络中的用户数据和所述抽奖活动数据网络中的抽奖活动数据;
通过所述区块链中的核验节点对所述加密抽奖数据进行核验,并将通过核验的加密抽奖数据存储至所述区块链;
获取抽奖结果数据对应的用户输入的身份信息,通过所述核验节点对所述身份信息进行身份验证;
将通过身份验证的身份信息对应的用户数据上传至所述抽奖结果公开网络。
可选地,在所述通过所述区块链中的核验节点对所述加密抽奖数据进行核验的步骤之前,所述方法还包括:
基于所述区块链中各共识节点的总可信度,从各所述共识节点中选取核验节点;
基于各所述共识节点的可信度,删除可信度低于可信度阈值的共识节点。
可选地,所述基于所述区块链中各共识节点的总可信度,从各所述共识节点中选取核验节点的步骤包括:
根据各所述共识节点的类型、发送的消息、发送消息数以及接收消息数,确定各所述共识节点的当前可信度;
根据各所述共识节点所产生的区块数、作为核验节点的次数以及作为核验节点的时长,确定各所述共识节点的预测可信度;
根据各所述共识节点分别对应的当前可信度和预测可信度,确定各所述共识节点的总可信度;
选取总可信度最高的共识节点作为核验节点。
可选地,所述类型包括核验节点和备份节点,所述根据各所述共识节点的类型、发送的消息、发送消息数以及接收消息数,确定各所述共识节点的当前可信度的步骤包括:
当所述共识节点为核验节点时,判断所述核验节点向各共识节点发送的消息是否相同;
若所述核验节点向各共识节点发送的消息相同,则所述核验节点的当前可信度为第一预设值;
若所述核验节点向各共识节点发送的消息不同,则所述核验节点的当前可信度为第二预设值,其中,所述第一预设值大于所述第二预设值;
当所述共识节点为备份节点时,判断所述备份节点向所述核验节点发送的确认消息是否正确;
若所述确认消息正确,则根据所述备份节点的发送消息数和接收消息数,计算所述备份节点的当前可信度;
若所述确认消息错误,则所述备份节点的当前可信度为第二预设值。
可选地,所述根据各所述共识节点分别对应的当前可信度和预测可信度,确定各所述共识节点的总可信度的步骤包括:
根据各所述共识节点分别对应的当前可信度和预测可信度以及所述当前可信度和所述预测可信度分别对应的权重,计算各所述共识节点的总可信度。
可选地,所述加密抽奖数据至少包括加密抽奖数据,所述将通过核验的加密抽奖数据存储至所述区块链的步骤包括:
将通过核验的加密用户数据分布式存储在边缘存储服务器;
通过所述边缘存储服务器返回与所述加密用户数据对应的哈希路径值;
将所述哈希路径值和所述用户数据对应的加密秘钥进行属性加密后存储至所述抽奖用户网络。
可选地,所述区块链中包括活动发行方和数据用户方,所述获取抽奖结果数据对应的用户输入的身份信息,通过所述核验节点对所述身份信息进行身份验证的步骤包括:
通过活动发行方向所述抽奖结果数据对应的数据用户方发起授权申请,当所述数据用户方接收到所述授权申请时,获取用户输入的身份信息;
对所述身份信息进行哈希计算,获得身份哈希值;
将所述身份哈希值发送到所述核验节点,通过所述核验节点判断所述用户对应的用户身份标识是否与所述身份哈希值一致;
若是,则所述身份信息通过核验。
可选地,所述将通过身份验证的身份信息对应的用户数据上传至所述抽奖结果公开网络的步骤包括:
通过所述核验节点从所述抽奖用户网络中提取所述身份信息对应的用户数据的密文存储地址;
向所述密文存储地址对应的边缘存储服务器发送数据请求;
通过所述边缘存储服务器响应于所述数据请求,将所述密文存储地址对应的密文数据返回给所述数据用户方;
响应于所述数据用户方的确认指令,将所述密文数据发送至所述活动发行方;
通过所述活动发行方对所述密文数据进行解密,得到所述身份信息对应的用户数据,并将所述用户数据上传到所述抽奖结果公开网络。
可选地,所述基于区块链的抽奖数据处理方法还包括:
当满足预设的开奖条件时,通过各分布式预言机向量子随机数生成器请求获取随机数列表;
通过所述量子随机数生成器分别生成每个分布式预言机对应的随机数列表;
对各所述随机数列表进行秘钥封装和签名,并将封装后的随机数列表传递至智能合约,以供所述智能合约根据各所述随机数列表生成抽奖结果数据。
本申请还提供一种基于区块链的抽奖数据处理装置,所述基于区块链的抽奖数据处理装置应用于基于区块链的抽奖数据处理设备,所述基于区块链的抽奖数据处理装置包括:
数据加密模块,用于响应于区块链上各节点的抽奖数据上传请求,对抽奖数据进行加密,得到加密抽奖数据,其中,所述区块链至少包括抽奖用户网络、抽奖活动数据网络以及抽奖结果公开网络,所述抽奖数据至少包括所述抽奖用户网络中的用户数据和所述抽奖活动数据网络中的抽奖活动数据;
数据核验模块,用于通过所述区块链中的核验节点对所述加密抽奖数据进行核验,并将通过核验的加密抽奖数据存储至所述区块链;
身份验证模块,用于获取抽奖结果数据对应的用户输入的身份信息,通过所述核验节点对所述身份信息进行身份验证;
数据公开模块,用于将通过身份验证的身份信息对应的用户数据上传至所述抽奖结果公开网络。
本申请还提供一种电子设备,所述电子设备为实体设备,所述电子设备包括:存储器、处理器以及存储在所述存储器上并可在所述处理器上运行的所述基于区块链的抽奖数据处理方法的程序,所述基于区块链的抽奖数据处理方法的程序被处理器执行时可实现如上述的基于区块链的抽奖数据处理方法的步骤。
本申请还提供一种计算机可读存储介质,所述计算机可读存储介质上存储有实现基于区块链的抽奖数据处理方法的程序,所述基于区块链的抽奖数据处理方法的程序被处理器执行时实现如上述的基于区块链的抽奖数据处理方法的步骤。
本申请还提供一种计算机程序产品,包括计算机程序,所述计算机程序被处理器执行时实现如上述的基于区块链的抽奖数据处理方法的步骤。
本申请提供了一种基于区块链的抽奖数据处理方法、装置、电子设备及介质,首先响应于区块链上各节点的抽奖数据上传请求,对抽奖数据进行加密,得到加密抽奖数据,其中,所述区块链至少包括抽奖用户网络、抽奖活动数据网络以及抽奖结果公开网络,所述抽奖数据至少包括所述抽奖用户网络中的用户数据和所述抽奖活动数据网络中的抽奖活动数据,在通过所述区块链中的核验节点对所述加密抽奖数据进行核验,并将通过核验的加密抽奖数据存储至所述区块链,其中,所述区块链至少包括抽奖用户网络、抽奖活动数据网络以及抽奖结果公开网络,另一方面,获取抽奖结果数据对应的用户输入的身份信息,通过所述核验节点对所述身份信息进行身份验证,然后将通过身份验证的身份信息对应的用户数据上传至所述抽奖结果公开网络,本申请的技术方案通过区块链技术实现了对各个流程的抽奖数据分别进行加密、核验以及上链存储,提高了抽奖过程的透明性和可信度,而且通过存储在各个节点的抽奖数据保障了信息的公开性以及不可篡改性,本申请的技术方案中通过抽奖用户网络、抽奖活动数据网络以及抽奖结果公开网络组成整体的区块链网络,满足了对各种类型的抽奖数据分别进行分布式存储的要求,在保证数据使用的同时,通过不同的网络区分开不同的抽奖数据,从而保证了用户数据的隐私性,综上所述,本申请的技术方案提高了抽奖活动方案的透明度和可信度。
附图说明
此处的附图被并入说明书中并构成本说明书的一部分,示出了符合本申请的实施例,并与说明书一起用于解释本申请的原理。
为了更清楚地说明本申请实施例或现有技术中的技术方案,下面将对实施例或现有技术描述中所需要使用的附图作简单地介绍,显而易见地,对于本领域普通技术人员而言,在不付出创造性劳动性的前提下,还可以根据这些附图获得其他的附图。
图1为本申请基于区块链的抽奖数据处理方法第一实施例的流程示意图;
图2为本申请基于区块链的抽奖数据处理方法中基于区块链的抽奖平台数据存储及分享示意图;
图3为本申请基于区块链的抽奖数据处理方法中各网络件数据存储及分享示意图;
图4为本申请基于区块链的抽奖数据处理方法中跨链数据分享流程示意图;
图5为本申请基于区块链的抽奖数据处理方法中基于量子随机数生成器生成抽奖结果的示意图;
图6为本申请基于区块链的抽奖数据处理方法第二实施例的流程示意图;
图7为本申请基于区块链的抽奖数据处理方法中总体流程实施例示意图;
图8为本申请实施例中基于区块链的抽奖数据处理装置的组成结构示意图;
图9为本申请实施例中基于区块链的抽奖数据处理方法涉及的硬件运行环境的设备结构示意图。
本申请目的实现、功能特点及优点将结合实施例,参照附图做进一步说明。
具体实施方式
为使本申请的上述目的、特征和优点能够更加明显易懂,下面将结合本申请实施例中的附图,对本申请实施例中的技术方案进行清楚、完整地描述。显然,所描述的实施例仅仅是本申请一部分实施例,而不是全部的实施例。基于本申请中的实施例,本领域普通技术人员在没有作出创造性劳动的前提下所获得的所有其它实施例,均属于本申请保护的范围。
实施例一
当前业界主流的抽奖活动方案是基于中心化系统将参与用户、用户购买、抽奖发布、抽奖算法、抽奖结果等各个环节的数据均存储在集中化的服务器中,而这种中心化的处理方案通常会导致用户质疑抽奖公平性、用户数据隐私性等。而且针对中心化、非公开的问题,区块链技术从诞生起,通过去中心化和公开化的方式,集体维护一个可靠数据库的技术方案,区块链技术可以很好地保证数据的可信度和不可篡改性。但当目前并没有区块链与抽奖平台的成熟方案,或是仅将抽奖的阶段性过程数据,如发布抽奖活动、停止抽奖活动、抽奖结果等信息进行链上存储,并未将区块链公开、可信的能力,融入抽奖的各个流程中,亟需一种将抽奖平台数据加密存储,并结合摇号抽奖场景,将抽奖活动发布、个人购买参与抽奖、信息核对、开奖等全流程的抽奖数据均进行区块链上链,以保证抽奖过程的随机性、透明性以及可信能度的抽奖数据管理方案。
本申请实施例提供一种基于区块链的抽奖数据处理方法,在本申请基于区块链的抽奖数据处理方法的第一实施例中,参照图1,所述基于区块链的抽奖数据处理方法包括:
步骤S10,响应于区块链上各节点的抽奖数据上传请求,对抽奖数据进行加密,得到加密抽奖数据,其中,所述区块链至少包括抽奖用户网络、抽奖活动数据网络以及抽奖结果公开网络,所述抽奖数据至少包括所述抽奖用户网络中的用户数据和所述抽奖活动数据网络中的抽奖活动数据;
步骤S20,通过所述区块链中的核验节点对所述加密抽奖数据进行核验,并将通过核验的加密抽奖数据存储至所述区块链;
步骤S30,获取抽奖结果数据对应的用户输入的身份信息,通过所述核验节点对所述身份信息进行身份验证;
步骤S40,将通过身份验证的身份信息对应的用户数据上传至所述抽奖结果公开网络。
在本申请实施例中,所述区块链中包括多个联盟链,其中包括抽奖用户网络、抽奖活动数据网络以及抽奖结果公开网络等,均为不同的联盟链,在抽奖活动中,参与各方(如数据用户、证书机构、抽奖活动发行方以及核验节点等)在各联盟链中均包括节点,其中,所述抽奖用户网络用于存储抽奖参与用户(数据用户)的用户数据,包括隐私数据,各抽奖用户可以将自己的用户数据上传到所述抽奖用户网络中,而抽奖活动发行方在获取用户数据时则需要获得授权和验证,从而保证用户数据的隐私不被泄露;另外所述抽奖活动数据网络用于存储抽奖活动发行方上传的抽奖活动数据,所述抽奖结果公开网络用于存储中奖用户对应的部分用户数据,以向各参与抽奖的用户展示抽奖结果。本申请实施例的技术方案中采用了区块链联盟网络,避免了在单一链的场景下,大量的用户使用对区块链的支撑能力影响。
另外,在本申请实施例中,抽奖用户均通过创建数字身份,在多联盟链下的用户统一,参照图2,在基于区块链的抽奖数据处理方法中,负责进行各联盟链之间的数据分享的节点为VC(Validate Cross Chain,对跨链交易或跨链操作进行验证),其中,各联盟链网络包括抽奖用户网络(PUN,Participate User Block Chain Network)、抽奖活动数据网络(LCN,Lottery Activity Block Chain Network)以及抽奖结果公开网络(Public ResultBlock Chain Network,PRN),此外,区块链中还包括证书机构CA(CertificateAuthority),负责管理区块链网络中身份标识、管理密钥、抽奖活动参与者的用户数据鉴权等,而每个联盟链中,也包括多个节点(PC1-PC4)等,各节点即为参与各方分别对应的节点,需要说明的是,每个参与方在各联盟链中分别具有一个对应的节点,用于上传、存储以及读取数据。
另外,各位抽奖活动参与者在区块链内作为一个数据用户,因区块链的安全接入要求以及保证联盟链用户身份统一,不能直接使用手机号作为其用户标识,需应用数字身份DID(Decentralized Identifiers)作为其用户标识,具体地,所述数据身份DID的数据结构包括哈希值、prevld(前一个区块的标识符)、PrePubKey(前一个区块生成者的公钥)、哈希路径值(URL)、Nonce(随机数)以及标识(sign),其中,所述哈希路径值所指向的文件路径中包括由抽奖活动参与者的加密后的用户数据,便于后续的数据分享。
进一步地,所述区块链的抽奖数据管理方法可以应用于基于区块链的数据存储及分享模型,参照图3,其中,除了区块链中的各联盟网络,还包括边缘数据节点(Edge Node,EN),所述边缘数据节点用于在抽奖结果公开时对抽奖用户的部分信息和抽奖结果信息进行公开,而数据用户DU(DataUser),则是各抽奖参与者对应的节点,是抽奖活动用户数据产生方,通过在将用户的身份数据、用户的隐私信息、用户购买信息上传至区块链节点及存储系统,可查看、分享数据;另外,抽奖活动发行方AO(Activity Organizer)则负责为抽奖活动参与者生成身份标识和管理秘钥等;除此之外,各联盟链中还包括核验节点,用于生成区块,将每次上链交易打包为区块,并加入区块链账本,确保数据正确上链,并负责为联盟区块链的网络通信,处理内部、外部的处理申请,而且,为了保证核验节点的可信度,核验节点需根据一定的方案进行节点更新。具体地,生成的每个区块在上链时的数据结构如下表1所示。
表1
作为一种示例,步骤S10至步骤S40包括:响应于区块链上各节点的抽奖数据上传请求,对抽奖数据进行加密,得到加密抽奖数据,其中,各所述节点可以包括数据用户节点和抽奖活动发行方节点,所述抽奖数据可以包括用户数据和抽奖活动数据中的一种,其中,所述数据用户节点上传的是用户数据,所述抽奖活动发行方节点上传的是抽奖活动数据,在对抽奖数据进行加密是,可以通过预设的秘钥对节点所上传的数据进行加密处理,从而得到加密抽奖数据;在加密完成后,需要对所述加密抽奖数据进行核验后才能上传,具体通过区块链中的核验节点执行对所述加密抽奖数据的核验,其中,所述核验节点为区块链中各共识节点中的一个,且根据预设的更新规则对核验节点进行更新,以保证所述核验节点的可信度;通过所述核验节点对上传的加密抽奖数据中的各部分的数据进行核验,以判断是否符合区块链中各联盟链分别对应的预设规则,避免被恶意攻击以及上传无意义的垃圾数据;在所述加密抽奖数据通过核验后,即可将所述加密抽奖数据上传到区块链中对应的联盟链,具体地,核验节点基于核验的加密抽奖数据打包成区块,加入到区块链账本,记录本次上链,所述抽奖数据为用户数据时,则存储到抽奖用户网络、所述抽奖数据为抽奖活动数据时,则存储到抽奖活动数据网络;另外,在符合抽奖活动发行方规定的抽奖条件后,即通过抽奖活动数据网络根据抽奖用户网络中各抽奖参与者的数字身份DID随机筛选出一批中奖用户,得到抽奖结果,其中,所述抽奖结果中包括多个中奖用户的数字身份DID以及分别对应的中奖等级;通过抽奖活动发行方获取各中奖用户输入的身份信息,其中,在身份信息无误的情况下,所述身份信息为中奖用户在参与抽奖时选择的某个关键字;通过区块链中的核验节点根据中奖用户在抽奖时输入的身份信息和所述身份信息进行核对,以判断所述中奖用户的身份信息是否正确;若正确,则所述身份信息验证通过;根据抽奖用户网络中获取所述身份信息对应的用户数据中的部分数据,进行数据访问记录,将所述部分数据上传到区块链中的抽奖公开网络,以供各抽奖参与者查阅;上传所述数据访问记录,其中,访问记录上传与数据上传的过程一致。
在另一种可行的实施例中,所述基于区块链的抽奖数据处理方法还可以应用于评分投票领域,能为区块链隐匿投票评分提供理论基础。评分投票平台主要功能包括评分/投票发布、评分/投票记录、扫码评分/投票、评分码评分/投票入口、评分/投票核验等,由于评分投票平台具体的技术场景与本方案的抽奖数据存储分享能力一致,在保证高效共识的基础上,可以有效地保证个人数据的隐私和结果的可靠性。
本申请实施例提出一种基于区块链的抽奖数据存储及分享思路,将抽奖活动的发起、抽奖活动数据存储与分享等关键动作与区块链紧密结合,将现有中心化的抽奖平台,优化为支持分布式、去中心化、全流程可信的抽奖流程,有效地提升了抽奖活动的透明度和可信度。
进一步地,所述将通过核验的加密抽奖数据存储至所述区块链的步骤包括:
步骤S21,将通过核验的加密用户数据分布式存储在边缘存储服务器;
步骤S22,通过所述边缘存储服务器返回与所述加密用户数据对应的哈希路径值;
步骤S23,将所述哈希路径值和所述用户数据对应的加密秘钥进行属性加密后存储至所述抽奖用户网络。
在本申请实施例中提出了一种将抽奖活动参与者的隐私数据如个人姓名、手机号、身份证号的加密保存方案,所述加密抽奖数据包括加密用户数据,可以采用IPFS(InterPlanetary File System,星际文件系统)来作为边缘存储服务器,用于存储加密抽奖数据的源数据,然后通过所述边缘存储服务器将源数据的哈希路径返回存储至区块链,区块链中只需要存储哈希路径即可,以节省区块链中各联盟链的存储资源,以便于后续的数据分享。
作为一种示例,步骤S21至步骤S23包括:当所述加密用户数据通过核验后,将所述加密用户数据分布式存储在与区块链连接的边缘存储服务器中;在存储完毕后,通过所述边缘存储服务器将所述加密用户数据在所述边缘存储服务器中的哈希路径值返回给区块链中的抽奖用户网络;通过所述抽奖用户网络中的核验节点将所述哈希路径值和所述用户数据对应的加密秘钥生成对应的区块,并进行属性加密后存储在所述抽奖用户网络中。
另外,在所述区块链中,至少包括活动发行方和数据用户方,所述获取抽奖结果数据对应的用户输入的身份信息,通过所述核验节点对所述身份信息进行身份验证的步骤包括:
步骤S31,通过活动发行方向所述抽奖结果数据对应的数据用户方发起授权申请,当所述数据用户方接收到所述授权申请时,获取用户输入的身份信息;
步骤S32,对所述身份信息进行哈希计算,获得身份哈希值;
步骤S33,将所述身份哈希值发送到所述核验节点,通过所述核验节点判断所述用户对应的用户身份标识是否与所述身份哈希值一致;
步骤S34,若是,则所述身份信息通过核验。
在本申请实施例中,主要公开了针对抽奖活动开奖时,抽奖活动发行方需要对部分中奖用户进行详细信息的核验时的一种数据分享、传输以及核验的方法。使得抽奖平台的数据满足支持分布式存储的要求的同时,还在多机构存储后,保证用户数据其本身的隐私性,满足数据使用时,又能保障数据共享的便捷性、高效性。所以通过区块链中的各联盟链存储个人用户数据、用户购买数据、开奖数据等,在保护用户隐私的情况下,为了保障数据的可靠性和隐私性,需要建立多个联盟链,并通过跨链技术,将多个联盟链的数据联合与共享,便于后续的审计。
作为一种示例,步骤S31至步骤S34包括:在抽奖结果数据出来后,通过活动发行方向所述抽奖结果中的中奖用户对应的数据用户方发起授权申请,以读取所述数据用户方在抽奖用户网络中存储的用户数据;当所述数据用户方接收到所述授权申请时,通过所述数据用户方对应的终端提示用户输入身份信息,以获取用户输入的身份信息,其中,所述身份信息为用户输入的关键词,在用户参与抽奖活动时,首先选取一关键词,并对所述关键词进行哈希计算,得到用户身份标识,而在该用户中奖之后,需要对用户的身份进行核验,所以需要该用户再次输入该关键词;对所述关键词再次进行哈希计算,得到对应的身份哈希值;再通过核验节点比对所述身份哈希值是否与改用户预存的身份标识一致;若一致,则说明的所述身份信息核验通过。
在一种可行的实施例中,数据用户输入关键字y,对其进行哈希计算得到H(y),将<ID,H(y),NodeID,H(ID)>发送给核验节点,核验节点验证用户身份,如果H(ID)与核验节点保存的用户身份标识一致,则身份验证通过;其中,说明:ID表示唯一身份标识,H()表示哈希计算,NodeID为节点标识。
进一步地,所述将通过身份验证的身份信息对应的用户数据上传至所述抽奖结果公开网络的步骤还可以包括:
步骤S41,通过所述核验节点从所述抽奖用户网络中提取所述身份信息对应的用户数据的密文存储地址;
步骤S42,向所述密文存储地址对应的边缘存储服务器发送数据请求;
步骤S43,通过所述边缘存储服务器响应于所述数据请求,将所述密文存储地址对应的密文数据返回给所述数据用户方;
步骤S44,响应于所述数据用户方的确认指令,将所述密文数据发送至所述活动发行方;
步骤S45,通过所述活动发行方对所述密文数据进行解密,得到所述身份信息对应的用户数据,并将所述用户数据上传到所述抽奖结果公开网络。
在本申请实施例中提供了一种基于区块链中的各联盟链和边缘存储服务器进行数据的分享、传输以及上传的跨链数据管理方法,主要调取了边缘存储服务器中用于存储了数据用户方的密文数据,保护了用户的数据隐私。还需要说明的是,在所述活动发行方成功获取到所述密文数据以及上传到联盟链(抽奖结果公开网络)后,还需要将访问记录上传到联盟链中,完成存证,避免私自修改用户数据,保证区块链中数据的真实性和可信度。
作为一种示例,步骤S41至步骤S45包括:通过抽奖用户网络中的核验节点从所述抽奖用户网络中提取密文存储地址,并将数据请求发送至所述密文存储地址对应的边缘存储服务器,以供所述边缘存储服务器根据所述密文地址返回对应的密文数据,其中,所述密文存储地址为所述密文数据在所述边缘存储服务器中的存储地址path(路径);通过所述边缘存储服务器将所述密文存储地址对应的密文数据返回给所述数据用户方,以供所述数据用户方确认,避免用户数据被篡改;当所述数据用户方确认该密文数据对应的明文信息无误后,向所述边缘服务存储器发送确认指令,通过所述边缘服务存储器向所述活动发行方发送所述密文数据;通过所述活动发行方根据预置的私钥对所述密文数据进行解密,获得所述身份信息对应的数据明文,将所述数据明文上传至所述抽奖结果公开网络,需要说明的,其中,所述数据明文为中奖用户对应的部分不涉及隐私的用户数据;生成本次数据访问的访问记录,并将所述访问记录上传到所述抽奖用户网络。
在一种可行的实施例中,参照图4,所述活动发行方为彩票发行方,所述数据用户方为个人用户,所述联盟链为抽奖用户网络,彩票发行方向个人用户发起访问请求,个人用户输入身份信息后通过核验节点核验所述个人用户的身份并接收抽奖用户网络中节点反馈的密文存储地址,以及从边缘存储服务器获取密文数据。
另一方面,本申请实施例中还提供了一种通过区块链中的量子随机数生成器生成抽奖结果的方法,具体地,所述基于区块链的抽奖数据处理方法还包括:
步骤A10,当满足预设的开奖条件时,通过各分布式预言机向量子随机数生成器请求获取随机数列表;
步骤A20,通过所述量子随机数生成器分别生成每个分布式预言机对应的随机数列表;
步骤A30,对各所述随机数列表进行秘钥封装和签名,并将封装后的随机数列表传递至智能合约,以供所述智能合约根据各所述随机数列表生成抽奖结果数据。
本申请实施例中,可以彩票在开奖前固定时间段,将停止售卖,此限制可通过智能合约的限制固定在代码中,保证不可随意变更。而在彩票开奖时,基于线上生成开奖号码的随机性严格要求,要求随机数生成的可靠性和不可破解性,可通过增加量子随机数发生器QRNG(Quantum Random Number Generator),能使得随机数实时生成速率达到10Gbps。再通过生成的随机数和联盟链中的智能合约进行开奖,保障了抽奖活动的公平公正和不可篡改性。
作为一种示例,参照图5中表述的区块链各部分之间的数据传输关系,步骤A10至步骤A30包括:通过联盟链中的智能合约判断是否满足开奖条件,其中,所述开奖条件可以包括购买彩票的人数和开奖时间;当满足所述开奖条件时,向分布式预言机发起量子随机数获取请求,其中,分布式预言机的数量可以为一个,也可以为多个;通过分布式预言机向量子随机数生成器请求随机数列表;通过所述量子随机数生成器响应于分布式于延琦的请求,生成各所述分布式预言机分别对应的随机数列表并返回给分布式预言机;通过所述分布式预言机对随机数列表进行多重签名,所述多重签名用于表征随机数列表的数据提供者身份,即来源于哪一个分布式预言机,分布式预言机能保证输出的随机数列表不会被大量篡改,提高了抽奖结果的可信度;在多重签名后,再根据量子加密算法CRYSTALS(代数格密码套件)对所述随机数列表进行密钥封装和签名,以保证所述随机数列表不会被窃取;最后将分装后的随机数列表传输至智能合约,通过所述智能合约根据所述随机数列表生成抽奖结果数据,其中,所述抽奖结果数据中包括中奖用户的数字身份和中奖等级;通过所述智能合约将所述抽奖结果数据存储在联盟链(抽奖结果公开网络)的分布式账本中。
本申请实施例提供了一种基于区块链的抽奖数据处理方法,首先响应于区块链上各节点的抽奖数据上传请求,对抽奖数据进行加密,得到加密抽奖数据,其中,所述区块链至少包括抽奖用户网络、抽奖活动数据网络以及抽奖结果公开网络,所述抽奖数据至少包括所述抽奖用户网络中的用户数据和所述抽奖活动数据网络中的抽奖活动数据,在通过所述区块链中的核验节点对所述加密抽奖数据进行核验,并将通过核验的加密抽奖数据存储至所述区块链,其中,所述区块链至少包括抽奖用户网络、抽奖活动数据网络以及抽奖结果公开网络,另一方面,获取抽奖结果数据对应的用户输入的身份信息,通过所述核验节点对所述身份信息进行身份验证,然后将通过身份验证的身份信息对应的用户数据上传至所述抽奖结果公开网络,本申请实施例的技术方案通过区块链技术实现了对各个流程的抽奖数据分别进行加密、核验以及上链存储,提高了抽奖过程的透明性和可信度,而且通过存储在各个节点的抽奖数据保障了信息的公开性以及不可篡改性,本申请的技术方案中通过抽奖用户网络、抽奖活动数据网络以及抽奖结果公开网络组成整体的区块链网络,满足了对各种类型的抽奖数据分别进行分布式存储的要求,在保证数据使用的同时,通过不同的网络区分开不同的抽奖数据,从而保证了用户数据的隐私性,综上所述,本申请实施例的技术方案提高了抽奖活动方案的透明度和可信度。
实施例二
进一步地,基于本申请第一实施例,在本申请另一实施例中,与上述实施例一相同或相似的内容,可以参考上文介绍,后续不再赘述。在此基础上,在所述通过所述区块链中的核验节点对所述加密抽奖数据进行核验的步骤之前,参照图6,所述方法还包括:
步骤B10,基于所述区块链中各共识节点的总可信度,从各所述共识节点中选取核验节点;
步骤B20,基于各所述共识节点的可信度,删除可信度低于可信度阈值的共识节点。
在本申请实施例中,提供了一种基于节点可信度的核验节点更新方案,由于抽奖数据存储时,数据上链时需要通过核验节点进行核验,所以可以将可信程度最高的节点列为核验节点,负责网络通信。而且因为在多联盟链场景下,当前常用的共识算法的性能已不能完全满足抽奖平台的整体性能要求,在共识过程中通信开销较大,无法满足大规模联盟链下的可扩展性。所以提出一个基于可信度的共识算法,能通过计算核验节点的当总可信度,对核验节点进行更新,提升共识节点的容错能力、减少共识耗时。
作为一种示例,步骤B10至步骤B20包括:通过预设的可信度算法计算所述区块链中各共识节点的总可信度,并选取总可信度最高的公式节点作为核验节点;获取预设的可信度阈值,将各所述共识节点中总可信度低于所述可信度阈值的共识节点删除,以保证区块链中各共识节点的可信度。
进一步地,还提供一种计算共识节点的总可信度的方法,其中,所述基于所述区块链中各共识节点的总可信度,从各所述共识节点中选取核验节点的步骤包括:
步骤B11,根据各所述共识节点的类型、发送的消息、发送消息数以及接收消息数,确定各所述共识节点的当前可信度;
步骤B12,根据各所述共识节点所产生的区块数、作为核验节点的次数以及作为核验节点的时长,确定各所述共识节点的预测可信度;
步骤B13,根据各所述共识节点分别对应的当前可信度和预测可信度,确定各所述共识节点的总可信度;
步骤B14,选取总可信度最高的共识节点作为核验节点。
在本申请实施例中,采用了PBFT(Practical Byzantine Fault Tolerance,使用拜占庭容错)算法来作为区块链中核验节点的更新策略,所述PBFT算法在一个N个节点构成的网络中,不少于2x+1个(x为容错节点数量,x<=(N-1)/3)正常节点工作,即可达成共识。完成一次共识需要复杂度为的数据通信,且在PBFT中所有节点作为主节点的概率相等。为减少一次共识的数据通信次数,降低拜占庭节点作为主节点的概率。本申请实施例在此基础上提出基于节点可信度的核验节点方案TNPBFT(Trusted Node PBFT)。主要理念为从当前可信度、预测可信度来计算阶段的可信程度,将可信程度最高的节点列为核验节点,负责网络通信。
在采用TNPBFT进行核验节点的总可信度计算的过程中,需要先后计算各共识节点的当前可信度以及预测可信度,其中,当前可信度表征所述共识节点在当前的状态下的行为对应的可信度,而所述预测可信度则表征所述共识节点在之前的状态中积累的可信度。具体地,所述共识节点当前可以为核验节点或备份节点,不同的节点类型所对应的当前可信度计算方式不同。
作为一种示例,步骤B11至步骤B14包括:判断所述共识节点的类型时核验节点还是备份节点;若所述共识节点为核验节点,则根据所述核验节点向其他共识节点发送的消息确定所述核验节点的当前可信度;若所述共识节点为备份节点,则根据所述备份节点向区块链内的核验节点发送的确认消息的正确性、正确消息的数量(发送消息数)和接收消息数,计算所述备份节点的当前可信度;通过各所述共识节点在之前的共识过程中产生的区块数、历史作为过核验节点的次数以及作为核验节点的时长,计算各所述共识节点的预测可信度;基于各所述共识节点的当前可信度和预测可信度以及预设的总可信度计算方法,计算各所述共识节点的总可信度。
在一种可行的实施例中,核验节点的当前可信度的计算公式为:
;/>
其中,表示当前信任度,/>表示核验节点发送消息数;/>表示参与共识的节点个数。
在一种可行的实施例中,备份节点的当前可选地的计算公式为:
其中,表示当前信任度;/>表示节点/>在/>轮共识中发送的消息数;/>表示节点/>在/>轮共识中收到的消息数。
在一种可行的实施例中,预测可信度,是对共识节点的历史信息计算,计算的数据维度包括:共识节点作为核验节点时,链上生成的区块数量;节点成为共识节点后,作为核验节点的次数。具体地,共识节点预测可信度的计算公式为:
其中,表示预测信任度,/>表示共识节点产生的区块数;/>表示共识节点作为核验节点的次数,/>表示共识节点作为核验节点的时长。
在一种可行的实施例中,通过当前可信度与预测可信度,来计算共识节点的可信度,并设置可信度阈值,某个节点可信度值低于所述可信度阈值时,从共识节点中剔除。本申请实施例的技术方案可以解决共识节点共同串通勾结的问题。由于可信度由共识节点的行为计算得出,若共识节点间存在串通的问题,在共识过程中,仅发送消息给串通的共识节点,以此办法来提高共识节点的当前可信度,那么可以在共识节点发送的消息数小于(共识节点数-1),那么此共识节点会被判断为存在串通行径,直接剔除。
在本申请实施例中,其中TNPBFT消息交互的通信开销为,而PBFT的消息交互的通信开销为2n(n-1);TNPBFT的容错节点数为1/3(n-1);其中n为节点数,/>为常数,可以通过增加可信度判断的逻辑,降低节点在共识逻辑中的消息交互数量,提高容错节点数,最终更快响应数据存储和分享的请求。
进一步地,所述根据各所述共识节点的类型、发送的消息、发送消息数以及接收消息数,确定各所述共识节点的当前可信度的步骤包括:
步骤B111,当所述共识节点为核验节点时,判断所述核验节点向各共识节点发送的消息是否相同;
步骤B112,若所述核验节点向各共识节点发送的消息相同,则所述核验节点的当前可信度为第一预设值;
步骤B113,若所述核验节点向各共识节点发送的消息不同,则所述核验节点的当前可信度为第二预设值,其中,所述第一预设值大于所述第二预设值;
步骤B114,当所述共识节点为备份节点时,判断所述备份节点向所述核验节点发送的确认消息是否正确;
步骤B115,若所述确认消息正确,则根据所述备份节点的发送消息数和接收消息数,计算所述备份节点的当前可信度;
步骤B116,若所述确认消息错误,则所述备份节点的当前可信度为第二预设值。
在本申请实施例中,具体公开了一种在共识节点属于不同类型时,计算共识节点的当前可信度的方法,其中,核验节点的当前可信度主要取决于发给其他共识节点的消息是否相同,来判断该核验节点的行为是否有作假的可能,而共识节点的当前可信度一方面需要看向核验节点回复的确认消息,如确认消息错误,则可认定存在作假行为,另一方面,如果没有确认消息错误的情况,则根据接收到的消息数和发送消息数来计算当前性,具体地,发送消息数越接近发送消息数,则当前可信度越高,即当共识节点接收到核验节点发送的消息后,响应的消息数越少,当前可信度越高。
在一种可行的实施例中,所述第一预设值为1,所述第二预设值为0。
作为一种示例,步骤B111至步骤B116包括:当所述共识节点为核验节点时,判断所述核验节点向各共识节点发送的消息是否相同;若所述核验节点向各共识节点发送的消息相同,则所述核验节点的当前可信度为1;若所述核验节点向各共识节点发送的消息不同,则所述核验节点的当前可信度为0;当所述共识节点为备份节点时,判断所述备份节点向所述核验节点发送的确认消息是否正确;若所述确认消息正确,则计算所述备份节点的发送消息数与接收消息数的商,得到所述备份节点的当前可信度,所述当前可信度在0-1之间;若所述确认消息错误,则所述备份节点的当前可信度为0。
进一步地,所述根据各所述共识节点分别对应的当前可信度和预测可信度,确定各所述共识节点的总可信度的步骤还可以包括:
步骤B131,根据各所述共识节点分别对应的当前可信度和预测可信度以及所述当前可信度和所述预测可信度分别对应的权重,计算各所述共识节点的总可信度。
本申请实施例中,主要通过预设的当前可信度和预测可信度分别对应的权重来计算共识节点的总可信度,而各权重可以根据经验和实际情况自适应调整,使得总可信度能真实地反映出共识节点的可信程度。
作为一种示例,步骤B131包括:计算各所述共识节点的当前可信度与所述当前可信度的权重之间的积,得到当前可信度权值;计算各所述共识节点的预测可信度与所述预测可信度的权重之间的积,得到预测可信度权值;求所述当前可信度权值与所述预测可信度权值的和,得到各所述共识节点的总可信度。
在一种可行的实施例中,计算总可信度的公式可以为:
其中,,/>分别为当前可信度和预测可信度分别对应的权重,可根据实际情况对应调整,/>为当前信任度,/>为总可信度,/>为预测信任度。
为更好的理解本申请总体流程逻辑,结合本申请实施例与上一申请实施例以下以一总体流程实施例进行说明,参照图7(其中的步骤序号不表示执行顺序),在进行数据上链之前,首先执行步骤1,基于区块链中各共识节点的总可信度选取核验节点并删除可信度低于可信度阈值的共识节点,具体地,步骤1包括步骤2至步骤4,步骤2计算共识节点的当前可信度;步骤3,计算共识节点的预测可信度;步骤4,根据共识节点的当前可信度和预测可信度以及分别对应的权重确定总可信度并选取总可信度最高的共识节点作为核验节点;其中,步骤2中还包括步骤5至步骤6,步骤5,若所述共识节点为核验节点,则根据核验节点向各共识节点发送的消息确定当前可信度;步骤6,若所述共识节点为备份节点,则根据所述备份节点发送的确认消息的准确性、发送消息数和接收消息数确定预测可信度;在核验节点更新完毕后,则执行步骤7,通过核验节点对各节点上传的抽奖数据进行加密和核验,并将核验通过的加密抽奖数据上传至区块链;其中,步骤7包括步骤8至步骤10,步骤8,将加密用户数据分布式存储在边缘存储服务器;步骤9,通过所述边缘存储服务器返回哈希路径值;步骤10,将哈希路径值和秘钥属性加密后存储至抽奖用户网络;步骤11,满足开奖条件时,请求获取随机数列表;步骤12,通过所述量子随机数生成器分别生成每个分布式预言机对应的随机数列表;步骤13,对各所述随机数列表进行秘钥封装和签名,并将封装后的随机数列表传递至智能合约,生成抽奖结果数据;步骤14,获取抽奖结果数据对应的用户输入的身份信息,通过所述核验节点对所述身份信息进行身份验证;具体地,步骤14包括步骤15至步骤17,步骤15,接收用户输入的身份信息;步骤16,对所述身份信息进行哈希计算,获得身份哈希值;步骤17,若所述身份哈希值与用户身份标识一致,则通过核验;步骤18,将通过身份验证的身份信息对应的用户数据上传至抽奖结果公开网络,其中,步骤18包括步骤19至步骤21,步骤19,获取密文存储地址并向边缘存储服务器发送数据请求;步骤20,接收密文数据并对密文数据进行解密;步骤21,将解密后的密文数据上传到抽奖结果公开网络。
本申请实施例中提出了一种区块链核验节点更新基于PBFT的优化方案,基于节点可信度的对核验节点进行更新,使得区块链上的核验节点始终保持较高的可信度,从而也提升了区块链中数据的可信度以及提升数据上链节点更新效率。
实施例三
本申请实施例还提供一种基于区块链的抽奖数据处理装置,所述基于区块链的抽奖数据处理装置应用于基于区块链的抽奖数据处理设备,参照图8,所述基于区块链的抽奖数据处理装置包括:
数据加密模块101,用于响应于区块链上各节点的抽奖数据上传请求,对抽奖数据进行加密,得到加密抽奖数据,其中,所述区块链至少包括抽奖用户网络、抽奖活动数据网络以及抽奖结果公开网络,所述抽奖数据至少包括所述抽奖用户网络中的用户数据和所述抽奖活动数据网络中的抽奖活动数据;
数据核验模块102,用于通过所述区块链中的核验节点对所述加密抽奖数据进行核验,并将通过核验的加密抽奖数据存储至所述区块链;
身份验证模块103,用于获取抽奖结果数据对应的用户输入的身份信息,通过所述核验节点对所述身份信息进行身份验证;
数据公开模块104,用于将通过身份验证的身份信息对应的用户数据上传至所述抽奖结果公开网络。
可选地,所述数据核验模块102还用于:
基于所述区块链中各共识节点的总可信度,从各所述共识节点中选取核验节点;
基于各所述共识节点的可信度,删除可信度低于可信度阈值的共识节点。
可选地,所述数据核验模块102还用于:
根据各所述共识节点的类型、发送的消息、发送消息数以及接收消息数,确定各所述共识节点的当前可信度;
根据各所述共识节点所产生的区块数、作为核验节点的次数以及作为核验节点的时长,确定各所述共识节点的预测可信度;
根据各所述共识节点分别对应的当前可信度和预测可信度,确定各所述共识节点的总可信度;
选取总可信度最高的共识节点作为核验节点。
可选地,所述类型包括核验节点和备份节点,所述数据核验模块102还用于:
当所述共识节点为核验节点时,判断所述核验节点向各共识节点发送的消息是否相同;
若所述核验节点向各共识节点发送的消息相同,则所述核验节点的当前可信度为第一预设值;
若所述核验节点向各共识节点发送的消息不同,则所述核验节点的当前可信度为第二预设值,其中,所述第一预设值大于所述第二预设值;
当所述共识节点为备份节点时,判断所述备份节点向所述核验节点发送的确认消息是否正确;
若所述确认消息正确,则根据所述备份节点的发送消息数和接收消息数,计算所述备份节点的当前可信度;
若所述确认消息错误,则所述备份节点的当前可信度为第二预设值。
可选地,所述数据核验模块102还用于:
根据各所述共识节点分别对应的当前可信度和预测可信度以及所述当前可信度和所述预测可信度分别对应的权重,计算各所述共识节点的总可信度。
可选地,所述加密抽奖数据至少包括加密抽奖数据,所述数据核验模块102还用于:
将通过核验的加密用户数据分布式存储在边缘存储服务器;
通过所述边缘存储服务器返回与所述加密用户数据对应的哈希路径值;
将所述哈希路径值和所述用户数据对应的加密秘钥进行属性加密后存储至所述抽奖用户网络。
可选地,所述区块链中包括活动发行方和数据用户方,所述身份验证模块103还用于:
通过活动发行方向所述抽奖结果数据对应的数据用户方发起授权申请,当所述数据用户方接收到所述授权申请时,获取用户输入的身份信息;
对所述身份信息进行哈希计算,获得身份哈希值;
将所述身份哈希值发送到所述核验节点,通过所述核验节点判断所述用户对应的用户身份标识是否与所述身份哈希值一致;
若是,则所述身份信息通过核验。
可选地,所述数据公开模块104还用于:
通过所述核验节点从所述抽奖用户网络中提取所述身份信息对应的用户数据的密文存储地址;
向所述密文存储地址对应的边缘存储服务器发送数据请求;
通过所述边缘存储服务器响应于所述数据请求,将所述密文存储地址对应的密文数据返回给所述数据用户方;
响应于所述数据用户方的确认指令,将所述密文数据发送至所述活动发行方;
通过所述活动发行方对所述密文数据进行解密,得到所述身份信息对应的用户数据,并将所述用户数据上传到所述抽奖结果公开网络。
可选地,所述基于区块链的抽奖数据处理装置还包括抽奖结果生成模块,所述抽奖结果生成模块用于:
当满足预设的开奖条件时,通过各分布式预言机向量子随机数生成器请求获取随机数列表;
通过所述量子随机数生成器分别生成每个分布式预言机对应的随机数列表;
对各所述随机数列表进行秘钥封装和签名,并将封装后的随机数列表传递至智能合约,以供所述智能合约根据各所述随机数列表生成抽奖结果数据。
本申请提供的基于区块链的抽奖数据处理装置,采用上述实施例中的基于区块链的抽奖数据处理方法,解决了当前的抽奖活动方案的透明性和可信度偏低的技术问题。与现有技术相比,本申请实施例提供的基于区块链的抽奖数据处理装置的有益效果与上述实施例提供的基于区块链的抽奖数据处理方法的有益效果相同,且该基于区块链的抽奖数据处理装置中的其他技术特征与上一实施例方法公开的特征相同,在此不做赘述。
实施例四
本申请实施例提供一种电子设备,电子设备包括:至少一个处理器;以及,与至少一个处理器通信链接的存储器;其中,存储器存储有可被至少一个处理器执行的指令,指令被至少一个处理器执行,以使至少一个处理器能够执行上述实施例一中的基于区块链的抽奖数据处理方法。
下面参考图9,其示出了适于用来实现本公开实施例的电子设备的结构示意图。本公开实施例中的电子设备可以包括但不限于诸如移动电话、笔记本电脑、数字广播接收器、PDA(personal digital assistant,个人数字助理)、PAD(平板电脑)、PMP(Portable MediaPlayer,便携式多媒体播放器)、车载终端(例如车载导航终端)等等的移动终端以及诸如数字TV、台式计算机等等的固定终端。图9示出的电子设备仅仅是一个示例,不应对本公开实施例的功能和使用范围带来任何限制。
如图9所示,电子设备可以包括处理装置1001(例如中央处理器、图形处理器等),其可以根据存储在只读存储器1002(ROM,read only memory)中的程序或者从存储装置1003加载到随机访问存储器1004(RAM,random access memory)中的程序而执行各种适当的动作和处理。在RAM1004中,还存储有电子设备操作所需的各种程序和数据。处理装置1004、ROM1002以及RAM1004通过总线1005彼此相连。输入/输出(I/O)接口1006也链接至总线1005。
通常,以下系统可以链接至I/O接口1006:包括例如触摸屏、触摸板、键盘、鼠标、图像传感器、麦克风、加速度计、陀螺仪等的输入装置1007;包括例如液晶显示器(LCD,liquidcrystal display)、扬声器、振动器等的输出装置1008;包括例如磁带、硬盘等的存储装置1003;以及通信装置1009。通信装置1009可以允许电子设备与其他设备进行无线或有线通信以交换数据。虽然图中示出了具有各种系统的电子设备,但是应理解的是,并不要求实施或具备所有示出的系统。可以替代地实施或具备更多或更少的系统。
特别地,根据本公开的实施例,上文参考流程图描述的过程可以被实现为计算机软件程序。例如,本公开的实施例包括一种计算机程序产品,其包括承载在计算机可读介质上的计算机程序,该计算机程序包含用于执行流程图所示的方法的程序代码。在这样的实施例中,该计算机程序可以通过通信装置从网络上被下载和安装,或者从存储装置被安装,或者从ROM被安装。在该计算机程序被处理装置执行时,执行本公开实施例的方法中限定的上述功能。
本申请提供的电子设备,采用上述实施例中的基于区块链的抽奖数据处理方法,解决了当前的抽奖活动方案的透明性和可信度偏低的技术问题。与现有技术相比,本申请实施例提供的电子设备的有益效果与上述实施例一提供的基于区块链的抽奖数据处理方法的有益效果相同,且该电子设备中的其他技术特征与上一实施例方法公开的特征相同,在此不做赘述。
应当理解,本公开的各部分可以用硬件、软件、固件或它们的组合来实现。在上述实施方式的描述中,具体特征、结构、材料或者特点可以在任何的一个或多个实施例或示例中以合适的方式结合。
以上所述,仅为本申请的具体实施方式,但本申请的保护范围并不局限于此,任何熟悉本技术领域的技术人员在本申请揭露的技术范围内,可轻易想到变化或替换,都应涵盖在本申请的保护范围之内。因此,本申请的保护范围应以所述权利要求的保护范围为准。
实施例五
本实施例提供一种计算机可读存储介质,具有存储在其上的计算机可读程序指令,计算机可读程序指令用于执行上述实施例一中的基于区块链的抽奖数据处理的方法。
本申请实施例提供的计算机可读存储介质例如可以是U盘,但不限于电、磁、光、电磁、红外线、或半导体的系统、系统或器件,或者任意以上的组合。计算机可读存储介质的更具体的例子可以包括但不限于:具有一个或多个导线的电链接、便携式计算机磁盘、硬盘、随机访问存储器(RAM)、只读存储器(ROM)、可擦式可编程只读存储器(EPROM,ErasableProgrammable Read-Only Memory或闪存)、光纤、便携式紧凑磁盘只读存储器(CD-ROM)、光存储器件、磁存储器件、或者上述的任意合适的组合。在本实施例中,计算机可读存储介质可以是任何包含或存储程序的有形介质,该程序可以被指令执行系统、系统或者器件使用或者与其结合使用。计算机可读存储介质上包含的程序代码可以用任何适当的介质传输,包括但不限于:电线、光缆、RF(射频)等等,或者上述的任意合适的组合。
上述计算机可读存储介质可以是电子设备中所包含的;也可以是单独存在,而未装配入电子设备中。
上述计算机可读存储介质承载有一个或者多个程序,当上述一个或者多个程序被电子设备执行时,使得电子设备:响应于区块链上各节点的抽奖数据上传请求,对抽奖数据进行加密,得到加密抽奖数据,其中,所述区块链至少包括抽奖用户网络、抽奖活动数据网络以及抽奖结果公开网络,所述抽奖数据至少包括所述抽奖用户网络中的用户数据和所述抽奖活动数据网络中的抽奖活动数据;通过所述区块链中的核验节点对所述加密抽奖数据进行核验,并将通过核验的加密抽奖数据存储至所述区块链;获取抽奖结果数据对应的用户输入的身份信息,通过所述核验节点对所述身份信息进行身份验证;将通过身份验证的身份信息对应的用户数据上传至所述抽奖结果公开网络。
可以以一种或多种程序设计语言或其组合来编写用于执行本公开的操作的计算机程序代码,上述程序设计语言包括面向对象的程序设计语言—诸如Java、Smalltalk、C++,还包括常规的过程式程序设计语言—诸如“C”语言或类似的程序设计语言。程序代码可以完全地在用户计算机上执行、部分地在用户计算机上执行、作为一个独立的软件包执行、部分在用户计算机上部分在远程计算机上执行、或者完全在远程计算机或服务器上执行。在涉及远程计算机的情形中,远程计算机可以通过任意种类的网络——包括局域网(LAN,local area network)或广域网(WAN,Wide Area Network)—链接到用户计算机,或者,可以链接到外部计算机(例如利用因特网服务提供商来通过因特网链接)。
附图中的流程图和框图,图示了按照本申请各种实施例的系统、方法和计算机程序产品的可能实现的体系架构、功能和操作。在这点上,流程图或框图中的每个方框可以代表一个模块、程序段、或代码的一部分,该模块、程序段、或代码的一部分包含一个或多个用于实现规定的逻辑功能的可执行指令。也应当注意,在有些作为替换的实现中,方框中所标注的功能也可以以不同于附图中所标注的顺序发生。例如,两个接连地表示的方框实际上可以基本并行地执行,它们有时也可以按相反的顺序执行,这依所涉及的功能而定。也要注意的是,框图和/或流程图中的每个方框、以及框图和/或流程图中的方框的组合,可以用执行规定的功能或操作的专用的基于硬件的系统来实现,或者可以用专用硬件与计算机指令的组合来实现。
描述于本公开实施例中所涉及到的模块可以通过软件的方式实现,也可以通过硬件的方式来实现。其中,模块的名称在某种情况下并不构成对该单元本身的限定。
本申请提供的计算机可读存储介质,存储有用于执行上述基于区块链的抽奖数据处理方法的计算机可读程序指令,解决了当前的抽奖活动方案的透明性和可信度偏低的技术问题。与现有技术相比,本申请实施例提供的计算机可读存储介质的有益效果与上述实施例提供的基于区块链的抽奖数据处理方法的有益效果相同,在此不做赘述。
实施例六
本申请还提供一种计算机程序产品,包括计算机程序,所述计算机程序被处理器执行时实现如上述的基于区块链的抽奖数据处理方法的步骤。
本申请提供的计算机程序产品解决了当前的抽奖活动方案的透明性和可信度偏低的技术问题。与现有技术相比,本申请实施例提供的计算机程序产品的有益效果与上述实施例提供的基于区块链的抽奖数据处理方法的有益效果相同,在此不做赘述。
以上仅为本申请的优选实施例,并非因此限制本申请的专利范围,凡是利用本申请说明书及附图内容所作的等效结构或等效流程变换,或直接或间接运用在其他相关的技术领域,均同理包括在本申请的专利处理范围内。

Claims (12)

1.一种基于区块链的抽奖数据处理方法,其特征在于,所述基于区块链的抽奖数据处理方法包括:
响应于区块链上各节点的抽奖数据上传请求,对抽奖数据进行加密,得到加密抽奖数据,其中,所述区块链至少包括抽奖用户网络、抽奖活动数据网络以及抽奖结果公开网络,所述抽奖数据至少包括所述抽奖用户网络中的用户数据和所述抽奖活动数据网络中的抽奖活动数据;
通过所述区块链中的核验节点对所述加密抽奖数据进行核验,并将通过核验的加密抽奖数据存储至所述区块链;
获取抽奖结果数据对应的用户输入的身份信息,通过所述核验节点对所述身份信息进行身份验证;
将通过身份验证的身份信息对应的用户数据上传至所述抽奖结果公开网络。
2.如权利要求1所述基于区块链的抽奖数据处理方法,其特征在于,在所述通过所述区块链中的核验节点对所述加密抽奖数据进行核验的步骤之前,所述方法还包括:
基于所述区块链中各共识节点的总可信度,从各所述共识节点中选取核验节点;
基于各所述共识节点的可信度,删除可信度低于可信度阈值的共识节点。
3.如权利要求2所述基于区块链的抽奖数据处理方法,其特征在于,所述基于所述区块链中各共识节点的总可信度,从各所述共识节点中选取核验节点的步骤包括:
根据各所述共识节点的类型、发送的消息、发送消息数以及接收消息数,确定各所述共识节点的当前可信度;
根据各所述共识节点所产生的区块数、作为核验节点的次数以及作为核验节点的时长,确定各所述共识节点的预测可信度;
根据各所述共识节点分别对应的当前可信度和预测可信度,确定各所述共识节点的总可信度;
选取总可信度最高的共识节点作为核验节点。
4.如权利要求3所述基于区块链的抽奖数据处理方法,其特征在于,所述类型包括核验节点和备份节点,所述根据各所述共识节点的类型、发送的消息、发送消息数以及接收消息数,确定各所述共识节点的当前可信度的步骤包括:
当所述共识节点为核验节点时,判断所述核验节点向各共识节点发送的消息是否相同;
若所述核验节点向各共识节点发送的消息相同,则所述核验节点的当前可信度为第一预设值;
若所述核验节点向各共识节点发送的消息不同,则所述核验节点的当前可信度为第二预设值,其中,所述第一预设值大于所述第二预设值;
当所述共识节点为备份节点时,判断所述备份节点向所述核验节点发送的确认消息是否正确;
若所述确认消息正确,则根据所述备份节点的发送消息数和接收消息数,计算所述备份节点的当前可信度;
若所述确认消息错误,则所述备份节点的当前可信度为第二预设值。
5.如权利要求3所述基于区块链的抽奖数据处理方法,其特征在于,所述根据各所述共识节点分别对应的当前可信度和预测可信度,确定各所述共识节点的总可信度的步骤包括:
根据各所述共识节点分别对应的当前可信度和预测可信度以及所述当前可信度和所述预测可信度分别对应的权重,计算各所述共识节点的总可信度。
6.如权利要求1所述基于区块链的抽奖数据处理方法,其特征在于,所述加密抽奖数据至少包括加密抽奖数据,所述将通过核验的加密抽奖数据存储至所述区块链的步骤包括:
将通过核验的加密用户数据分布式存储在边缘存储服务器;
通过所述边缘存储服务器返回与所述加密用户数据对应的哈希路径值;
将所述哈希路径值和所述用户数据对应的加密秘钥进行属性加密后存储至所述抽奖用户网络。
7.如权利要求1所述基于区块链的抽奖数据处理方法,其特征在于,所述区块链中包括活动发行方和数据用户方,所述获取抽奖结果数据对应的用户输入的身份信息,通过所述核验节点对所述身份信息进行身份验证的步骤包括:
通过活动发行方向所述抽奖结果数据对应的数据用户方发起授权申请,当所述数据用户方接收到所述授权申请时,获取用户输入的身份信息;
对所述身份信息进行哈希计算,获得身份哈希值;
将所述身份哈希值发送到所述核验节点,通过所述核验节点判断所述用户对应的用户身份标识是否与所述身份哈希值一致;
若是,则所述身份信息通过核验。
8.如权利要求7所述基于区块链的抽奖数据处理方法,其特征在于,所述将通过身份验证的身份信息对应的用户数据上传至所述抽奖结果公开网络的步骤包括:
通过所述核验节点从所述抽奖用户网络中提取所述身份信息对应的用户数据的密文存储地址;
向所述密文存储地址对应的边缘存储服务器发送数据请求;
通过所述边缘存储服务器响应于所述数据请求,将所述密文存储地址对应的密文数据返回给所述数据用户方;
响应于所述数据用户方的确认指令,将所述密文数据发送至所述活动发行方;
通过所述活动发行方对所述密文数据进行解密,得到所述身份信息对应的用户数据,并将所述用户数据上传到所述抽奖结果公开网络。
9.如权利要求1-8任一项所述的基于区块链的抽奖数据处理方法,其特征在于,所述基于区块链的抽奖数据处理方法还包括:
当满足预设的开奖条件时,通过各分布式预言机向量子随机数生成器请求获取随机数列表;
通过所述量子随机数生成器分别生成每个分布式预言机对应的随机数列表;
对各所述随机数列表进行秘钥封装和签名,并将封装后的随机数列表传递至智能合约,以供所述智能合约根据各所述随机数列表生成抽奖结果数据。
10.一种基于区块链的抽奖数据处理装置,其特征在于,所述基于区块链的抽奖数据处理装置包括:
数据加密模块,用于响应于区块链上各节点的抽奖数据上传请求,对抽奖数据进行加密,得到加密抽奖数据,其中,所述区块链至少包括抽奖用户网络、抽奖活动数据网络以及抽奖结果公开网络,所述抽奖数据至少包括所述抽奖用户网络中的用户数据和所述抽奖活动数据网络中的抽奖活动数据;
数据核验模块,用于通过所述区块链中的核验节点对所述加密抽奖数据进行核验,并将通过核验的加密抽奖数据存储至所述区块链;
身份验证模块,用于获取抽奖结果数据对应的用户输入的身份信息,通过所述核验节点对所述身份信息进行身份验证;
数据公开模块,用于将通过身份验证的身份信息对应的用户数据上传至所述抽奖结果公开网络。
11.一种电子设备,其特征在于,所述电子设备包括:
至少一个处理器;以及,
与所述至少一个处理器通信链接的存储器;其中,
所述存储器存储有可被所述至少一个处理器执行的指令,所述指令被所述至少一个处理器执行,以使所述至少一个处理器能够执行权利要求1至9中任一项所述的基于区块链的抽奖数据处理方法的步骤。
12.一种计算机可读存储介质,其特征在于,所述计算机可读存储介质上存储有实现基于区块链的抽奖数据处理方法的程序,所述实现基于区块链的抽奖数据处理方法的程序被处理器执行以实现如权利要求1至9中任一项所述基于区块链的抽奖数据处理方法的步骤。
CN202311103061.6A 2023-08-29 2023-08-29 基于区块链的抽奖数据处理方法、装置、电子设备及介质 Pending CN117454439A (zh)

Priority Applications (1)

Application Number Priority Date Filing Date Title
CN202311103061.6A CN117454439A (zh) 2023-08-29 2023-08-29 基于区块链的抽奖数据处理方法、装置、电子设备及介质

Applications Claiming Priority (1)

Application Number Priority Date Filing Date Title
CN202311103061.6A CN117454439A (zh) 2023-08-29 2023-08-29 基于区块链的抽奖数据处理方法、装置、电子设备及介质

Publications (1)

Publication Number Publication Date
CN117454439A true CN117454439A (zh) 2024-01-26

Family

ID=89582442

Family Applications (1)

Application Number Title Priority Date Filing Date
CN202311103061.6A Pending CN117454439A (zh) 2023-08-29 2023-08-29 基于区块链的抽奖数据处理方法、装置、电子设备及介质

Country Status (1)

Country Link
CN (1) CN117454439A (zh)

Similar Documents

Publication Publication Date Title
EP4120114A1 (en) Data processing method and apparatus, smart device and storage medium
Leng et al. Blockchain security: A survey of techniques and research directions
CN112232527B (zh) 安全的分布式联邦深度学习方法
KR102145701B1 (ko) 안전한 다자 계산에서 참가자에 의한 입력 데이터의 허위 표시 방지
EP3070630A2 (en) Data system and method
CN112132198A (zh) 数据处理方法、装置、系统和服务器
US11921884B2 (en) Techniques for preventing collusion using simultaneous key release
CN109361508A (zh) 数据传输方法、电子设备及计算机可读存储介质
WO2021169767A1 (zh) 一种数据处理方法、装置、设备及介质
US20220278845A1 (en) Honest behavior enforcement via blockchain
CN113486122A (zh) 数据共享方法和电子设备
CN114866323A (zh) 一种用户可控的隐私数据授权共享系统及方法
Abubaker et al. Trustful data trading through monetizing IoT data using BlockChain based review system
CN112765642A (zh) 数据处理方法、数据处理装置、电子设备及介质
Gao et al. BFR‐SE: A Blockchain‐Based Fair and Reliable Searchable Encryption Scheme for IoT with Fine‐Grained Access Control in Cloud Environment
CN113869901B (zh) 密钥生成方法、装置、计算机可读存储介质及计算机设备
CN115953244A (zh) 基于区块链的交易监管方法、装置、电子设备和存储介质
CN115908001A (zh) 基于区块链的交易监管方法、装置、电子设备和存储介质
CN111125734B (zh) 一种数据处理方法及系统
CN115150151A (zh) 基于区块链的数据管理系统、方法、装置及存储介质
CN117454439A (zh) 基于区块链的抽奖数据处理方法、装置、电子设备及介质
CN114666064A (zh) 基于区块链的数字资产管理方法、装置、存储介质及设备
CN114418769A (zh) 一种区块链交易计费方法、装置及可读存储介质
CN116264860A (zh) 广播内容的阈值加密
CN116095671B (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