CN109450910A - Data sharing method, data sharing network and electronic equipment based on block chain - Google Patents

Data sharing method, data sharing network and electronic equipment based on block chain Download PDF

Info

Publication number
CN109450910A
CN109450910A CN201811420021.3A CN201811420021A CN109450910A CN 109450910 A CN109450910 A CN 109450910A CN 201811420021 A CN201811420021 A CN 201811420021A CN 109450910 A CN109450910 A CN 109450910A
Authority
CN
China
Prior art keywords
data
user node
access
node
access request
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
Application number
CN201811420021.3A
Other languages
Chinese (zh)
Other versions
CN109450910B (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.)
Yuanguang Software Co Ltd
Original Assignee
Yuanguang Software Co Ltd
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 Yuanguang Software Co Ltd filed Critical Yuanguang Software Co Ltd
Priority to CN201811420021.3A priority Critical patent/CN109450910B/en
Publication of CN109450910A publication Critical patent/CN109450910A/en
Application granted granted Critical
Publication of CN109450910B publication Critical patent/CN109450910B/en
Active legal-status Critical Current
Anticipated expiration legal-status Critical

Links

Classifications

    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L63/00Network architectures or network communication protocols for network security
    • H04L63/08Network architectures or network communication protocols for network security for authentication of entities
    • H04L63/0807Network architectures or network communication protocols for network security for authentication of entities using tickets, e.g. Kerberos
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L63/00Network architectures or network communication protocols for network security
    • H04L63/04Network architectures or network communication protocols for network security for providing a confidential data exchange among entities communicating through data packet networks
    • H04L63/0428Network 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
    • H04L63/0442Network 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 wherein the sending and receiving network entities apply asymmetric encryption, i.e. different keys for encryption and decryption
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L63/00Network architectures or network communication protocols for network security
    • H04L63/08Network architectures or network communication protocols for network security for authentication of entities
    • H04L63/0876Network architectures or network communication protocols for network security for authentication of entities based on the identity of the terminal or configuration, e.g. MAC address, hardware or software configuration or device fingerprint
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L63/00Network architectures or network communication protocols for network security
    • H04L63/10Network architectures or network communication protocols for network security for controlling access to devices or network resources
    • H04L63/102Entity profiles
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L67/00Network arrangements or protocols for supporting network services or applications
    • H04L67/01Protocols
    • H04L67/10Protocols in which an application is distributed across nodes in the network
    • H04L67/1097Protocols in which an application is distributed across nodes in the network for distributed storage of data in networks, e.g. transport arrangements for network file system [NFS], storage area networks [SAN] or network attached storage [NAS]

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)
  • Power Engineering (AREA)
  • Storage Device Security (AREA)

Abstract

This application discloses a kind of data sharing method based on block chain, data sharing network and electronic equipments.Data sharing method includes the first access request that the first user node corresponds to data to be visited to the broadcast of block chain;It submits node to be based on the first access request and generates corresponding shared token, and shared token is fed back into the first user node;First user node initiates the second access request to second user node corresponding with data to be visited using shared token and access mandate contract;Second user node is based on shared token and verifies to the first access request, and assesses access mandate contract, obtains assessment result;First user node accesses data to be visited according to access mandate contract when assessment result is that access mandate contract passes through assessment.The safety and compliance that data circulate in block chain network are improved through the above way.

Description

Data sharing method based on block chain, data sharing network and electronic equipment
Technical Field
The present application relates to the field of blockchain technologies, and in particular, to a data sharing method, a data sharing network, and an electronic device based on a blockchain.
Background
The block chain technology is a novel application technology set of computer technologies such as distributed data storage, point-to-point transmission, a consensus mechanism, an encryption algorithm and the like. From the data perspective, the block chain combines the data blocks in a sequential connection mode into a chain data structure according to the time sequence, and the data structure is guaranteed to be not falsifiable and not to be forged in a cryptographic mode. From a technical perspective, the blockchain technology integrates a plurality of different technologies, and by constructing a blockchain network, each node in the network is allowed to obtain a complete copy of a data block, and updates of the blockchain-based data blocks are maintained based on a consensus mechanism and competition calculation. Therefore, the decentralization and the distrust of data storage and management are realized through an end-to-end network formed by multi-node communication.
With the continuous maturity of the cloud computing platform, the audit service is gradually changed from the traditional audit mode to the cloud audit mode, the cloud audit changes the problem that the traditional audit has a problem of post audit on economic activities, and the reason for generating the audit result is more concerned. Under the environment of a cloud computing platform, auditing mechanisms in different regions can implement auditing services in a cross-time and cross-space mode, and auditors can perform the operation of the auditing services through the Internet at any time and any place. The auditing program of the cloud computing platform is provided, maintained and upgraded by a special cloud software provider, has homology, can improve standardization and normalization of auditing data, accelerates data screening and processing, and reduces data analysis difficulty and auditing difficulty.
However, cloud auditing also faces challenges from external security issues within the audit data while providing convenience for auditing services. At present, audit data are collected by auditing objects by each stationing mechanism, and then are uploaded to a central cloud database in a unified manner for centralized management. In addition, when the audit data is uploaded to a cloud database and called by a plurality of organizations, the transmission of the audit data is not highly encrypted and is easy to crack by hackers, so that the data is leaked, and the situations of unauthorized and private abuse, copying and even selling of the audit data occur.
Disclosure of Invention
The technical problem mainly solved by the application is to provide a data sharing method based on a block chain, a data sharing network and electronic equipment.
In order to solve the above problem, a first aspect of the present application provides a data sharing method based on a block chain, where the data sharing method includes:
a first user node broadcasts a first access request corresponding to data to be accessed to a blockchain;
the submitting node generates a corresponding sharing token based on the first access request and feeds the sharing token back to the first user node;
the first user node initiates a second access request to a second user node corresponding to the data to be accessed by utilizing the sharing token and the access authorization contract;
the second user node verifies the first access request based on the shared token and evaluates the access authorization contract to obtain an evaluation result;
and when the evaluation result is that the access authorization contract passes the evaluation, the first user node accesses the data to be accessed according to the access authorization contract.
In order to solve the above problem, a second aspect of the present application provides a data sharing network based on a block chain, the data sharing network including a first user node, a second user node, and a commit node, which communicate with each other; the first user node, the second user node and the submitting node are respectively used for executing corresponding steps in the data sharing method.
In order to solve the above-mentioned problems, a third aspect of the present application provides an electronic device comprising a memory and a processor connected to each other, wherein,
the memory is used for storing computer instructions executed by the processor;
the processor is configured to execute the computer instructions stored in the memory to implement the corresponding steps executed by the first user node, the second user node, or the submitting node in the data sharing method.
In the scheme, the data sharing method based on the block chain broadcasts the transaction corresponding to the data access to the whole network through the first user node, so that the submitting node authenticates the first user node according to the broadcasted data access and forms a sharing token to determine the data access; and then the first user node can operate to carry the sharing token to initiate a data access request to the second user node, after the second user node verifies and evaluates the transaction, and after the first user node is allowed to access the data according to the evaluation result, the first user node can access the data of the second user node, so that the safety and the compliance of data circulation in the block chain network are improved.
Drawings
FIG. 1 is a block chain platform infrastructure architecture of the present application;
FIG. 2 is a block diagram of a block chain used in an embodiment of the present application;
FIG. 3 is a block diagram of an embodiment of a data processing network according to the present application;
FIG. 4 is a schematic flow chart diagram of a first embodiment of the data processing method of the present application;
FIG. 5 is a schematic flow chart diagram illustrating one embodiment of step S12 in FIG. 4;
FIG. 6 is a block chain cloud audit platform infrastructure architecture diagram according to the present application;
FIG. 7 is a schematic block diagram of an embodiment of a data storage network of the present application;
FIG. 8 is a schematic flow chart diagram illustrating a first embodiment of the data storage method of the present application;
FIG. 9 is a schematic flow chart diagram illustrating one embodiment of step S21 of FIG. 8;
FIG. 10 is a schematic flow chart diagram illustrating a second embodiment of the data storage method of the present application;
FIG. 11 is a flowchart illustrating a first embodiment of a data sharing method according to the present application;
FIG. 12 is a schematic flow chart diagram illustrating one embodiment of step S42 of FIG. 11;
FIG. 13 is a schematic flow chart diagram illustrating one embodiment of step S44 of FIG. 11;
FIG. 14 is a schematic flow chart diagram illustrating one embodiment of step S444 of FIG. 13;
FIG. 15 is a flowchart illustrating a data sharing method according to a second embodiment of the present application;
FIG. 16 is a schematic structural diagram of an embodiment of an electronic device of the present application;
FIG. 17 is a schematic structural diagram of an embodiment of a storage medium according to the present application.
Detailed Description
The following describes in detail the embodiments of the present application with reference to the drawings attached hereto.
In the following description, for purposes of explanation and not limitation, specific details are set forth such as particular system structures, interfaces, techniques, etc. in order to provide a thorough understanding of the present application.
The terms "system" and "network" are often used interchangeably herein. The term "and/or" herein is merely an association describing an associated object, meaning that three relationships may exist, e.g., a and/or B, may mean: a exists alone, A and B exist simultaneously, and B exists alone. In addition, the character "/" herein generally indicates that the former and latter related objects are in an "or" relationship.
The block chain technology is a novel distributed data organization method and an operation mode which are developed along with digital encryption currencies such as bitcoin and the like. The method is characterized in that: decentralization enables the data to realize distributed collective maintenance, and greatly improves the efficiency of data operation, management and maintenance; the consensus nodes are based on a set of consensus mechanism, the whole block chain is maintained together through competition calculation, any node fails, and other nodes can still work normally. Meanwhile, the block chain carrying the asymmetric encryption technology has high safety and traceability, and can effectively prevent data leakage or illegal tampering. The application provides a block chain technology combined with a cloud computing platform to realize data storage, processing and sharing, the data can be audit data, accounting data, transaction data and the like, and the application takes the audit data as an example for explanation.
To facilitate understanding of the blockchain network of the present application, the blockchain technique employed in the present application is first exemplified. In one embodiment, the electronic device runs the blockchain technique to become a node of the blockchain network, and the blockchain platform infrastructure is shown in fig. 1 and includes a data layer, a network layer, a consensus layer, a contract layer, a service layer, an application layer, and a presentation layer of the blockchain.
The blockchain data layer is used for encapsulating the underlying data blocks and related data encryption and time stamping technologies. Also, at least one (e.g., two) computations may be performed on the file data using an irreversible encryption algorithm (e.g., SHA256 algorithm) to generate a unique blockchain ID, i.e., a Hash (Hash) value. Specifically, the blockchain may be a blockchain, ensuring that the blockchain is not fully public and only accessible to registered member nodes.
And the network layer encapsulates elements such as a P2P networking mode, a message propagation protocol, a data verification mechanism and the like of the blockchain network system, so that the nodes are equal in status and mutually communicated in a flat topological structure, and the characteristics of distribution, autonomy, openness, free access and the like are possessed. Each node in the block chain network can participate in the checking and accounting process of the block data, and the block chain can be recorded only after the block data passes verification of most nodes in the whole network. The decentralized design of the block chain ensures that the file data cannot be tampered and forged.
And the consensus layer encapsulates a method for rapidly completing consensus in a topological network with highly dispersed decision weights so as to participate in a consensus mechanism of the block chain network.
The contract layer encapsulates contract codes with data access strategies, automatically executes corresponding transactions when conditions in the contract codes are triggered, and simultaneously can access corresponding data through corresponding access conditions specified by contract contents.
And the service layer is used for effectively integrating and managing the related functions of the application through the distributed server, such as user registration, user identity management, encryption and decryption service, distributed book service, intelligent contract service, data management service and the like.
The application layer is used for displaying specific functions of the block chain network, is an important link for data storage and sharing, and can be divided into user management, authority control, resource directory management and the like according to different functions.
And each data main body can log in an interface displayed by the corresponding presentation layer through a system client to access the application layer so as to acquire information resources, including a registration interface, an operation execution interface, a query interface, an application management interface, an administrator interface and the like.
The blockchain network collects, packages and securely protects archive file related information data such as archive file related identification, archive file lending information, and archive file returning information in a decentralized manner, and anchors the information data to the blockchain. In particular, the blockchain may be implemented using a network of blockfederation chains or blockchain private chains. The nodes of the block chain continuously change the responsibility born by the network system, and only one node can never control the whole network system, namely only one accounting node can not carry out accounting. Each node is only part of the network system. The node timing of the blockchain changes roles, e.g., once every minute, and no node will permanently control any part of the network system.
In one embodiment, the block encapsulation of the data layer of the block chain may be as shown in fig. 2. The block of the blockchain includes a block Header 21(Header) and a block Body 22 (Body). The block 22 stores at least one Hash value (Hash) obtained by performing a Hash operation on data related to the execution service. The block header 21 may be packaged with information such as a current version number 211, a previous block address 212, a target hash value 213 of the current block, a solution random number 214 of a PoW (workload proof) consensus process of the current block, a Merkle root 215(Merkle-root), and a timestamp 216. Wherein, the current version number 211 is used for marking the relevant version information of software and protocol; the previous block address 212, which may also be referred to as a previous block hash value, by which each block is concatenated end to form a chain of blocks; the solution random number 214 is a value of the answer to record the decrypted block-related mathematical question; the Merkle root 215 is computed from all hash values of the data in the block 22 to verify whether the associated data exists in the block; the timestamp 216 is used to record the time when the block 20 was generated. It is understood that the structure of the block can be adjusted according to the block chain technique, for example, if the consensus process does not use the Pow consensus mechanism, the random number solution does not exist.
In one embodiment, the Block chain underlying system may be comprised of hierarchically structured blocks (blocks). The root is a Directory Block (Directory Block). These blocks form a mini chain, on which compressed references (references) are stored. In order to avoid the data size being too large, the reference in the Directory Block (Directory Block) is only the hash value of the recording Block (Entry Block).
The directory block corresponds to the first layer of the system and records the integrity (Hash value) proof block of the recording block. The directory block is created by combining all the recording blocks defined in all the servers together. Thus, each server has all recording blocks, all directory blocks, and all records (entries).
The recording Block (Entry Block) corresponds to the second layer of the system and is a Block for recording an Entry integrity (Hash value) certificate. The application seeking the record may need the record block, and the record of storing, processing, sharing, accessing and the like of all the possibly related data can be searched from one digital fingerprint. The recording block contains the electronically recorded hash value. The electronically recorded hash value simultaneously proves the existence of the data and the key to find the record in a Distributed Hash Table (DHT) network.
The recording Block (Entry Block) contains all entries associated with one chain ID. An Entry may be considered not to exist if it is associated to a recording Block (Entry Block). The design can ensure that the application program can be easily certified and can conveniently identify which entries are real and reliable.
Referring to fig. 3, fig. 3 is a schematic structural diagram of a data processing network based on a block chain according to an embodiment of the present application. As shown in fig. 3, the data processing network 30 of the present embodiment is a blockchain network 31, wherein the data processing network 30 at least includes a user node 311, an accounting node 312 and a submitting node 313.
In an embodiment, the user node may correspond to various organization nodes related to auditing activities, such as an auditing organization, an audited unit, a tax organization, a bank, and the like. The user node corresponding to the audited unit can generate corresponding audit data based on the economic activity of the user node, and the audit data is stored in the block chain; the user node corresponding to the auditing unit can acquire the auditing data from the block chain and perform corresponding auditing operation on the auditing data, so as to generate new auditing data such as an auditing evaluation report, an auditing comment book, an auditing work manuscript and the like for auditing the audited unit, and store the new auditing data in the block chain; other user nodes such as tax agencies and banks can access and check various audit data generated by the auditing agencies and audited agencies based on the block chain. Therefore, the user node 311 is divided into a first user node 311a corresponding to an auditing agency and a second user node 311b corresponding to an audited unit according to the specific identity information of the user node 311.
Further, authoritative institution nodes such as financial institutions, regulatory agencies, etc. may be added to the blockchain as billing nodes 312. The accounting nodes 312 can perform accounting of the blockchain network, each accounting node 312 is a node having competitive accounting capability to store related information and data of transactions related to audit data generated by user nodes, such as storage, processing, addition, modification, access and the like, and each accounting node 312 stores transaction information related to audit data generated by user nodes, so that distributed storage of transaction information related to audit data generated by each user node is realized. Further, in this embodiment, the user node 311 corresponding to the auditing mechanism and the audited unit may also be reused as the accounting node 312 in the blockchain network 31 to perform the above accounting operation.
The blockchain network 31 may further include a management node 314, configured to perform identity registration for the user node 311, the accounting node 312, and the submitting node 313, and manage various auditing service functions such as identity information and data sharing policies of the user node 311, the accounting node 312, and the submitting node 313. In the present application, the management node 314 may be configured to correspond to a Certificate Authority (Certificate Authority), and when joining the blockchain network 31, the user node 311, the accounting node 312, and the submitting node 313 initiate a registration request to the Certificate Authority, and the Certificate Authority provides a digital Certificate capable of indicating identity information of the node to the corresponding node based on the registration request, where the digital Certificate may include a public key and a private key allocated to the node. After obtaining the distributed public key and private key, the node applying for registration stores the private key locally, and broadcasts the public key to the blockchain network 31.
The user node 311, the billing node 312, the submitting node 313, and the management node 314 may be any electronic device, such as a server, a mobile phone, a computer, a tablet computer, and the like, and in an embodiment, the billing node 312 is a blockchain server, and the management node 314 is an application server with a service processing capability, and may be used as a bankbook system based on a blockchain network. It is to be understood that the user node 311, the accounting node 312, the submitting node 313 and the management node 314 are communicable, the user node 311 and the management node 314 in this embodiment are regarded as blockchain nodes, for example, as lightweight accounting nodes of a blockchain, but in other embodiments, the user node 311 and the management node 314 are not limited to be blockchain nodes, that is, at least part of the user node 311 and the management node 314 do not necessarily participate in the blockchain. In addition, the distinction of the nodes is determined according to the identity information registered by the nodes. Therefore, corresponding entities of the nodes, such as an auditing organization, an audited unit, a tax administration, a bank, a financial institution, a supervision organization and the like, need to complete registration in advance on a block chain platform (in an application, the block chain is a block private chain or a block alliance chain, and the story completes identity registration on the block chain platform in advance), acquire corresponding public keys and private keys, and allow the following data processing services to be developed after the identity is determined to be trusted.
The blockchain network of this embodiment is exemplified by a alliance-chain network or a private-chain network, that is, when a node joins the blockchain network, an identity information registration needs to be performed, and only a member node of the registered identity information can access the blockchain network.
Referring to fig. 4, fig. 4 is a flowchart illustrating a block chain-based data processing method according to a first embodiment of the present application. The data processing method of this embodiment may be applied to the block chain network shown in fig. 3, and as shown in fig. 4, the data processing method of this embodiment may include the following steps:
in step S11, the first user node divides the data it generates into the first kind of data and the second kind of data according to the data content; storing the first type of data in a blockchain; and encrypting the second type of data by using the private key of the user to form a corresponding second type of data ciphertext, and sending the second type of data ciphertext to the second user node.
In this embodiment, data is taken as an example for explanation, and with reference to the blockchain network 30 shown in fig. 3, a user node corresponding to an auditing mechanism and a user node corresponding to an audited unit are both collectively referred to as a user node, and according to different identities, the user node corresponding to the auditing mechanism is taken as a first user node, and the user node corresponding to the audited unit is taken as a second user node.
The second user node generates corresponding audit data including financial reports, financial statements and the like which need to be audited when economic activities occur, and in the audit process, the second user node encrypts the generated audit data by using a private key of the second user node and uploads the encrypted audit data to a block chain for storage; at this time, when the auditing unit of the first user node and/or other user nodes want to access the auditing data, the second user node needs to approve the auditing unit. In other words, the ownership of the audit data is the second user node, the second user node may set a corresponding data access policy for the audit data uploaded thereon, when the first user node and/or other user nodes need to access the audit data, an access request needs to be initiated to the second user node, and the audit data can be accessed according to the data access policy set by the second user node after being approved by the second user node. Further, the first user node can acquire the audit data from the block chain and perform corresponding audit operation on the audit data, so as to generate new audit data including an audit evaluation report, an audit suggestion book, an audit work draft and the like. The new audit data are all generated by the first user node, and when the first user node transmits the new audit data to the block chain for storage, the new audit data are encrypted by using a private key of the first user node, in other words, the ownership of the new audit data is the first user node. However, the data content of the new audit data such as the audit evaluation report and the audit opinion book generated based on the audit data generated by the second user node in the new audit data corresponds to the second user node, that is, the access of the part of data needs to be performed based on the data access policy set by the second user node, but the access of the part of data by other user nodes is very inconvenient because the access of the part of data by the other user nodes needs to be approved by the first user node.
In the embodiment, after the first user node generates new audit data including an audit evaluation report, an audit opinion book, an audit work draft and the like, the generated new audit data is divided into first-class data and second-class data according to data content; the first type of data is audit data of a first user node corresponding to data contents such as an audit work draft, and other user nodes can access the first type of data only by approval of the first user node; the second type of data is audit data of which the data contents such as the audit evaluation report and the audit opinion book correspond to the second user node, and the part of the audit data needs to be accessed based on a data access strategy set by the second user node.
In this embodiment, the first user node encrypts the first type of data whose data content corresponds to its own private key, and stores the encrypted first type of data in the block chain. And for the second type of data, the first user node encrypts the second type of data by using the private key of the first user node to form a corresponding second type of data ciphertext and sends the second type of data ciphertext to the second user node.
In step S12, the second user node transfers ownership of the second type of data from the first user node to the second user node based on the second type of data ciphertext.
In this embodiment, the second user node receives the second type data ciphertext, that is, the second type data ciphertext can be decrypted by using the public key of the first user node, so as to obtain the corresponding second type data, and further transfer ownership of the second type data to the second user node.
Further, referring to fig. 5, as shown in fig. 5, the step S12 may include the following steps:
in step S121, the second user node decrypts the second-class data ciphertext by using the public key of the first user node, so as to obtain the second-class data.
The public key of the first user node is broadcasted to the block chain, that is, any node in the block chain can obtain the public key of the first user node. In this embodiment, after receiving the second-type data ciphertext, the second user node may decrypt the second-type data ciphertext by using the obtained public key of the first user node, thereby obtaining corresponding second-type data.
In step S122, the second type data is encrypted again using its own private key, and the second type data that is encrypted again is stored in the blockchain.
The second user node further encrypts the second type of data again by using the private key of the second user node, and stores the second type of data encrypted by the private key of the second user node in the block chain. It can be understood that, at this time, the second type data is encrypted by the private key of the second user node, in other words, other user nodes need to decrypt the second type data by using the public key of the second user node, that is, ownership of the second type data is transferred to the second user node. At this time, when other user nodes need to access the second type of data, an access request needs to be sent to the second user node, and the second type of data can be accessed according to the corresponding data access strategy after the approval of the second user node.
In the embodiment, the ownership of the second type data is transferred through the encrypted transfer of the second type data private key, so that when other user nodes need to access the second type data, only an access request needs to be sent to the corresponding user nodes with ownership, and the process of accessing the second type data by other user nodes is simplified.
Further, the present application combines with a cloud technology, and based on the block chain Platform Infrastructure shown in fig. 1, a block chain cloud audit Platform Infrastructure is also provided, as shown in fig. 6, the block chain cloud audit Platform Infrastructure of the present application combines with a basic Service mode of a cloud computing Platform, that is, Infrastructure as a Service (IaaS), Platform as a Service (PaaS, Platform as a Service), and Software as a Service (SaaS, Software as a Service), on the basis of the block chain Platform Infrastructure shown in fig. 1; the IaaS service continuously collects mass audit data of audited units in various places to a cloud database through various modes such as a standard data interface and offline uploading, and performs primary unified classification, screening, storage and access control on the data according to different audit apertures; the structured data and the unstructured data are encapsulated in hardware equipment so as to be conveniently accessed remotely by an auditing agency; the PaaS service is used for implementing fine management on audit data stored in the IaaS layer, and various analysis and visualization components are packaged according to specific audit business requirements, so that an audit organization can be facilitated to independently construct various audit business processes, and the audit efficiency is improved; the SaaS service is used for further packaging and storing audit output of the IaaS service and the PaaS service, not only is the functions of acquiring, analyzing, exchanging and the like of audit data completely deployed at the cloud end, but also the formed audit method and model, audit case, audit training and other resources are further stored, and more accurate value mining is achieved.
In addition, the basic architecture of the block chain platform in the block chain cloud audit platform basic architecture of the present application is basically the same as the block chain platform basic architecture shown in fig. 1, and the difference lies in that the data layer further includes a cloud database, and the cloud database is used for storing massive audit data so as to conveniently perform multidimensional data processing and implement data services with complex logic.
Further, referring to fig. 7, fig. 7 is a block chain cloud auditing system provided in the present application based on the block chain network shown in fig. 3 to form a data storage network 40 based on a block chain, that is, based on the block chain network 31 shown in fig. 3, the data storage network further includes a cloud database 32, and each node on the side of the block chain network 31 is shown in fig. 3, which is not described herein again. The blockchain network 31 and the cloud database 32 may perform data interaction with each other, and the user node 311 may directly store data generated or obtained by the user node in the cloud database 32.
It is understood that the first embodiment of the data processing method shown in fig. 4 to fig. 5 may also be applied to the blockchain cloud auditing system shown in fig. 7, where each node is configured with the blockchain cloud auditing platform infrastructure shown in fig. 6.
Referring to fig. 8, fig. 8 is a schematic flowchart of a first embodiment of the data storage method based on a block chain according to the present application, where the data storage method according to the present embodiment is applicable to the data storage network 40 based on a block chain shown in fig. 7, and each node is configured with the block chain cloud audit platform infrastructure shown in fig. 6. The present embodiment takes the first user node storing the first type data in the block chain as an example. As shown in fig. 8, the data storage method of this embodiment may at least include the following steps:
in step S21, the first user node screens out the sensitive data from the first type of data by using the preset sensitive field, and stores the sensitive data in the block chain.
The first user node acquires first-class data, the data content of which corresponds to the first user node and can be stored in the block chain after being encrypted by a private key of the first user node, further, corresponding sensitive data is screened out from the first-class data according to a sensitive field set by a user, and the screened sensitive data is stored in the block chain.
In this embodiment, the sensitive fields may be set by a user as required, and in this embodiment, the first type of data is audit data, and the corresponding sensitive fields may be set according to an audit part or an audited unit, an audit data keyword, and the like, including money amount, an economic activity name, an important financial statement, and the like, and data matched with the sensitive fields in the first type of data is screened out to be stored as sensitive data and in a block chain.
Further, referring to fig. 9, the storing of the sensitive data in the blockchain performed in step S21 may include the following steps:
in step S211, the first user node divides the sensitive data into a first type of sensitive data and a second type of sensitive data according to the data structure type.
In this embodiment, the sensitive data is divided into a first type of sensitive data and a second type of sensitive data according to the data structure type, specifically, the data structure type of the first type of sensitive data is structured data, and the data structure type of the second type of sensitive data is unstructured data. It can be understood that the structured data is usually structured data generated by a financial management system of a user node, which is generated by auditing data by an auditing unit, an auditing agency and the like, and is usually data such as characters, tables and the like which can be represented through a corresponding data structure, and the data capacity of the structured data is relatively small and is relatively easy to arrange and process. The unstructured data is specific audit data which is generated based on economic activities of a big data platform under big data development, has huge scale, is tedious, grows at any time, has low value density and the like, can comprise data such as pictures, videos, webpage information and various reports, and has relatively large data capacity.
In step S212, the first type of sensitive data is encrypted and stored in the blockchain, and the first type of sensitive data is encrypted and stored in the blockchain.
The first type of sensitive data is structured data, so that the data volume of the first type of sensitive data is small, and the first type of sensitive data is easy to arrange and process, so that the first type of sensitive data can be directly encrypted and then stored in the block chain. In this embodiment, the first type of sensitive data may be encrypted by using an elliptic curve algorithm, and further, the first user node encrypts the first type of sensitive data by using its own private key and using an elliptic curve algorithm.
In other embodiments, other asymmetric encryption algorithms may also be used to encrypt the first type of sensitive data, which is not specifically limited in this embodiment.
In step S213, a corresponding digital fingerprint is generated for the second type sensitive data, and the digital fingerprint is encrypted and stored in the blockchain.
The second type of sensitive data is unstructured data, so that the data volume of the second type of sensitive data is large, the formats of the second type of sensitive data are not uniform, if the second type of sensitive data is directly encrypted and stored in the block chain, the storage pressure of the block chain is increased to a great extent, and the overall processing efficiency and speed of the block chain are affected. Therefore, for the second type of sensitive data, a corresponding digital fingerprint is generated, and the digital fingerprint is encrypted and then stored in the block chain.
In the embodiment, the second type of sensitive data is subjected to Hash calculation to generate corresponding digital fingerprints, and the digital fingerprints are encrypted and then stored in a block chain; further, the first user node encrypts the second type of sensitive data by using a private key of the first user node.
In step S22, the remaining data in the first type of data is stored as non-sensitive data in the cloud database.
Further, the data left after screening in the first type of data is used as non-sensitive data, and the data is stored in the cloud database, so that it can be understood that the non-sensitive data can be encrypted when the non-sensitive data is stored in the cloud database, and the encrypted data is stored in the cloud database. The encryption algorithm used may be an asymmetric encryption algorithm such as an RSA algorithm, and the embodiment is not particularly limited.
In the embodiment, data required to be stored by a user node is divided into sensitive data and non-sensitive data by using a sensitive field, the sensitive data is further divided into first-class sensitive data and second-class sensitive data according to the data structure type, the non-sensitive data is stored in a cloud database, the sensitive data belongs to a structured data direct storage and block chain, the non-structured data is calculated into a digital fingerprint storage and block chain, the safety of sensitive data storage is improved, and meanwhile, the data storage and data processing pressure of the block chain is relatively reduced.
Further, referring to fig. 10, fig. 10 is a schematic flowchart illustrating a second embodiment of the data storage method based on a block chain according to the present application, as shown in fig. 10, the data storage method of the present embodiment may include the following steps:
in step S31, the first user node stores the first type of data in the cloud database.
In this embodiment, before the first user node performs the screening of the sensitive data on the first type of data, the first type of data is completely stored in the cloud database.
In step S32, sensitive data is screened from the first type of data by using a preset sensitive field, and the sensitive data is stored in the block chain.
Further, corresponding sensitive data are screened out from the first type of data according to sensitive fields set by the user, and the screened out sensitive data are stored in the block chain. Step S32 in this embodiment is the same as step S21 shown in fig. 8, and is not repeated here.
For sensitive data, the embodiment stores the sensitive data and the cloud database in the block chain; it can be understood that when the sensitive data is stored in the cloud database and the blockchain at the same time, a data index between the cloud database and the blockchain may be established, that is, the sensitive data identical to the sensitive data stored in the cloud database may be found from the blockchain according to the data index, and the data index may be a data guide tag. At this time, when the first user node or other user nodes needing to access the sensitive data determine that the sensitive data stored in the cloud database is missing, the same sensitive data can be searched from the block chain according to the data index, and then the searched same sensitive data is stored in the cloud database again, so that the stored data in the cloud database is rapidly recovered, and the long-term stable operation of the block chain cloud audit system is maintained.
It can be understood that the first and second embodiments of the data storage method based on the blockchain shown in fig. 8 to 10 may be applied to any user node in the blockchain network, that is, any user node may filter sensitive data by setting a sensitive field for the data to be stored, and store the sensitive data in the blockchain and the cloud database; and further storing the structured data in the sensitive data in a direct encryption storage mode, and storing the unstructured data in a digital fingerprint calculation mode.
Further, please refer to fig. 11, fig. 11 is a block chain-based data sharing method according to a first embodiment of the present application. The data sharing method of this embodiment may be applied to the blockchain network shown in fig. 3, and may also be applied to the blockchain cloud auditing system shown in fig. 7, which is not limited in this embodiment. As shown in fig. 11, the data sharing method of this embodiment at least includes the following steps:
in step S41, the first user node broadcasts a first access request corresponding to the data to be accessed to the blockchain.
In this embodiment, data to be accessed is generated by the second user node, and data whose ownership is attributed to the second user node is taken as an example for explanation. For convenience of understanding, a user node corresponding to an auditing mechanism can be used as a first user node, and a user node corresponding to an audited unit can be used as a second user node; the data to be accessed is audit data generated by the second user node based on own economic activities, or corresponding audit data such as audit evaluation reports, audit opinion books and the like.
The first user node can carry out retrieval based on the shared data resource catalog according to the access requirement of the first user node, and the second user node corresponding to the data to be accessed, the storage address of the data to be accessed and other related information are obtained according to the retrieval result. Thus, the first access request can be created based on the search result, and the first access request can be broadcasted to the blockchain. The first access request may include a public key of the first user node.
In step S42, the submitting node generates a corresponding sharing token based on the first access request and feeds back the sharing token to the first user node.
And the submitting node in the block chain can acquire the first access request and perform identity authentication on the first user node according to the first access request. After the identity of the first user node is confirmed, a corresponding sharing token can be generated, and the generated sharing token is fed back to the first user node. Wherein the shared token may comprise at least the public key of the first user node encrypted with the public key of the second user node.
In this embodiment, the behavior that the first user node broadcasts the first access request may be regarded as a transaction request, the submitting node is a transaction party corresponding to the transaction request, and the shared token generated by the submitting node may be regarded as transaction confirmation information created in response to the transaction request, so that a transaction random number may be generated based on the transaction request. The shared token of this embodiment may include the transaction random number corresponding to the first access request encrypted by the public key of the second user node.
Further, as shown in fig. 12, step S42 may include at least the following steps:
in step S421, the submitting node obtains a corresponding data access policy based on the first access request matching.
The submitting node performs identity authentication on the first user node according to the first access request, and can further acquire identity information of the first user node, so that a corresponding data access strategy can be obtained according to the identity information matching of the first user node. In this embodiment, the data access policy may be an intelligent contract, which is a data script that is deployed in the blockchain and can be automatically executed by setting a preset trigger condition. The data access policy specifies data access conditions and related specifications related to the identity information of the user node, and sets preset conditions.
In step S422, the first access request is made to trigger a preset condition of the data sharing policy, the sharing token is generated, and the sharing token is fed back to the first user node.
Further, the submitting node matches the first access request with the data sharing policy so that the request information contained in the first access request triggers a preset condition of the data sharing policy, the preset condition is triggered to indicate that the first user node can utilize the first access request, a second access request for data to be accessed is initiated based on the data sharing policy, and a corresponding sharing token is generated at the moment.
In step S43, the first user node initiates a second access request to a second user node corresponding to the data to be accessed using the shared token and the access authorization contract.
And after receiving the sharing token fed back by the submitting node, the first user node confirms that the first user node can initiate data access to the second user node, wherein the sharing token is used as confirmation information corresponding to the first access request. At this time, the first user node can also generate an access authorization policy according to the access requirement of the first user node on the data to be accessed, and encrypt the access authorization policy by using a private key of the first user node to form an access authorization contract. Therefore, the first user node can carry the sharing token and the access authorization contract to initiate a second access request to the second user node.
The access authorization policy is generated by the first user node according to the access requirement of the first user node on the data to be accessed, and the access authorization policy includes access requirements of the first user node on the access time period, the access duration, whether downloading is needed, whether adding new content is needed, and the like of the data to be accessed.
In step S44, the second user node verifies the first access request based on the sharing token, and evaluates the access authorization contract to obtain an evaluation result.
And the second user node receives a second access request carrying a shared token and an access authorization contract, wherein the shared token comprises the public key of the first user node and the transaction random number encrypted by the public key of the second user node. Thus, the second user node may validate the first access request based on the transaction random number, the public key of the first user node, and the access authorization contract, and evaluate the access authorization contract.
Further, as shown in fig. 13, step S44 may include the following steps:
in step S441, the second user node decrypts the shared token by using its own private key, obtains the public key and the transaction random number of the first user node included in the shared token, and obtains the identity information of the first user node.
The shared token comprises the public key of the first user node and the transaction random number encrypted by the public key of the second user node, so that the second user node can decrypt the shared token by using the private key of the second user node to further obtain the public key of the first user node and the transaction random number contained in the shared token. Wherein the transaction random number is a random number generated based on the first access request for preventing the request from being repeated.
In step S442, the first access request is verified according to the transaction random number, and a verification result is obtained.
The second user node verifies the first access request using the transaction random number. Specifically, when a first access request is generated in the blockchain, the first access request is regarded as a transaction request, so that a transaction random number (nonce) is generated, the numerical value of the transaction random number is increased from 0 along with the increase of the transaction times, 1 is added to the numerical value of the transaction random number every time the transaction times are increased, and in the blockchain, only after the transaction processing corresponding to the transaction random number with the smaller previous numerical value is completed, the transaction corresponding to the transaction random number with the larger subsequent numerical value is processed. Therefore, whether the numerical value of the transaction random number corresponding to the first access request at the moment is larger than the numerical value of the transaction random number corresponding to the access request processed before or whether a jump interval occurs in the numerical value of the transaction random number can be judged, the first access request is verified, if the numerical value of the transaction random number is larger than the numerical value of the transaction random number corresponding to the access request processed before and the jump interval does not occur in the numerical value of the transaction random number, the verification result of verifying the first access request is verification pass, and the subsequent step S443 can be continuously executed based on the first access request, otherwise, the verification result of verifying the first access request is verification fail, and the subsequent step is not executed based on the first access request.
In step S443, the access authorization contract is decrypted by using the obtained public key of the first user node, and a corresponding access authorization policy is obtained.
When the verification result obtained in step S442 is that the verification passes, the second user node further decrypts the access authorization contract by using the public key of the first user node obtained in step S441 to obtain a corresponding access authorization policy; and proceeds to step S444 based on the access authorization policy.
In step S444, the access authorization contract is evaluated by using the identity information of the first user node and the access authorization policy, and an evaluation result is obtained.
The second user node evaluates the access authorization contract according to the identity information of the first user node obtained in step S441 and the access authorization policy obtained in step S443, and obtains an evaluation result.
Further, as shown in fig. 14, the step S444 may include the steps of:
in step S4441, the data access right specified by the block chain to the first user node is confirmed according to the identity information of the first user node.
The block chain is provided with corresponding data access authority according to the unused identity information of the user node, for example, the user node with the identity information of an audit part can have larger data access authority, the access time period of the data to be accessed can be any time period, the access time period can be half a month or even one month, and the like, and the data to be accessed can be downloaded, and new content can be added; the access time period of the user node with the identity information of the common data user to the data to be accessed can only be a specified certain time period, the access time can be days or a week, the data to be accessed cannot be downloaded, new contents cannot be added, and the like.
Therefore, the second user node can acquire the specified data access authority of the first user node from the block chain according to the identity information of the first user node.
In step S4442, it is determined whether the access requirement for the data to be accessed included in the access authorization policy matches the data access right.
Further, whether an access authorization policy formed by the first user node according to the access requirement of the first user node is within a data access authority of a specified first user node is judged, for example, whether an access time period recorded in the access authorization policy is within a time period specified in the data access authority, whether an access duration recorded in the access authorization policy does not exceed an access duration specified in the data access authority, and the like are judged, and whether the access authorization policy is matched with the data access authority is further judged. If the access request recorded in the access authorization policy is within the data access authority of the specified first user node, continuing to execute step S4443; otherwise, step S4444 is performed.
In step S4443, it is determined that the evaluation result is that the access authorization contract passes the evaluation.
If the access request recorded in the access authorization policy is within the data access right of the predetermined first user node, it indicates that the access request of the first user node does not exceed the predetermined data access right, and the evaluation result indicates that the access authorization contract passes the evaluation, so that the step S35 may be continuously executed.
In step S4444, it is determined that the evaluation result is that the access authorization contract is not evaluated.
If the access request recorded in the access authorization strategy exceeds the data access authority of the specified first user node, if the evaluation result is that the access authorization contract is not evaluated, the subsequent steps are stopped to be executed, and information that the access request does not accord with the specification can be fed back to the first user node.
In step S45, when the evaluation result is that the access authorization contract passes the evaluation, the first user node accesses the data to be accessed according to the access authorization contract.
When the evaluation result is that the access authorization contract passes the evaluation, that is, the second user node completes the identity authentication of the first user node and the approval of the access request, so that the first user node can access the data to be accessed according to the access requirement specified in the access authorization contract, and can correspondingly perform operations such as sharing, downloading, content adding and the like on the data to be accessed.
Further, in this embodiment, the data that the second user node needs to store may be stored in the manner described in the first embodiment and the second embodiment of the block chain based data storage method shown in fig. 8 to fig. 10, that is, all data of the second user node is stored in the cloud database, further, the sensitive data is also stored in the block chain, the first type of sensitive data is directly encrypted and stored in the block chain, and the second type of sensitive data is stored in the block chain in the manner of digital fingerprint. Correspondingly, when the first user node accesses the second user node, the first user node can preferentially acquire required data from the cloud database, so that the data acquisition process can be simplified; if the data in the cloud database is missing, the data can be further acquired from the block chain, and the acquired data is stored in the cloud database again.
In this embodiment, the first user node needs to broadcast a transaction corresponding to data access to the whole network, and after the submitting node authenticates the first user node according to the transaction, a sharing token is generated; the first user node can initiate a data access request to the second user node based on the shared token after obtaining the shared token, and can perform data access after the second user node is verified and evaluated, so that the safety and the compliance of data circulation in the blockchain network are improved.
Further, please refer to fig. 15, fig. 15 is a flowchart illustrating a block chain-based data sharing method according to a second embodiment of the present invention. The data sharing method of the present embodiment is proposed on the basis of the data sharing methods shown in fig. 11 to 14, and as shown in fig. 15, the present embodiment may include the following steps:
in step S51, the first user node broadcasts a first access request corresponding to the data to be accessed to the blockchain.
In step S52, the submitting node generates a corresponding sharing token based on the first access request and feeds back the sharing token to the first user node.
In step S53, the first user node initiates a second access request to a second user node corresponding to the data to be accessed using the shared token and the access authorization contract.
In step S54, the second user node verifies the first access request based on the sharing token, evaluates the access authorization contract, and sends the evaluation result to the submitting node.
Steps S51 to S53 in this embodiment are the same as steps S41 to S43 in the first embodiment of the data sharing method shown in fig. 11 to 13, and are not repeated herein. Further, step S54 is similar to step 44 shown in fig. 11 to 14, except that after obtaining the evaluation result, the second user node sends the evaluation result to the submitting node, and the submitting node allows or disallows the first user node to access the data to be accessed according to the evaluation result.
In step S55, the commit node passes the data sharing interface for the first user node to the data to be accessed.
After the submitting node obtains the evaluation result sent by the second user node, if the evaluation result is that the access authorization contract passes the evaluation, the data sharing interface of the data to be accessed by the first user node is released, and thus the step S56 is continued.
In step S56, the first user node accesses the data to be accessed according to the access authorization contract.
After the submitting node releases the data sharing interface of the first user node for the data to be accessed, the first user node can access the data to be accessed through the data sharing interface according to the access authorization contract.
In step S57, the commit node blocks the data sharing interface of the first user node to the data to be accessed.
And after the submitting node acquires the evaluation result sent by the second user node, if the evaluation result is that the access authorization contract does not pass the evaluation, blocking the data sharing interface of the first user node to the data to be accessed, and ending the process.
Further, please refer to fig. 16, fig. 16 is a schematic structural diagram of an embodiment of an electronic device according to the present application. As shown in fig. 16, the electronic device 160 of this embodiment may be the user node 411, the accounting node 412, the submitting node 313, or the management node 314 shown in fig. 3 or fig. 7. The electronic device 160 may be embodied as a computer, a mobile phone, a tablet computer, or the like corresponding to the user node 411, the accounting node 412, the submitting node 313, or the management node 314. The electronic device 160 of the present embodiment is deployed with a blockchain platform infrastructure as shown in fig. 1 or a blockchain cloud auditing infrastructure as shown in fig. 6, and can join in a blockchain network as a node in the blockchain network.
Further, the electronic device 160 of the present embodiment may include a processor 1601 and a memory 1602 disposed inside the electronic device 160, wherein the processor 1601 and the memory 1602 are connected by a bus. The memory 1602 stores computer instructions executable by the processor 1601, and the processor 1601 executes the computer instructions to implement any one or more of the first embodiment of the blockchain-based data processing method shown in fig. 4 to 5, the first and second embodiments of the blockchain-based data storage method shown in fig. 8 to 10, and the first and second embodiments of the blockchain-based data sharing method shown in fig. 11 to 15.
Further, please refer to fig. 17, fig. 17 is a schematic structural diagram of an embodiment of a storage medium according to the present application. As shown in fig. 17, the storage medium 170 in this embodiment stores therein a computer instruction 1701 capable of being executed, and the computer instruction 1701 is executed to implement any one or more of the first embodiment of the block chain based data processing method shown in fig. 4 to 5, the first and second embodiments of the block chain based data storage method shown in fig. 8 to 10, and the first and second embodiments of the block chain based data sharing method shown in fig. 11 to 15.
In this embodiment, the storage medium 170 may be a storage medium with a storage function, such as a storage module of an intelligent terminal, a mobile storage device (e.g., a mobile hard disk, a usb disk, etc.), a network cloud disk, an application storage platform, or a server. In addition, the storage medium may also be a storage device of a terminal corresponding to the user node 311 shown in fig. 3 or fig. 7, or a server corresponding to the accounting node 312, the submitting node 313, and the management node 314; or memory 1602 as shown in figure 16.
The scheme can realize the following beneficial effects:
(1) the audit data are encrypted by using an asymmetric encryption algorithm in the circulation process, only the private key of the authorization node can be decrypted to obtain corresponding audit data, and part of the audit data are subjected to uplink storage in a digital fingerprint mode, so that the data decryption difficulty is further increased, the data security is strengthened, and the data feasibility is improved.
(2) Key financial certificates, receipts and major contracts are stored as digital assets in a chaining mode through sensitive fields, different consulting authorities are set according to the responsibility of an auditing main body, the data are communicated in a multi-party secure sharing mode across time and space while the auditing data privacy is protected, a shared log cannot be tampered and traced, besides, an auditing result is recorded into a block chain and is associated with an audited unit, digital preservation is achieved, a real-time decision-making basis is provided for benefit relatives, and therefore data circulation load is reduced, and auditing time is saved.
(3) After being identified, the abstract content of the audit data is booked on a block chain, the authenticity of an audit data source is checked through cross check, and meanwhile, the abnormal record is automatically marked and processed, so that real-time audit is completed; the highly programmable script is used for coding the audit model, relevant audit data cleaning and data analysis are automatically executed according to a specific audit object and a preset time period, subjective audit data validity judgment of an audit worker is eliminated, and the whole audit process and results are more fair, objective and reliable.
(4) Distributed storage of block chain cloud audit system, every node all possess unanimous data account book, not only solve traditional audit when carrying out this frequency data processing, system load is high, the functioning speed is slow scheduling problem, can also improve audit speed, reduce the high volume fortune dimension expense of server through sharing audit work load to different nodes.
(5) The chain audit data is associated with a producer of the audit data, a programmable data access strategy is formulated by an audit main body, when data transaction is initiated, the data transaction needs to be broadcast to the whole network and approved by a certain number of nodes, and then the data transaction is allowed to be effectively accessed, so that the use compliance and safety of the audit data are ensured.
In the description above, for purposes of explanation and not limitation, specific details are set forth such as particular system structures, interfaces, techniques, etc. in order to provide a thorough understanding of the present application. It will be apparent, however, to one skilled in the art that the present application may be practiced in other embodiments that depart from these specific details. In other instances, detailed descriptions of well-known devices, circuits, and methods are omitted so as not to obscure the description of the present application with unnecessary detail.

Claims (10)

1. A method for sharing data based on block chains is characterized by comprising the following steps:
a first user node broadcasts a first access request corresponding to data to be accessed to a blockchain;
the submitting node generates a corresponding sharing token based on the first access request and feeds the sharing token back to the first user node;
the first user node initiates a second access request to a second user node corresponding to the data to be accessed by utilizing the sharing token and the access authorization contract;
the second user node verifies the first access request based on the shared token and evaluates the access authorization contract to obtain an evaluation result;
and when the evaluation result is that the access authorization contract passes the evaluation, the first user node accesses the data to be accessed according to the access authorization contract.
2. The data sharing method according to claim 1,
the shared token comprises a public key of the first user node encrypted with a public key of the second user node;
the access authorization contract is an access authorization policy encrypted by a private key of the first user node; the access authorization policy is an access policy generated by the first user node based on the access requirement of the first user node on the data to be accessed.
3. The data sharing method according to claim 2,
the second user node evaluating the access authorization contract, comprising:
the second user node decrypts the shared token by using a private key of the second user node, acquires a public key of the first user node contained in the second user node, and acquires identity information of the first user node;
decrypting the access authorization contract by using the acquired public key of the first user node to acquire a corresponding access authorization strategy;
evaluating the access authorization contract using the identity information of the first user node and the access authorization policy.
4. The data sharing method according to claim 3,
the second user node evaluates the access authorization contract according to the identity information of the first user node and the access authorization policy to obtain an evaluation result, and the evaluation result includes:
confirming the data access authority of the block chain to the first user node according to the identity information of the first user node;
judging whether the access requirement for the data to be accessed contained in the access authorization strategy is matched with the data access authority or not;
if so, determining that the evaluation result is that the access authorization contract passes the evaluation;
otherwise, determining that the evaluation result is that the access authorization contract is not evaluated.
5. The data sharing method according to claim 2,
the shared token further comprises a transaction random number corresponding to the first access request encrypted by a public key of the second user node;
the second user node verifying the first access request based on the shared token, including:
the second user node decrypts the shared token by using a private key of the second user node to obtain the transaction random number contained in the shared token;
and verifying the first access request according to the transaction random number.
6. The data sharing method according to claim 1,
the submitting node generating a respective sharing token based on the first access request, including:
the submitting node obtains a corresponding data access strategy based on the first access request matching;
and enabling the first access request to trigger a preset condition of the data sharing strategy, and generating the sharing token.
7. The data sharing method according to claim 1,
the data sharing method further comprises the following steps:
the second user node sends the evaluation result to the submitting node;
and when the submitting node determines that the evaluation result is that the access authorization contract passes the evaluation, releasing the data sharing interface of the first user node for the data to be accessed.
8. The data sharing method according to claim 1,
the first user node broadcasting a first access request corresponding to data to be accessed to a blockchain, comprising:
the first user node creates the first access request according to the data to be accessed and broadcasts the first access request to the block chain;
the first access request carries a public key of the first user node.
9. A data sharing network based on a block chain is characterized by comprising a first user node, a second user node and a submitting node which are communicated with each other; wherein,
the first user node, the second user node and the submitting node are respectively used for executing the corresponding steps in the data sharing method of any one of claims 1 to 8.
10. An electronic device, characterized in that the electronic device comprises a memory and a processor, which are connected to each other,
the memory is used for storing computer instructions executed by the processor;
the processor is configured to execute the computer instructions stored in the memory to implement the corresponding steps performed by the first user node, the second user node or the submitting node in the data sharing method according to any one of claims 1 to 8.
CN201811420021.3A 2018-11-26 2018-11-26 Data sharing method based on block chain, data sharing network and electronic equipment Active CN109450910B (en)

Priority Applications (1)

Application Number Priority Date Filing Date Title
CN201811420021.3A CN109450910B (en) 2018-11-26 2018-11-26 Data sharing method based on block chain, data sharing network and electronic equipment

Applications Claiming Priority (1)

Application Number Priority Date Filing Date Title
CN201811420021.3A CN109450910B (en) 2018-11-26 2018-11-26 Data sharing method based on block chain, data sharing network and electronic equipment

Publications (2)

Publication Number Publication Date
CN109450910A true CN109450910A (en) 2019-03-08
CN109450910B CN109450910B (en) 2021-03-30

Family

ID=65555800

Family Applications (1)

Application Number Title Priority Date Filing Date
CN201811420021.3A Active CN109450910B (en) 2018-11-26 2018-11-26 Data sharing method based on block chain, data sharing network and electronic equipment

Country Status (1)

Country Link
CN (1) CN109450910B (en)

Cited By (42)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN110059981A (en) * 2019-04-29 2019-07-26 威富通科技有限公司 Trust Values Asses method, apparatus and terminal device
CN110197081A (en) * 2019-05-30 2019-09-03 北京理工大学 A kind of cloud data sharing secret protection scheme based on block chain
CN110263086A (en) * 2019-05-20 2019-09-20 阿里巴巴集团控股有限公司 In conjunction with the receipt storage method and node of user type and event functions type
CN110473094A (en) * 2019-07-31 2019-11-19 阿里巴巴集团控股有限公司 Data grant method and device based on block chain
CN110602206A (en) * 2019-09-12 2019-12-20 腾讯科技(深圳)有限公司 Data sharing method and device based on block chain and storage medium
CN110740044A (en) * 2019-10-30 2020-01-31 北京海益同展信息科技有限公司 Data processing method, device, system and storage medium
CN110955699A (en) * 2019-11-25 2020-04-03 远光软件股份有限公司 Decentralized electronic academic certificate checking method and system
CN111445162A (en) * 2020-04-15 2020-07-24 中国银行股份有限公司 Evaluation data sharing method and system
CN111625847A (en) * 2020-04-27 2020-09-04 上海市大数据中心 Data authorization access method based on application scene
CN111682934A (en) * 2020-04-21 2020-09-18 国网天津市电力公司电力科学研究院 Storage, access and sharing method and system for comprehensive energy metering data
CN111753002A (en) * 2019-03-26 2020-10-09 国际商业机器公司 Consent-based data management
CN111797415A (en) * 2020-06-30 2020-10-20 远光软件股份有限公司 Block chain based data sharing method, electronic device and storage medium
CN111858769A (en) * 2020-07-28 2020-10-30 北京金山云网络技术有限公司 Data using method, device, node equipment and storage medium
CN111858611A (en) * 2020-07-28 2020-10-30 北京金山云网络技术有限公司 Data access method and device, computer equipment and storage medium
CN111967988A (en) * 2020-07-10 2020-11-20 广州汇通国信科技有限公司 Smart power grid data governance framework based on block chain technology
CN112214518A (en) * 2020-11-09 2021-01-12 广东新禾道信息科技有限公司 Block chain-based geospatial basic data sharing method and system
CN112214617A (en) * 2020-11-11 2021-01-12 广东新禾道信息科技有限公司 Digital file management method and system based on block chain technology
WO2021017433A1 (en) * 2019-07-31 2021-02-04 创新先进技术有限公司 Data authorization method and device employing smart contract
CN112463843A (en) * 2020-11-27 2021-03-09 国家电网有限公司大数据中心 Power grid data sharing method and system based on block chain and data resource catalog
CN112511309A (en) * 2020-11-19 2021-03-16 从法信息科技有限公司 Method and device for directionally sharing supervision-oriented information on block chain and electronic equipment
CN112543236A (en) * 2020-12-18 2021-03-23 中国联合网络通信集团有限公司 Data sharing method and block link point
CN112634058A (en) * 2020-12-22 2021-04-09 无锡井通网络科技有限公司 Data mutual trust and mutual sharing and intercommunication platform based on block chain
WO2021088728A1 (en) * 2019-11-06 2021-05-14 阿里巴巴集团控股有限公司 Data encryption method, data decryption method, data sharing method, device, system, and storage medium
CN112819617A (en) * 2020-08-21 2021-05-18 支付宝(杭州)信息技术有限公司 Data uplink method and device, electronic equipment and storage medium
CN112905554A (en) * 2021-02-07 2021-06-04 全链通有限公司 Data sharing method and device based on block chain
CN112989380A (en) * 2021-03-18 2021-06-18 深圳前海微众银行股份有限公司 Resource exchange processing method, device, equipment and storage medium
US11057189B2 (en) 2019-07-31 2021-07-06 Advanced New Technologies Co., Ltd. Providing data authorization based on blockchain
WO2021134835A1 (en) * 2020-01-02 2021-07-08 Hong Kong Applied Science and Technology Research Institute Company Limited System and methods for data exchange using a distributed ledger
CN113259105A (en) * 2021-06-23 2021-08-13 发明之家(北京)科技有限公司 Block chain data sharing method and system
CN113268763A (en) * 2020-12-28 2021-08-17 上海能链众合科技有限公司 Block chain-based distributed private data storage method
CN113327163A (en) * 2021-05-17 2021-08-31 广东电网有限责任公司 Data processing method and device based on block chain, electronic equipment and storage medium
CN113486385A (en) * 2021-07-29 2021-10-08 深圳市至诚峰汇科技有限公司 Jewelry sharing method, device, equipment and storage medium based on block chain
CN113849556A (en) * 2021-08-11 2021-12-28 国网甘肃省电力公司信息通信公司 Sharing mechanism based on block chain distributed database
US11252166B2 (en) 2019-07-31 2022-02-15 Advanced New Technologies Co., Ltd. Providing data authorization based on blockchain
US11251963B2 (en) 2019-07-31 2022-02-15 Advanced New Technologies Co., Ltd. Blockchain-based data authorization method and apparatus
US11310051B2 (en) 2020-01-15 2022-04-19 Advanced New Technologies Co., Ltd. Blockchain-based data authorization method and apparatus
CN114547209A (en) * 2022-04-26 2022-05-27 睿至科技集团有限公司 Data sharing interaction method and system based on block chain
CN114629684A (en) * 2022-02-16 2022-06-14 深圳番多拉信息科技有限公司 Permission token processing method, system, device and storage medium based on block chain
CN114762291A (en) * 2019-12-03 2022-07-15 索尼集团公司 Method, computer program and data sharing system for sharing user specific data of a user
CN115622721A (en) * 2021-07-13 2023-01-17 中移物联网有限公司 Information processing method and device, block chain equipment, user equipment and network equipment
CN117436878A (en) * 2023-12-19 2024-01-23 成都天府通数字科技有限公司 Multi-channel payment method and payment system based on blockchain technology
CN118368154A (en) * 2024-06-20 2024-07-19 宁波梦创信息科技有限公司 Project cloud data sharing method based on block chain

Citations (7)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN106302546A (en) * 2016-10-18 2017-01-04 青岛海信电器股份有限公司 The method and apparatus realizing server access
CN106651346A (en) * 2016-11-28 2017-05-10 上海凯岸信息科技有限公司 Block chain-based credit investigation data sharing and trading system
US20170244707A1 (en) * 2016-02-22 2017-08-24 Bank Of America Corporation System for establishing secure access for users in a process data network
KR101857223B1 (en) * 2017-11-13 2018-05-11 주식회사 온더 Method and system for user identification based block chain token
CN108156232A (en) * 2017-12-22 2018-06-12 王轶捷 Data sharing method and device
CN108173850A (en) * 2017-12-28 2018-06-15 杭州趣链科技有限公司 A kind of identity authorization system and identity identifying method based on block chain intelligence contract
CN108737370A (en) * 2018-04-05 2018-11-02 西安电子科技大学 A kind of cross-domain Verification System of Internet of Things based on block chain and method

Patent Citations (7)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US20170244707A1 (en) * 2016-02-22 2017-08-24 Bank Of America Corporation System for establishing secure access for users in a process data network
CN106302546A (en) * 2016-10-18 2017-01-04 青岛海信电器股份有限公司 The method and apparatus realizing server access
CN106651346A (en) * 2016-11-28 2017-05-10 上海凯岸信息科技有限公司 Block chain-based credit investigation data sharing and trading system
KR101857223B1 (en) * 2017-11-13 2018-05-11 주식회사 온더 Method and system for user identification based block chain token
CN108156232A (en) * 2017-12-22 2018-06-12 王轶捷 Data sharing method and device
CN108173850A (en) * 2017-12-28 2018-06-15 杭州趣链科技有限公司 A kind of identity authorization system and identity identifying method based on block chain intelligence contract
CN108737370A (en) * 2018-04-05 2018-11-02 西安电子科技大学 A kind of cross-domain Verification System of Internet of Things based on block chain and method

Non-Patent Citations (2)

* Cited by examiner, † Cited by third party
Title
SHANGPING WANG: ""A Blockchain-Based Framework for Data Sharing With Fine-Grained Access Control in Decentralized Storage Systems"", 《IEEE ACCESS》 *
刘敖迪等: ""区块链技术及其在信息安全领域的研究进展"", 《软件学报》 *

Cited By (64)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN111753002A (en) * 2019-03-26 2020-10-09 国际商业机器公司 Consent-based data management
CN110059981A (en) * 2019-04-29 2019-07-26 威富通科技有限公司 Trust Values Asses method, apparatus and terminal device
CN110059981B (en) * 2019-04-29 2021-06-04 威富通科技有限公司 Trust degree evaluation method and device and terminal equipment
CN110263086A (en) * 2019-05-20 2019-09-20 阿里巴巴集团控股有限公司 In conjunction with the receipt storage method and node of user type and event functions type
CN110263086B (en) * 2019-05-20 2021-04-02 创新先进技术有限公司 Receipt storage method and node combining user type and event function type
CN110197081A (en) * 2019-05-30 2019-09-03 北京理工大学 A kind of cloud data sharing secret protection scheme based on block chain
US11831656B2 (en) 2019-07-31 2023-11-28 Advanced New Technologies Co., Ltd. Providing data authorization based on blockchain
US11398914B2 (en) 2019-07-31 2022-07-26 Advanced New Technologies Co., Ltd. Blockchain-based data authorization method and apparatus
US11252166B2 (en) 2019-07-31 2022-02-15 Advanced New Technologies Co., Ltd. Providing data authorization based on blockchain
CN110473094A (en) * 2019-07-31 2019-11-19 阿里巴巴集团控股有限公司 Data grant method and device based on block chain
WO2021017433A1 (en) * 2019-07-31 2021-02-04 创新先进技术有限公司 Data authorization method and device employing smart contract
US11057189B2 (en) 2019-07-31 2021-07-06 Advanced New Technologies Co., Ltd. Providing data authorization based on blockchain
US11251963B2 (en) 2019-07-31 2022-02-15 Advanced New Technologies Co., Ltd. Blockchain-based data authorization method and apparatus
CN110602206B (en) * 2019-09-12 2022-06-10 腾讯科技(深圳)有限公司 Data sharing method and device based on block chain and storage medium
CN110602206A (en) * 2019-09-12 2019-12-20 腾讯科技(深圳)有限公司 Data sharing method and device based on block chain and storage medium
CN110740044A (en) * 2019-10-30 2020-01-31 北京海益同展信息科技有限公司 Data processing method, device, system and storage medium
CN110740044B (en) * 2019-10-30 2021-10-12 北京海益同展信息科技有限公司 Data processing method, device, system and storage medium
WO2021088728A1 (en) * 2019-11-06 2021-05-14 阿里巴巴集团控股有限公司 Data encryption method, data decryption method, data sharing method, device, system, and storage medium
CN110955699B (en) * 2019-11-25 2022-12-06 远光软件股份有限公司 Decentralized electronic academic certificate checking method and system
CN110955699A (en) * 2019-11-25 2020-04-03 远光软件股份有限公司 Decentralized electronic academic certificate checking method and system
CN114762291A (en) * 2019-12-03 2022-07-15 索尼集团公司 Method, computer program and data sharing system for sharing user specific data of a user
WO2021134835A1 (en) * 2020-01-02 2021-07-08 Hong Kong Applied Science and Technology Research Institute Company Limited System and methods for data exchange using a distributed ledger
US11418342B2 (en) 2020-01-02 2022-08-16 Hong Kong Applied Science and Technology Research Institute Co.. Ltd. System and methods for data exchange using a distributed ledger
US11310051B2 (en) 2020-01-15 2022-04-19 Advanced New Technologies Co., Ltd. Blockchain-based data authorization method and apparatus
CN111445162A (en) * 2020-04-15 2020-07-24 中国银行股份有限公司 Evaluation data sharing method and system
CN111682934A (en) * 2020-04-21 2020-09-18 国网天津市电力公司电力科学研究院 Storage, access and sharing method and system for comprehensive energy metering data
CN111682934B (en) * 2020-04-21 2023-08-01 国网天津市电力公司电力科学研究院 Method and system for storing, accessing and sharing comprehensive energy metering data
CN111625847B (en) * 2020-04-27 2023-03-17 上海市大数据中心 Data authorization access method based on application scene
CN111625847A (en) * 2020-04-27 2020-09-04 上海市大数据中心 Data authorization access method based on application scene
CN111797415A (en) * 2020-06-30 2020-10-20 远光软件股份有限公司 Block chain based data sharing method, electronic device and storage medium
CN111967988A (en) * 2020-07-10 2020-11-20 广州汇通国信科技有限公司 Smart power grid data governance framework based on block chain technology
CN111858769B (en) * 2020-07-28 2024-05-03 北京金山云网络技术有限公司 Data use method, device, node equipment and storage medium
CN111858611A (en) * 2020-07-28 2020-10-30 北京金山云网络技术有限公司 Data access method and device, computer equipment and storage medium
CN111858769A (en) * 2020-07-28 2020-10-30 北京金山云网络技术有限公司 Data using method, device, node equipment and storage medium
CN112819617A (en) * 2020-08-21 2021-05-18 支付宝(杭州)信息技术有限公司 Data uplink method and device, electronic equipment and storage medium
US11972414B2 (en) 2020-08-21 2024-04-30 Alipay (Hangzhou) Information Technology Co., Ltd. Data recording methods and apparatuses, electronic devices, and storage media
CN112819617B (en) * 2020-08-21 2022-06-07 支付宝(杭州)信息技术有限公司 Data uplink method and device, electronic equipment and storage medium
CN112214518A (en) * 2020-11-09 2021-01-12 广东新禾道信息科技有限公司 Block chain-based geospatial basic data sharing method and system
CN112214518B (en) * 2020-11-09 2021-06-11 广东新禾道信息科技有限公司 Block chain-based geospatial basic data sharing method and system
CN112214617A (en) * 2020-11-11 2021-01-12 广东新禾道信息科技有限公司 Digital file management method and system based on block chain technology
CN112214617B (en) * 2020-11-11 2021-05-14 广东新禾道信息科技有限公司 Digital file management method and system based on block chain technology
CN112511309A (en) * 2020-11-19 2021-03-16 从法信息科技有限公司 Method and device for directionally sharing supervision-oriented information on block chain and electronic equipment
CN112511309B (en) * 2020-11-19 2022-07-08 从法信息科技有限公司 Method and device for directionally sharing supervision-oriented information on block chain and electronic equipment
CN112463843A (en) * 2020-11-27 2021-03-09 国家电网有限公司大数据中心 Power grid data sharing method and system based on block chain and data resource catalog
CN112543236A (en) * 2020-12-18 2021-03-23 中国联合网络通信集团有限公司 Data sharing method and block link point
CN112634058A (en) * 2020-12-22 2021-04-09 无锡井通网络科技有限公司 Data mutual trust and mutual sharing and intercommunication platform based on block chain
CN113268763B (en) * 2020-12-28 2023-09-15 上海零数众合信息科技有限公司 Distributed privacy data storage method based on blockchain
CN113268763A (en) * 2020-12-28 2021-08-17 上海能链众合科技有限公司 Block chain-based distributed private data storage method
CN112905554B (en) * 2021-02-07 2024-05-10 全链通有限公司 Block chain-based data sharing method and device
CN112905554A (en) * 2021-02-07 2021-06-04 全链通有限公司 Data sharing method and device based on block chain
CN112989380A (en) * 2021-03-18 2021-06-18 深圳前海微众银行股份有限公司 Resource exchange processing method, device, equipment and storage medium
CN113327163B (en) * 2021-05-17 2023-02-10 广东电网有限责任公司 Data processing method and device based on block chain, electronic equipment and storage medium
CN113327163A (en) * 2021-05-17 2021-08-31 广东电网有限责任公司 Data processing method and device based on block chain, electronic equipment and storage medium
CN113259105A (en) * 2021-06-23 2021-08-13 发明之家(北京)科技有限公司 Block chain data sharing method and system
CN115622721A (en) * 2021-07-13 2023-01-17 中移物联网有限公司 Information processing method and device, block chain equipment, user equipment and network equipment
CN113486385A (en) * 2021-07-29 2021-10-08 深圳市至诚峰汇科技有限公司 Jewelry sharing method, device, equipment and storage medium based on block chain
CN113849556A (en) * 2021-08-11 2021-12-28 国网甘肃省电力公司信息通信公司 Sharing mechanism based on block chain distributed database
CN114629684A (en) * 2022-02-16 2022-06-14 深圳番多拉信息科技有限公司 Permission token processing method, system, device and storage medium based on block chain
CN114547209A (en) * 2022-04-26 2022-05-27 睿至科技集团有限公司 Data sharing interaction method and system based on block chain
CN114547209B (en) * 2022-04-26 2022-07-29 睿至科技集团有限公司 Data sharing interaction method and system based on block chain
CN117436878B (en) * 2023-12-19 2024-02-23 成都天府通数字科技有限公司 Multi-channel payment method and payment system based on blockchain technology
CN117436878A (en) * 2023-12-19 2024-01-23 成都天府通数字科技有限公司 Multi-channel payment method and payment system based on blockchain technology
CN118368154A (en) * 2024-06-20 2024-07-19 宁波梦创信息科技有限公司 Project cloud data sharing method based on block chain
CN118368154B (en) * 2024-06-20 2024-08-23 宁波梦创信息科技有限公司 Project cloud data sharing method based on block chain

Also Published As

Publication number Publication date
CN109450910B (en) 2021-03-30

Similar Documents

Publication Publication Date Title
CN109450910B (en) Data sharing method based on block chain, data sharing network and electronic equipment
CN109525671B (en) Block chain-based data storage method, electronic device and storage medium
CN109753815B (en) Data processing method based on block chain, data processing network and electronic equipment
Alblooshi et al. Blockchain-based ownership management for medical IoT (MIoT) devices
US12105823B2 (en) Protecting sensitive data
KR20220044306A (en) Partially-aligned blockchain
US11949794B2 (en) Data anonymization of blockchain-based processing pipeline
US11269863B2 (en) Index structure for blockchain ledger
US20210029163A1 (en) Security layer for configuring blockchain
US20220138550A1 (en) Blockchain for artificial intelligence training
US20220329411A1 (en) Blockchain processing offload to network device
US20220329436A1 (en) Token-based identity validation via blockchain
US11228424B2 (en) Blu-ray copy service
KR20230005353A (en) Sanctioned Events in a Decentralized Database
US11310311B2 (en) Media obfuscation
US20220166616A1 (en) Key reclamation in blockchain network via oprf
Janani et al. A security framework to enhance IoT device identity and data access through blockchain consensus model
US20230208640A1 (en) Selective audit process for privacy-preserving blockchain
US11271742B2 (en) Decentralized secure data sharing
US11088833B1 (en) Decentralized secure data sharing
US11356260B2 (en) Decentralized secure data sharing
US20230091686A1 (en) Digital asset platform with hsm verification
US11343085B2 (en) Threshold encryption for broadcast content
US11379594B2 (en) Media obfuscation
US12147413B2 (en) Dynamic updates of decentralized invoices

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