METHOD AND APPARATUS FOR VERIFYING DIGITAL IDENTITY, DEVICE AND STORAGE MEDIUM

Abstract
Embodiments of the present disclosure disclose a method and apparatus for verifying digital identity, a device and a storage medium, and relate to the technical field of blockchain. An implementation of the method can include: acquiring target login information of a target verifier, in response to a login operation of a target user on the target verifier; sending, based on the target login information, a login request including a target user decentralized identity (DID) of a target user to the target verifier, to authorize the target verifier to acquire a target claim of the target user from an identity hub of the target user and verify the target user DID and the target claim; and logging in to the target verifier using the target user DID, in response to the target user DID and the target claim passing the verification.
Description
CROSS-REFERENCE TO RELATED APPLICATIONS

This application claims priority to Chinese Patent Application No. 202010037958.3, filed with the China National Intellectual Property Administration (CNIPA) on Jan. 14, 2020, the contents of which are incorporated herein by reference in their entirety.


TECHNICAL FIELD

Embodiments of the present disclosure relate to the field of computer technology, particularly to the field of blockchain technology, and more particularly to a method and apparatus for verifying digital identity, a device and a storage medium.


BACKGROUND

With the rapid development of Internet applications, computer automatic verification and application login connect offline entities to online virtual identities, and its convenience and importance are becoming increasingly prominent. At present, digital identity verification technology based on decentralization is in an initial phase of exploration. The system is not well defined, and there is no client that could be used by users to conveniently use and manage digital identities. Therefore, there is actually no complete set of digital identity verification system for realizing decentralization.


SUMMARY

Embodiments of the present disclosure provide a method and apparatus for verifying digital identity, a device, and a storage medium, which can implement a complete digital identity verification system.


In a first aspect, some embodiments of the present disclosure provide a method for verifying digital identity, executed by a decentralized identity, DID, wallet. The method includes: acquiring target login information of a target verifier, in response to a login operation of a target user on the target verifier; sending, based on the target login information, a login request including a target user DID of a target user to the target verifier, to authorize the target verifier to acquire a target claim of the target user from an identity hub of the target user and verify the target user DID and the target claim; and logging in to the target verifier using the target user DID, in response to the target user DID and the target claim passing the verification.


An embodiment in the above disclosure has the following advantages or beneficial effects: by adding and defining architectures such as the DID wallet and the identity hub based on a DID standard formulated by the world wide web consortium W3C, the working process and access method of the entire digital identity verification system is clarified based on the interaction between the DID wallet, the identity hub and other existing structures, and a complete digital identity verification system is realized, providing the users or enterprises with the DID wallet that uses and manages DID accounts for, and ensuring an absolute ownership and control of digital identities.


Alternatively, the acquiring the target login information of the target verifier, in response to the login operation of the target user on the target verifier, includes: acquiring the target login information including at least a target verifier DID in response to the login operation of the target user on the target verifier, for acquiring, from a blockchain network, a DID document associated with the target verifier DID based on the target verifier DID.


An embodiment in the above disclosure has the following advantages or beneficial effects: the blockchain network may store DIDs and their related information, and provide information services for various participants.


Correspondingly, the DID wallet may obtain the DID document associated with the target verifier DID through the blockchain network for data encryption and sharing.


Alternatively, the authorize the target verifier to acquire the target claim of the target user from the identity hub of the target user, includes: sending a target site address storing the target claim in the identity hub to the target verifier, to authorize the target verifier to access a target site of the identity hub based on the target site address to acquire the target claim.


An embodiment in the above disclosure has the following advantages or beneficial effects: the target site address is used to instruct the target verifier to acquire the designated verifiable claim from the identity hub, and then achieve the purpose of authorizing the target verifier by sending the target site address, and realize the sharing of the verifiable claim.


Alternatively, before sending the target site address storing the target claim in the identity hub to the target verifier, the method further includes: encrypting the target claim based on a proxy re-encryption mechanism.


An embodiment in the above disclosure has the following advantages or beneficial effects: the proxy re-encryption mechanism is used to realize the sharing of the claim, avoid the leak of the claim and ensure the safety of the data.


Alternatively, the encrypting the target claim based on the proxy re-encryption mechanism, includes: encrypting the target claim using an advanced encryption standard, AES, key, to obtain an encrypted target claim; encrypting the AES key using a target user public key, to obtain a symmetric key ciphertext; calculating to obtain a re-encryption key, based on a target user private key, and a target verifier public key acquired from the DID document associated with the target verifier DID; and storing the encrypted target claim, the symmetric key ciphertext, and the re-encryption key into the target site address of the identity hub, to control the identity hub to re-encrypt the symmetric key ciphertext using the re-encryption key to generate and store a re-encrypted ciphertext.


An embodiment in the above disclosure has the following advantages or beneficial effects: the purpose of the proxy re-encryption mechanism is that the data encrypted based on the target user public key may be decrypted by a sharing party, i.e., the target verifier, using the target verifier private key to acquire the data, ensuring the safe sharing of the data.


Alternatively, the target site address is used by the target verifier to: acquire the encrypted target claim and the re-encrypted ciphertext based on the target site address, and decrypt the re-encrypted ciphertext based on a target verifier private key to obtain a symmetric encryption key, and decrypt the encrypted target claim based on the symmetric encryption key to obtain the target claim.


An embodiment in the above disclosure has the following advantages or beneficial effects: the target site address is used to instruct the target verifier to acquire the designated verifiable claim. Correspondingly, under the protection of the proxy re-encryption mechanism, the target verifier is required to decrypt the acquired verifiable claim to ensure the safe sharing of the data.


Alternatively, before the acquiring the target login information of the target verifier, in response to the login operation of the target user on the target verifier, the method further includes: searching for a target issuer that issues a claim, based on service information of issuers in a claim issuer registry; sending a claim application request to the target issuer, to control the target issuer to generate the target claim of the target user; and obtaining the target claim issued by the target issuer responding to the claim application request.


An embodiment in the above disclosure has the following advantages or beneficial effects: based on business requirements, the user may apply to the corresponding issuer through the DID wallet to acquire the verifiable claim, so that the user may log in to the verifier through the verifiable claim.


Alternatively, the obtaining the target claim issued by the target issuer responding to the claim application request, includes: receiving a target site address fed back by the target issuer responding to the claim application request; wherein, the target site address is located in the identity hub of the target user for storing a target claim proxy re-encrypted by the target issuer; accessing, based on the target site address, a target site in the identity hub to obtain the proxy re-encrypted target claim; and decrypting the proxy re-encrypted target claim using a target user private key to obtain the target claim.


An embodiment in the above disclosure has the following advantages or beneficial effects: since the issuance of the verifiable claim is also a data sharing process, when issuing, the issuer may also use the proxy re-encryption technology to share the issued verifiable claim with the DID wallet.


Alternatively, before the accessing, based on the target site address, the target site in the identity hub to obtain the proxy re-encrypted target claim, the method further includes: sending the target user DID to the identity hub, for the identity hub to: acquire a DID document associated with the target user DID from a blockchain network, and verify a user signature of the target user using a target user public key in the DID document, to verify whether the target user is a holder of the target user DID.


An embodiment in the above disclosure has the following advantages or beneficial effects: During interaction between participants, any one of the participants may verify the DID digital identity of the other party based on the digital identity and related information stored in the blockchain network, based on the known DID of the other party, to confirm that the other party is the true holder of the DID known, to avoid theft or forgery of digital identities by the interacting party, and to ensure the security of the interaction.


Alternatively, after the obtaining the target claim issued by the target issuer responding to the claim application request, the method includes: acquiring a revocation list address from the target claim; accessing the revocation list address and obtaining a revocation list, from a personal revocation service site of the issuer that issues the target claim; and querying a revocation status of the target claim based on the revocation list.


An embodiment in the above disclosure has the following advantages or beneficial effects: the issuer may also revoke an issued verifiable claim. Accordingly, other participants may query the revocation status of the verifiable claim based on the revocation list address recorded in the verifiable claim to avoid using invalid verifiable claim.


Alternatively, before the acquiring the target login information of the target verifier, in response to the login operation of the target user on the target verifier, the method further includes: creating the target user DID and at least one public and private key pair for the target user, in response to a DID creation request of the target user.


An embodiment in the above disclosure has the following advantages or beneficial effects: the DID wallet provides the user with a DID creation service to provide the user with a globally unique digital identity.


In a second aspect, embodiments of the present disclosure provide a method for verifying digital identity, executed by a verifier. The method includes: in response to a login request including a target user decentralized identity, DID, of a target user sent by a target DID wallet, acquiring a target claim of the target user from an identity hub of the target user; verifying the target user DID and the target claim; and determining that the target user successfully logs in using the target user DID, in response to the target user DID and the target claim passing the verification.


An embodiment in the above disclosure has the following advantages or beneficial effects: by adding and defining architectures such as the DID wallet and the identity hub to a DID standard formulated by W3C, the working process and access method of the entire digital identity verification system is clarified based on the interaction between the DID wallet, the identity hub and other existing structures, and a complete digital identity verification system is realized, so that the verifier allows the user to log in using DID with the verification of the DID and the verifiable claim.


Alternatively, the acquiring the target claim of the target user from the identity hub of the target user, includes: acquiring a target site address storing the target claim, based on an authorization result of the target DID wallet for the verifier; and accessing a target site of the identity hub based on the target site address to obtain the target claim.


An embodiment in the above disclosure has the following advantages or beneficial effects: the target site address is used to instruct the target verifier to acquire the designated verifiable claim, and then when the verifier receives the target site address, it is authorized by the DID wallet to realize the sharing of the verifiable claim.


Alternatively, the accessing the target site of the identity hub based on the target site address to obtain the target claim, includes: accessing the target site of the identity hub based on the target site address, to obtain an encrypted target claim and a re-encrypted ciphertext; wherein the encrypted target claim and the re-encrypted ciphertext are encrypted and generated based on a proxy re-encryption mechanism; decrypting the re-encrypted ciphertext using a verifier private key, to obtain a symmetric encryption key; and decrypting the encrypted target claim using the symmetric encryption key, to obtain the target claim.


An embodiment in the above disclosure has the following advantages or beneficial effects: the proxy re-encryption mechanism is used to realize the sharing of the verifiable claim, avoid the leak of the verifiable claim and ensure the security of the data.


Alternatively, the verifying the target user DID and the target claim, includes: verifying whether the target user is a holder of the target user DID, according to a user signature of the target user; and in response to verifying that the target user is the holder of the target user DID, verifying the target claim based on at least one of: an issuer issuing the target claim, a claim type, a validity period, or a revocation status of the target claim.


An embodiment in the above disclosure has the following advantages or beneficial effects: during interaction between participants, any one of the participants may verify the DID digital identity of the other party based on the known DID of the other party, to confirm that the other party is the true holder of the DID known, to avoid theft or forgery of digital identities by the interacting party, and to ensure the safety of the interaction. Therefore, the verifier may determine whether the user has a login authority by verifying the verifiable claim on the premise that the DID is verified.


Alternatively, the verifying whether the target user is the holder of the target user DID, according to the user signature of the target user, includes: acquiring a DID document associated with the target user DID from a blockchain network, based on the target user DID; and verifying the user signature of the target user, based on a target user public key in the DID document associated with the target user DID, to verify whether the target user is the holder of the target user DID.


An embodiment in the above disclosure has the following advantages or beneficial effects: for a login verifier that requires verifiable claim verification, the verifiable claim verification may be used to verify whether the user has authority to login, to ensure the safety of user login and the safety of the verifier.


In the third aspect, some embodiments of the present disclosure provide an apparatus for verifying digital identity, configured in a decentralized identity, DID, wallet. The apparatus includes: a login information acquisition module, configured to acquire target login information of a target verifier, in response to a login operation of a target user on the target verifier; a claim authorization module, configured to send, based on the target login information, a login request including a target user DID to the target verifier, to authorize the target verifier to obtain a target claim of the target user from an identity hub of the target user and verify the target user DID and the target claim; and a verifier login module, configured to log in to the target verifier using the target user DID, in response to the target user DID and the target claim passing the verification.


In a fifth aspect, some embodiment of the present disclosure provide an electronic device. The electronic device includes: at least one processor; and a memory, communicatively connected to the at least one processor; where, the memory, storing instructions executable by the at least one processor, the instructions, when executed by the at least one processor, cause the at least one processor to perform the method for verifying digital identity according to the first aspect, or to perform the method for verifying digital identity according to the second aspect.


In a sixth aspect, some embodiments of the present disclose provide a non-transitory computer readable storage medium, storing computer instructions, the computer instructions, being used to cause the computer to perform the method for verifying digital identity according to the first aspect, or to perform the method for verifying digital identity according to the second aspect.


An embodiment in the above disclosure has the following advantages or beneficial effects: the user may operate the DID wallet to acquire the target login information of the target verifier, and then the user may send a login request to the target verifier through the DID wallet by using a target user DID account, to authorize the target verifier to acquire the target claim of the target user from the identity hub of the target user, thus, based on the verification on the target user DID and the target claim by the target verifier, the target user DID is used to log in to the target verifier. Embodiments of the present disclosure, by adding and defining architectures such as the DID wallet and the identity hub to a DID standard formulated by W3C, the working process and access method of the entire digital identity verification system is clarified based on the interaction between the DID wallet, the identity hub and other existing structures, and a complete digital identity verification system is realized, providing users or enterprises with the DID wallet that uses and manages DID accounts, and ensuring an absolute ownership and control of digital identities.


Other effects of the above alternative methods will be described below in conjunction with specific embodiments.





BRIEF DESCRIPTION OF THE DRAWINGS

The accompanying drawings are used to better understand the present solution and do not constitute a limitation to the present disclosure, in which:



FIG. 1 is a schematic structural diagram of a digital identity verification system provided by an embodiment of the present disclosure;



FIG. 2 is a flowchart of a method for verifying digital identity according to a first embodiment of the present disclosure;



FIG. 3 is a flowchart of logging in to a verifier by using DID according to the first embodiment of the present disclosure;



FIG. 4 is an example diagram of authorizing a verifier to acquire a claim according to the first embodiment of the present disclosure;



FIG. 5 is a flowchart of a method for verifying digital identity according to a second embodiment of the present disclosure;



FIG. 6 is an example diagram of a verifier acquiring a claim according to the second embodiment of the present disclosure;



FIG. 7 is a flowchart of logging in to a verifier by using DID and claim according to the second embodiment of the present disclosure;



FIG. 8 is a flowchart of applying for a claim according to a third embodiment of the present disclosure;



FIG. 9 is a schematic diagram of applying for a claim according to the third embodiment of the present disclosure;



FIG. 10 is a schematic diagram of issuing a claim according to the third embodiment of the present disclosure;



FIG. 11 is a schematic diagram of revoking a claim according to the third embodiment of the present disclosure;



FIG. 12 is a flowchart of a method for verifying digital identity according to a fourth embodiment of the present disclosure;



FIG. 13 is a flowchart of a method for verifying digital identity according to a fifth embodiment of the present disclosure;



FIG. 14 is a schematic diagram of verifying a claim according to the fifth embodiment of the present disclosure;



FIG. 15 is a schematic structural diagram of an apparatus for verifying digital identity according to a sixth embodiment of the present disclosure;



FIG. 16 is a schematic structural diagram of an apparatus for verifying digital identity according to a seventh embodiment of the present disclosure; and



FIG. 17 is a block diagram of an electronic device used to implement the method for verifying digital identity according to an embodiment of the present disclosure.





DETAILED DESCRIPTION OF EMBODIMENTS

The following describes exemplary embodiments of the present disclosure with reference to the accompanying drawings, which include various details of embodiments of the present disclosure to facilitate understanding, and should be regarded as merely exemplary. Therefore, those of ordinary skill in the art should realize that various changes and modifications may be made to the embodiments described herein without departing from the scope and spirit of the present disclosure. Likewise, for clarity and conciseness, descriptions of well-known functions and structures are omitted in the following description.


In order to clearly describe the technical solution of embodiments of the present disclosure, an architecture diagram of a digital identity verification system is first introduced. FIG. 1 is an architecture schematic diagram of a digital identity verification system provided by an embodiment of the present disclosure. Based on a DID (Decentralized Identity) standard formulated by W3C (World Wide Web Consortium), the system adds and defines architectures such as a DID wallet and an identity hub, and regulates interaction processes between the architectures to realize the management, verification and use on decentralized digital identity, etc. DID may be used to identify the identity of an individual, the identity of an organization, or even the identity of an item.


Referring to FIG. 1, the system includes a claim issuer registry 110, an issuer 120, a DID holder 130, a verifier 140 and a DID subsystem 150, etc. Each of the participants has a DID account, as the participant's globally unique digital identity.


The claim issuer registry 110 is used to uniformly release service information of the public and known issuer 120 to the public, so as to facilitate a user to apply for a verifiable credential claim (referred to as claim in the present disclosure for short).


The issuer 120 may register with the claim issuer registry 110 in advance, to configure the service information thereof in the claim issuer registry 110 for release. The service information may include service site information, applicable claim type, and information required from an applicant, etc. The issuer 120 may particularly include a claim issuer service 121 and a claim revocation service 122. The claim issuer service 121 is used for issue a claim. For example, a bank, as an issuer, may use the DID account of the bank to issue an asset certificate for customers of the bank. The claim revocation service 122 is used to revoke a claim issued by the issuer 120. The issuer also includes a personal revocation service endpoint, which is used to store a claim revocation list.


The DID holder 130 includes a DID wallet 131 and an identity hub 132. The DID wallet 131 may be any form of application, such as a small program. Through the DID wallet 131, a user may create a DID, update a DID document, use the DID to apply to the issuer 120 for a claim, and use the DID to log in to the verifier 140. The DID may be used as a key domain and the DID document may be used as a value domain, which are stored in a blockchain network as a key-value pair. The DID document is used to store detailed data associated with a DID account, such as key information and site access information. The identity hub 132 refers to a user data warehouse that is controllable by the user, allowing to be independently deployed and used by the user, and is used to functions of hosting user data and authorizing accessing.


The verifier 140 refers to a third-party application, website, organization, or device that can be logged in by using DID, or DID and claim. The verifier 140 is for verifying whether the DID holder 130 owns the DID based on the challenge-response mechanism, requesting required claim from the DID holder 130, and performing digital identity verification on the obtained claim.


The DID subsystem 150 provides DID on-chain and DID resolver services. Particularly, after a user creates a DID by using the DID wallet 131, the user only has an offline DID at this time. To make the DID truly effective, the DID-related information, served as the DID document, needs to be put on-chain. DID resolve, that is, the DID subsystem 150 provides the function of resolving the DID document from the DID. During a user logs in on the verifier 140, the verifier 140 needs to confirm whether the user is the holder of the DID through challenge-response mechanism, and the core of challenge-response is that the verifier 140 constructs a challenge based on a public key in the DID document to make the user respond. Therefore, the verifier 140 may obtain the DID document through DID resolve.


Correspondingly, the system includes a blockchain network for storing digital identities and related information, and a blockchain Layer 2 (L2) node (DID germ) is used to package a DID operation into a transaction on-chain, thereby increasing TPS (Transactions Per Second) of Layer 1 (L1) of the blockchain. Correspondingly, the issuer 120, the DID holder 130, and the verifier 140 may use the digital identities and other related information as transaction data, and put the data onto the blockchain network for storage through the DID subsystem 150, realizing the addition, deletion, modification, and checking of the digital identities and other related information. The DID subsystem 150 may also acquire the digital identities and other related information from the blockchain network for digital identity verification. Alternatively, the issuer 120, the DID holder 130, and the verifier 140 may also serve as blockchain nodes or lightweight nodes, to directly send requests to the blockchain, and receive the transaction data fed back by the blockchain network. In addition, the system may also include a DIF universal resolver for resolving all DIDs.


In embodiments of the present disclosure, following the DID standard formulated by W3C, the format of DID is defined as follows:


did:ccp:<DID String>.


Here, ccp represents the DID specification proposed in the present embodiment. The present embodiment does not limit the proposed DID specification, and any DID specification proposed based on the framework of the digital identity verification system in the present embodiment may be applied to the present embodiment. DID String is a globally unique identifier of digital identity. The present embodiment proposes an algorithm for calculating DID String, that is, using the DID document as input, and DID String is generated using the following algorithm:


<DID String>=base58(ripemd160(sha256(<Base DID Document>))). Here, base58( ), ripemd160( ), sha256( ) are encryption functions.


Correspondingly, the digital identity related information may be defined in the DID document as needed. For example, the digital identity related information may include public key list information, main public key information, backup public key information, designated public key information used for verifying DID, restored public key list, and/or site information that can use the DID.


First Embodiment


FIG. 2 is a flowchart of a method for verifying digital identity according to a first embodiment of the present disclosure. The present embodiment is applicable to the scenario where the interaction with a verifier is through a DID wallet, based on the verification on DID and claim, the user logs in to the verifier using the DID. The method may be executed by the DID wallet and may be performed by an apparatus for verifying digital identity. The apparatus is implemented in software and/or hardware, and is preferably configured in an electronic device, such as a terminal device of a DID holder to which the DID wallet belongs. As shown in FIG. 2, the method specifically includes the following:


S210, acquiring target login information of a target verifier, in response to a login operation of a target user on the target verifier.


In an embodiment of the present disclosure, the target user refers to a user who uses the DID wallet, which may be an individual user or an enterprise user. If the target user owns a DID account, the user may directly use the DID wallet to manage and use the DID and related information thereof. The addition, deletion, modification, and checking of the DID and related information thereof may also be synchronized to the blockchain network. If the target user does not currently owns a DID account, the user may create a DID account for himself through the DID wallet. Correspondingly, in response to a DID creation request of the target user, the DID wallet creates a target user DID and at least one pair of public and private key for the target user. A plurality of pairs of public and private key may be master and backup for each other, and the usage method of the plurality of pairs of public and private key may be recorded in a DID document associated with the created DID account.


In the present embodiment, the target verifier refers to a platform that the target user is to log in using the DID, such as a third-party application, website, institution, or device. The DID wallet may log in to the target verifier based on a variety of methods, such as an account and password login mode or scanning a quick response (QR) code.


In the present embodiment, the target login information refers to information required to log in to the target verifier, which may include login address loginUrl of the target verifier, unique identifier loginID used to identify a login behavior of the target user, a target verifier DID, required claim type and other information.


Particularly, the target user may perform the login operation on the DID wallet based on a login mode of the target verifier, and acquire the target login information of the target verifier accordingly. Furthermore, based on the target verifier DID in the target login information, the DID document associated with the target verifier DID may be obtained from the blockchain network, so as to acquire a target verifier public key from the DID document for encryption and use during data sharing.


For example, the target user may operate on a local page or page of other devices to select a target verifier to log in, and choose to use DID login/verification mode, to display a QR code for logging in to the target verifier on the page. The target user uses the DID wallet to scan the QR code and confirm the login on the DID wallet. Correspondingly, the DID wallet may obtain the target login information carried on the QR code by scanning the QR code.


S220, sending, based on the target login information, a login request including a target user DID to the target verifier, to authorize the target verifier to acquire a target claim of the target user from an identity hub of the target user and verify the target user DID and the target claim.


In an embodiment of the present disclosure, the login request is used to trigger the target verifier to perform digital identity verification on the target user who is to log in. The login request may include information such as the target user DID, loginID, and user signature. Correspondingly, the target verifier may associate a series of login behaviors of the target user based on the loginID, and may also acquire a DID document associated with the target user DID from the blockchain network based on the target user DID to obtain a target user public key from the DID document, and verify the user signature using the target user public key, to verify whether the target user is the true holder of the target user DID, and prevent digital identities from being leaked or forged.


In the present embodiment, for the login mode that only uses DID to log in to the verifier, the flow is as shown in FIG. 3. The DID wallet obtains the login information by scanning the QR code of the target verifier and sends the login request to the target verifier. After receiving the login request and verifying the DID, the target verifier may first randomly generate a Nonce (Number Once, a random number value) and save the same, use the target user public key to encrypt the Nonce to obtain a cipherText and feed back the ciphertext to the DID wallet. Correspondingly, the DID wallet uses a target user private key PrivKey to decrypt the ciphertext, to obtain a plainText and feed back the plaintext to the target verifier. Therefore, the target verifier verifies a challenge-response result, determines the Nonce and the plaintext associated with the Nonce based on the loninID, and compares the Nonce with the plaintext. If the compare result is detected as consistent, then the target verifier polls to know that the challenge is successful, and that the target user successfully logs in is determined.


In the present embodiment, for the login mode that uses DID and claim to log in to the verifier, since the target claim of the target user is stored in its own identity hub, therefore, the DID wallet needs to authorize the target verifier to obtain the target claim of the target user from the identity hub of the target user after sending the login request to the target verifier, to verify the target claim.


Particularly, FIG. 4 is an example diagram of authorizing a verifier to acquire a claim. As shown in FIG. 4, after receiving the login request, the target verifier sends a claim acquisition request to the DID wallet. If the DID wallet saves the claim locally, the claim may be directly returned to the target verifier. If the DID wallet does not save the claim locally, the DID wallet may acquire a target site address storing the target claim in the identity hub, and send the target site address storing the target claim in the identity hub to the target verifier, to instruct the target verifier to acquire the designated target claim without infringing the safety of other data information. Correspondingly, after obtaining the authorization from the DID wallet, the target verifier may access a target site of the identity hub based on the target site address, and obtain the target claim from the target site and verify the target claim. For example, verifying whether the target claim is issued by a trusted issuer, verifying whether the target claim is required for logining the target verifier, and verifying a revocation status of the target claim. The process details will be described in subsequent embodiments.


In order to achieve safe sharing of the target claim, the DID wallet may encrypt the target claim based on a proxy re-encryption mechanism before sending the target site address storing the target claim in the identity hub to the target verifier. Particularly, the DID wallet uses an AES (advanced encryption standard) key to encrypt the target claim to obtain a encrypted target claim, uses the target user public key to encrypt the AES key to obtain a symmetric key ciphertext, calculates to obtain a re-encryption key based on the target user private key and the target verifier public key acquired from the DID document associated with the target verifier DID. The encrypted target claim, the symmetric key ciphertext, and the re-encryption key are stored in the target site address of the identity hub. Furthermore, the identity hub uses the re-encryption key to re-encrypt the symmetric key ciphertext, to generate a re-encrypted ciphertext and store the same. Correspondingly, under the authorization of the target site address, the target verifier acquires the encrypted target claim and the re-encrypted ciphertext based on the target site address, and decrypts the re-encrypted ciphertext based on a target verifier private key to obtain a symmetric encryption key. The encrypted target claim is decrypted based on the symmetric encryption key to obtain the target claim.


In the present embodiment, for a user who does not own a claim may apply to the issuer. Correspondingly, the issuer may also revoke a claim issued by itself. Particularly, the DID wallet searches for a target issuer that issues the claim, based on service information of issuers in a claim issuer registry, and sends a claim application request to the target issuer, and obtains the target claim issued by the target issuer respond to the claim application request. When applying for the claim, the DID wallet may actively provide the target issuer with the target site address, which is for storing the target claim, in the identity hub, or the target issuer determines the target site address. Furthermore, after generating the target claim, the target issuer encrypts the target claim based on the proxy re-encryption mechanism, and stores the re-encrypted target claim in the target site address, and feeds the target site address back to the DID wallet. Correspondingly, the DID wallet accesses the target site in the identity hub based on the target site address, to obtain the re-encrypted target claim; and uses the target user private key to decrypt the re-encrypted target claim to obtain the target claim.


In the digital identity verification system of the present embodiment, each of the participants needs to verify each other's DID, i.e., digital identity, before interaction. Therefore, before accessing the target site in the identity hub based on the target site address, the DID wallet may send the target user DID to the identity hub. The identity hub acquires the DID document associated with the target user DID from the blockchain network, and uses the target user public key in the DID document to verify the user signature of the target user to verify whether the target user is the holder of the target user DID.


S230, logging in to the target verifier using the target user DID, in response to the target user DID and the target claim passing the verification.


In an embodiment of the present disclosure, the DID wallet or the target verifier may detect whether the target user DID and the target claim pass the verification based on a polling method. If the DID wallet detects that the target user DID and the target claim passes the verification, the target user DID is used to log in to the target verifier. If the target verifier detects that the target user DID and the target claim pass the verification, it is confirmed that the target user successfully logs in using the target user DID.


In the technical solution of the present embodiment, the user may operate the DID wallet, to acquire the target login information of the target verifier, so that the user may use the target user DID account to send the login request to the target verifier through the DID wallet, to authorize the target verifier to acquire the target claim of the target user from the identity hub of the target user; thus, based on the verification on the target user DID and the target claim by the target verifier, the target user DID is used to log in to the target verifier. Embodiments of the present disclosure, by adding and defining architectures such as the DID wallet and the identity hub to a DID standard formulated by W3C, the working process and access method of the entire digital identity verification system is clarified based on the interaction between the DID wallet, the identity hub and other existing structures, and a complete digital identity verification system is realized, providing users or enterprises with the DID wallet that uses and manages DID accounts, and ensuring an absolute ownership and control of digital identities.


Second Embodiment


FIG. 5 is a flowchart of a method for verifying digital identity according to a second embodiment of the present disclosure. On the basis of the above first embodiment, the present embodiment further describes the process of the DID wallet authorizing the target verifier to acquire the designated claim. With the assistance of the blockchain network, the proxy re-encryption technology, and the identity hub, the target verifier is authorized. As shown in FIG. 5, the method specifically includes the following:


S510, acquiring target login information of a target verifier, in response to a login operation of a target user on the target verifier.


S520, sending, based on the target login information, a login request including a target user DID to the target verifier.


S530, acquiring, based on a target verifier DID, a DID document associated with the target user DID from a blockchain network.


In an embodiment of the present disclosure, the DID and DID document associated with the DID are stored in the blockchain network in the form of a key-value pair. After acquiring the target login information, the DID wallet may obtain the DID document associated with the target verifier DID from the blockchain network based on the target verifier DID, to acquire the target verifier public key from the DID document for encryption and use during data sharing.


S540, encrypting the target claim based on a proxy re-encryption mechanism.


In an embodiment of the present disclosure, the proxy re-encryption is a key conversion mechanism between ciphertexts. In proxy re-encryption, a semi-trusted proxy uses a conversion key generated by a proxy authorizer to convert the ciphertext encrypted with a public key of the authorizer into a ciphertext encrypted with a public key of an authorized person, realizing data sharing. In this process, the proxy cannot obtain plaintext information of the data, thereby reducing the risk of data leakage and improving the security of data sharing.


In the present embodiment, based on the proxy re-encryption mechanism, the DID wallet acquires the target verifier public key from the DID document associated with the target verifier DID based on the target user public key, and first encrypts the to-be-shared target claim.


Alternatively, the target claim is encrypted using an AES key to obtain an encrypted target claim; the AES key is encrypted using a target user public key to obtain a symmetric key ciphertext; a re-encryption key is obtained by calculating based on a target user private key and a target verifier public key acquired from the DID document associated with the target verifier DID; and the encrypted target claim, the symmetric key ciphertext, and the re-encryption key are stored to the target site address of the identity hub, to control the identity hub to use the re-encryption key to re-encrypt the symmetric key ciphertext, to generate a re-encrypted ciphertext and store the same.


In the present embodiment, the DID wallet sends the encrypted target claim and re-encrypted information generated by the encryption to the identity hub. The identity hub re-encrypts the encrypted target claim based on the re-encryption information, and saves the proxy re-encryption information in the target site address, for the target verifier to pull the re-encrypted claim from the identity hub, and obtain the target claim through decryption.


S550, sending a target site address storing the target claim in the identity hub to the target verifier, to authorize the target verifier to: access a target site of the identity hub based on the target site address, to obtain the target claim, and verify the target user DID and the target claim.


In an embodiment of the present disclosure, the target site address is used to authorize the target verifier to acquire the target claim. The sending of the target site address triggers the access to the target site of the identity hub based on the target site address, to obtain the proxy re-encrypted target claim. The encrypted target claim and the re-encrypted ciphertext are acquired based on the target site address, the re-encrypted ciphertext is decrypted based on the target verifier private key to obtain the symmetric encryption key, and the encrypted target claim is decrypted based on the symmetric encryption key to obtain the target claim.


In the present embodiment, after acquiring the target login information, the DID wallet may first acquire the target verifier public key and encrypts the target claim, and then synchronously sends the target site address to the target verifier for authorization when sending the login request to the target verifier. Or, after acquiring the target login information and sending the login request to the target verifier, the DID wallet may receive the claim acquisition request from the target verifier, and then DID wallet acquires the target verifier public key and encrypt the target claim, and return the target site address to the target verifier for authorization.


Exemplary, FIG. 6 is an example diagram of a verifier acquiring a claim. As shown in FIG. 6, after the DID wallet sends the login request to the target verifier, the target verifier sends the claim acquisition request to the DID wallet. Then, the DID wallet pulls the DID document of the target verifier based on the blockchain network, and obtains the target verifier public key therefrom. Therefore, the DID wallet encrypts the target claim based on the proxy re-encryption mechanism, and stores the re-encrypted target claim into the target site address of the identity hub. The target site address is returned to the target verifier to instruct the target verifier to acquire and decrypt to obtain the target claim from the identity hub.


S560, logging into the target verifier using the target user DID, in response to the target user DID and the target claim pass the verification.


Exemplary, FIG. 7 is a flowchart of logging in to a verifier using DID and claim. As shown in FIG. 7, the DID wallet obtains the login information by scanning QR code of the target verifier, and sends a login request including the target user DID to the target verifier. After receiving the login request and verifying the target user DID, the target verifier sends the claim acquisition request to the DID wallet. Then, based on the proxy re-encryption mechanism, the DID wallet: acquires target verifier public key appPubKey through the DID document (appDID document) associated with the target verifier DID pulled from the blockchain network; calculates to obtain re-encryption key K based on the target user private key and the target verifier public key; uses the AES key to encrypt the claim to obtain the encrypted target claim; encrypts the AES key using the target user public key to obtain the symmetric key ciphertext; and sends the symmetric key ciphertext to the identity hub, so that the identity hub uses the re-encryption key K to encrypt the symmetric key ciphertext to obtain re-encrypted ciphertext A and feeds back stored site address Endpoint to the DID wallet. At the same time, the target verifier may first randomly generate a Nonce and save the same, encrypt the Nonce using the target user public key to obtain a ciphertext, and feed the ciphertext back to the DID wallet. Correspondingly, the DID wallet uses target user private key PrivKey to decrypt the ciphertext to obtain a plainText. The DID wallet sends the plaintext and the site address to the target verifier, to control the target verifier to: acquire the encrypted target claim and the re-encrypted ciphertext A based on the site address, and decrypt the re-encrypted ciphertext A based on target verifier private key appPrivKey to obtain the symmetric encryption key, and decrypt the encrypted target claim based on the symmetric encryption key to obtain the target claim. Further, the target verifier performs a series of verifications based on information such as the target user DID, the target claim, and the plaintext. If the verification is passed, the target verifier polls to know that the challenge is successful, and it is determined that the target user successfully logs in.


In the technical solution of the present embodiment, the user may operate the DID wallet to acquire the target login information of the target verifier, then send the login request to the target verifier, perform proxy re-encryption on the claim, and send a target site address to the target verifier to authorize the target verifier to acquire the proxy re-encrypted claim from the identity hub of the target user, thereby the target verifier is logged in by using the target user DID based on that the target verifier verifies the target user DID and the target claim. Embodiments of the present disclosure, by adding and defining architectures such as the DID wallet and the identity hub to a DID standard formulated by W3C, the working process and access method of the entire digital identity verification system is clarified based on the interaction between the DID wallet, the identity hub and other existing structures, and a complete digital identity verification system is realized, providing users or enterprises with the DID wallet that uses and manages DID accounts, and ensuring an absolute ownership and control of digital identities.


Third Embodiment


FIG. 8 is a flowchart of applying for a claim according to a third embodiment of the present disclosure. On the basis of the above first embodiment, the present embodiment further describes the process of the DID wallet applying for a claim to the issuer, and the claim can be obtained through issuance by the issuer. As shown in FIG. 8, the method specifically includes the following:


S810, searching for a target issuer that issues a claim, based on service information of issuers in a claim issuer registry.


In an embodiment of the present disclosure, issuers may register with the claim issuer registry in advance to configure the service information in the claim issuer registry for release. The service information may include service site information, applicable claim type, and material required from an applicant, etc. Correspondingly, before a DID wallet applies for a claim, the DID wallet may query in the claim issuer registry to find the target issuer capable of issuing the required claim.


S820, sending a claim application request to the target issuer, to control the target issuer to generate the target claim of the target user.


In an embodiment of the present disclosure, the claim application request may include a target user signature and a target user DID. After the target issuer receives the claim application request sent by the DID wallet, the target issuer may acquire the DID document associated with the target user DID from the blockchain based on the target user DID, and acquire the target user public key therefrom, and use the target user public key to verify the target user signature, to verify that the target user is indeed the holder of the target user DID; after the verification is passed, the target issuer generates the target claim for the target user.


Exemplary, FIG. 9 is a schematic diagram of applying for a claim. As shown in FIG. 9, the issuer registers itself and an associated service site with the claim issuer registry, and declares information that a claim applicant needs to provide. The DID wallet searches in the claim issuer registry for a target issuer capable of providing the claim, and sends the claim application request to the service site of the target issuer to obtain an acceptance ID, which is used to globally identify this application behavior of the target user.


S830, acquiring the target claim issued by the target issuer responding to the claim application request.


In an embodiment of the present disclosure, FIG. 10 is a schematic diagram of issuing a claim. As shown in FIG. 10, after accepting the claim application, the target issuer first verifies the claim application request and information contained therein. Particularly, in addition to verifying the signature of the target user, the target issuer may also verify the information contained in the request with the help of an external platform to verify whether the information is required by the present issuer and the correctness of the information. The external platform may be a bank or a public security bureau.


If the verification is passed, the target issuer stores the generated target claim to the target site address in the identity hub of the target user, and feeds back the target site address to the DID wallet to authorize the target user to access. The target site address may be provided by the target user, or may be designated later by the issuer, so that the target user may directly access the target claim.


Alternatively, receiving a target site address fed back by the target issuer responding to the claim application request; where, the target site address is located in the identity hub of the target user, for storing a target claim proxy re-encrypted by the target issuer; accessing, based on the target site address, a target site in the identity hub to obtain the proxy re-encrypted target claim; and decrypting the proxy re-encrypted target claim using a target user private key to obtain the target claim. For example, the DID wallet may query an result of the issuing with the target issuer based on the acceptance ID to obtain the target site address.


Alternatively, before the accessing, based on the target site address, the target site in the identity hub, the target user DID is sent to the identity hub for the identity hub to: acquire a DID document associated with the target user DID from a blockchain network and verify a user signature of the target user using a target user public key in the DID document to verify whether the target user is the holder of the target user DID. Finally, the DID wallet sends the target user DID to the identity hub for the identity hub to verify the target user DID. If the verification is passed, the DID wallet accesses the target site in the identity hub based on the target site address, to obtain the target claim issued by the target issuer.


Before the target issuer stores the generated target claim into the identity hub, the target issuer may also perform proxy re-encryption on the target claim based on the proxy re-encryption mechanism. Correspondingly, after obtaining the proxy re-encrypted target claim, the DID wallet decrypts the proxy re-encrypted target claim to obtain the target claim, ensuring the security of data sharing.


In addition, the issuer may revoke a claim issued by itself, and store claim revocation information in a revocation list, which is a public address that everyone may access, and the revocation list is saved in a personal revocation service site of the issuer. Particularly, FIG. 11 is a schematic diagram of revoking a claim. As shown in FIG. 11, the issuer may write a revocation list address into the corresponding claim. Accordingly, the DID wallet may acquire the revocation list address from the target claim; access the revocation list address and obtain the revocation list, from the personal revocation service site of the issuer that issues the target claim; and query a revocation status of the target claim based on the revocation list.


In the technical solution of the present embodiment, based on transaction requirements, the user may apply, through the DID wallet, to the corresponding issuer to obtain the claim, and obtain the claim through issuance by the issuer, so that the user may log in to the verifier through the claim.


Fourth Embodiment


FIG. 12 is a flowchart of a method for verifying digital identity according to the scenario where the interaction with a verifier is through a DID wallet, based on the verification on DID and claim, the user logs in to the verifier using the DID. The method may be executed by the verifier and may be performed by an apparatus for verifying digital identity. The apparatus is implemented in software and/or hardware, and is preferably configured in an electronic device, such as a backend server of the verifier. As shown in FIG. 12, the method specifically includes the following:


S1210, in response to a login request including a target user decentralized identity, DID, of a target user sent by a target DID wallet, acquiring a target claim of the target user from an identity hub of the target user.


In an embodiment of the present disclosure, the login request is used to trigger the verifier to perform digital identity verification on the target user who is to log in. The login request may include information such as the target user DID, loginID, and/or user signature. The verifier may link a series of login behaviors of the target user based on the loginID, and may also acquire a DID document associated with the target user DID from a blockchain network based on the target user DID, to acquire a target user public key from the DID document and verify the user signature using the target user public key, to verify that the target user is the true holder of the target user DID, preventing digital identities from being leaked or forged.


In the present embodiment, since the target claim of the target user is stored in its own identity hub, the verifier may be authorized by the target decentralized identity DID wallet (target DID wallet) to obtain the target claim of the target user from the identity hub of the target user.


Particularly, acquiring a target site address storing the target claim, based on an authorization result of the target DID wallet for the verifier; and accessing a target site of the identity hub based on the target site address to obtain the target claim. A encrypted target claim and a re-encrypted ciphertext are encrypted and generated based on a proxy re-encryption mechanism. Therefore, the verifier may: access the target site of the identity hub based on the target site address to obtain the encrypted target claim and the re-encrypted ciphertext; decrypt the re-encrypted ciphertext using a verifier private key to obtain a symmetric encryption key; and decrypt the encrypted target claim using the symmetric encryption key to obtain the target claim.


S1220, verifying the target user DID and the target claim.


In an embodiment of the present disclosure, the verification on the target user DID is used to verify whether the current user is the true holder of the target user DID, to avoid theft or forgery of digital identities. The verification on the target claim is used to verify whether the current user has an authority, or whether it is authorized by a valid issuer verification, to log in to the verifier.


Particularly, whether the target user is the holder of the target user DID is verified according to the user signature of the target user. That is, acquiring a DID document associated with the target user DID from a blockchain network, based on the target user DID; and verifying the user signature of the target user, based on a target user public key in the DID document associated with the target user DID, to verify whether the target user is the holder of the target user DID. If the target user DID passes the verification, the target claim is verified based on at least one of: an issuing issuer, a claim type, a validity period, or a revocation status of the target claim.


S1230, determining that the target user successfully logs in using the target user DID, in response to the target user DID and the target claim passing the verification.


In the technical solution of the present embodiment, after receiving the login request sent by the target DID wallet, the verifier may acquire, based on the authorization of the target DID wallet, the target claim of the target user from the identity hub of the target user, and verify the target user DID and the target claim. After confirming that the verification is passed, it may be determined that the target user successfully logs in using the target user DID. Embodiments of the present disclosure, by adding and defining architectures such as the DID wallet and the identity hub to a DID standard formulated by W3C, the working process and access method of the entire digital identity verification system is clarified based on the interaction between the DID wallet, the identity hub and other existing structures, and a complete digital identity verification system is realized, providing users or enterprises with the DID wallet that uses and manages DID accounts, and ensuring an absolute ownership and control of digital identities.


Fifth Embodiment


FIG. 13 is a flowchart of a method for verifying digital identity according to a fifth embodiment of the present disclosure. On the basis of the above first embodiment, the present embodiment further describes the process of acquiring and verifying a claim, and can acquire the target claim based on the target site address provided by the target DID wallet and verify the acquired target claim. As shown in FIG. 13, the method specifically includes the following:


S1310, acquiring a target site address storing the target claim based on an authorization result of the target DID wallet for the verifier, in response to a login request including a target user DID sent by a target DID wallet.


In an embodiment of the present disclosure, after receiving a login request sent by the target DID wallet, the verifier may send a claim acquisition request to the target DID wallet to request the target DID wallet to authorize the acquiring of the target claim. If the target DID wallet feeds back the target site address, it may be regarded as being authorized by the target DID wallet. The target site address is located in an identity hub for storing the DID, claim and related information of the target user.


S1320, accessing a target site of the identity hub based on the target site address to obtain the target claim.


In an embodiment of the present disclosure, the verifier may access the target site of the identity hub based on the target site address to acquire the designated target claim from the target site. In view of the safety of data sharing, the target claim in the target site may be encrypted and obtained by the target DID wallet based on the re-encryption mechanism. Correspondingly, after acquired by the verifier, decryption is required to obtain the real target claim.


Alternatively, accessing the target site of the identity hub based on the target site address, to obtain a encrypted target claim and a re-encrypted ciphertext; where the encrypted target claim and the re-encrypted ciphertext are encrypted and generated based on a proxy re-encryption mechanism; decrypting the re-encrypted ciphertext using a verifier private key to obtain a symmetric encryption key; and decrypting the encrypted target claim using the symmetric encryption key to obtain the target claim.


S1330, verifying whether the target user is a holder of the target user DID, according to a user signature of the target user.


In an embodiment of the present disclosure, the login request may also include the user signature of the target user, so that the verifier verifies the target user DID.


Alternatively, obtaining a DID document associated with the target user DID from a blockchain network, based on the target user DID; and verifying the user signature of the target user, based on a target user public key in the DID document associated with the target user DID, to verify whether the target user is the holder of the target user DID.


S1340, in response to the target user being the holder of the target user DID, verifying the target claim based on at least one of: an issuing issuer, a claim type, a validity period, or a revocation status of the target claim.


In an embodiment of the present disclosure, the relevant information, claim type, validity period and other information of the issuer which issues the target claim may be stored in the DID document. Correspondingly, the verifier may: acquire the issuer issuing the target claim to verify whether the issuer is a trusted issuer; verify whether the target claim is the claim required for logging in to the present verifier based on the claim type; verify whether the target claim is currently within a limited use period based on the validity period; may also acquire a revocation list address from the target claim, and access the revocation list address of a personal revocation service site of the issuer issuing the target claim to obtain a revocation list to query the revocation status of the target claim. It may be understood that only when all of the relevant information of the target claim passes the verification can it be determined that the target claim is verified.


Exemplary, FIG. 14 is a schematic diagram of verifying a claim. As shown in FIG. 14, the issuer controls the issuance and revocation of the claim, and writes the revocation list address in the claim. After applying for and obtaining the claim, the DID wallet authorizes the verifier in the process of requesting to log in to the verifier, so that the verifier obtains the claim. Furthermore, the verifier obtains the DID document associated with the target user DID from the blockchain network based on the target user DID, and verifies the claim based on information in the DID document. At the same time, the verifier may also query the revocation status of the claim from the personal revocation service site of the issuer.


S1350, in response to the target user DID and the target claim pass the verification, determining that the target user successfully logs in using the target user DID.


In an embodiment of the present disclosure, if the authenticity verification on the target user DID is passed, the issuer issuing the target claim is a trusted organization, the target claim is the claim type required for login, and the target claim is within the validity period and has not been revoked, then it is determined that the target user DID and the target claim pass the verification, and it is further determined that the target user successfully logs in using the target user DID.


The verification on the claim is not limited to the above example, and any verification method may be applied in the present embodiment.


In the technical solution of the present embodiment, after receiving the login request sent by the target DID wallet, the verifier may: acquire the target site address based on the authorization of the target DID wallet, acquire the target claim of the target user from the target site of the identity hub of the target user, verify the target user DID, and verify the target claim based on at least one of the issuer issuing the target claim, the claim type, the validity period, and the revocation status of the target claim. When the verification is passed, it may be determined that the target user successfully logs in using the target user DID. Embodiments of the present disclosure, by adding and defining architectures such as the DID wallet and the identity hub to a DID standard formulated by W3C, the working process and access method of the entire digital identity verification system is clarified based on the interaction between the DID wallet, the identity hub and other existing structures, and a complete digital identity verification system is realized, providing users or enterprises with the DID wallet that uses and manages DID accounts, and ensuring an absolute ownership and control of digital identities.


Sixth Embodiment


FIG. 15 is a schematic structural diagram of an apparatus for verifying digital identity according to a sixth embodiment of the present disclosure. The present embodiment is applicable to the scenario where the interaction with a verifier is through a DID wallet, based on the verification on DID and claim, the user logs in to the verifier using the DID. The apparatus may be configured in the DID wallet, and may implement the method for verifying digital identity described in any embodiment of the present disclosure. The apparatus 1500 specifically includes the following:


a login information acquisition module 1510, configured to acquire target login information of a target verifier, in response to a login operation of a target user on the target verifier;


a claim authorization module 1520, configured to send, based on the target login information, a login request including a target user DID of a target user to the target verifier, to authorize the target verifier to acquire a target claim of the target user from an identity hub of the target user and verify the target user DID and the target claim; and


a verifier login module 1530, configured to login to the target verifier using the target user DID, in response to the target user DID and the target claim passing the verification.


Alternatively, the login information acquisition module 1510 is specifically configured to: acquire the target login information including at least a target verifier DID in response to the login operation of the target user on the target verifier, for acquiring, from a blockchain network, a DID document associated with the target verifier DID based on the target verifier DID.


Alternatively, the claim authorization module 1520 is specifically configured to: send a target site address storing the target claim in the identity hub to the target verifier, to authorize the target verifier to access a target site of the identity hub based on the target site address to acquire the target claim.


Further, the apparatus 1500 further includes an encryption module 1540, particularly configured to: before sending the target site address storing the target claim in the identity hub to the target verifier, encrypting the target claim based on a proxy re-encryption mechanism.


Alternatively, the encryption module 1540 is specifically configured to: encrypt the target claim using an advanced encryption standard, AES, key, to obtain an encrypted target claim; encrypt the AES key using a target user public key, to obtain a symmetric key ciphertext; calculate to obtain a re-encryption key, based on a target user private key, and a target verifier public key acquired from the DID document associated with the target verifier DID; and store the encrypted target claim, the symmetric key ciphertext, and the re-encryption key into the target site address of the identity hub, to control the identity hub to re-encrypt the symmetric key ciphertext using the re-encryption key to generate and store a re-encrypted ciphertext.


Alternatively, the target site address is used by the target verifier to: acquire the encrypted target claim and the re-encrypted ciphertext based on the target site address, and decrypt the re-encrypted ciphertext based on a target verifier private key to obtain a symmetric encryption key, and decrypt the encrypted target claim based on the symmetric encryption key to obtain the target claim.


Further, the apparatus 1500 further includes a claim application module 1550, configured to: before the acquiring the target login information of the target verifier, in response to the login operation of the target user on the target verifier, search for a target issuer that issues a claim, based on service information of issuers in a claim issuer registry; send a claim application request to the target issuer, to control the target issuer to generate the target claim of the target user; and obtain the target claim issued by the target issuer responding to the claim application request.


Alternatively, the claim application module 1550 is configured to: receive a target site address fed back by the target issuer responding to the claim application request, where, the target site address is located in the identity hub of the target user for storing a target claim proxy re-encrypted by the target issuer; access, based on the target site address, a target site in the identity hub to obtain the proxy re-encrypted target claim; and decrypt the proxy re-encrypted target claim using a target user private key to obtain the target claim.


Alternatively, the claim application module 1550 is specifically configured to: before the accessing, based on the target site address, the target site in the identity hub to obtain the proxy re-encrypted target claim, send the target user DID to the identity hub, for the identity hub to: acquire a DID document associated with the target user DID from a blockchain network, and verify a user signature of the target user using a target user public key in the DID document, to verify whether the target user is a holder of the target user DID.


Further, the apparatus 1500 further includes a revocation query module 1560, configured to: acquire a revocation list address from the target claim; access the revocation list address and obtain a revocation list, from a personal revocation service site of the issuer that issues the target claim; and query a revocation status of the target claim based on the revocation list.


Further, the apparatus 1500 further includes a DID creation module 1570, configured to: before the acquiring the target login information of the target verifier, in response to the login operation of the target user on the target verifier, create the target user DID and at least one public and private key pair for the target user, in response to a DID creation request of the target user.


The technical solution of the present embodiment realizes functions such as DID creation, claim application, login information acquisition, claim encryption and decryption, verifier authorization, verifier login and revocation status query, through the cooperation between various functional modules. Embodiments of the present disclosure, by adding and defining architectures such as the DID wallet and the identity hub to a DID standard formulated by W3C, the working process and access method of the entire digital identity verification system is clarified based on the interaction between the DID wallet, the identity hub and other existing structures, and a complete digital identity verification system is realized, providing users or enterprises with the DID wallet that uses and manages DID accounts, and ensuring an absolute ownership and control of digital identities.


Seventh Embodiment


FIG. 16 is a schematic structural diagram of an apparatus for verifying digital identity according to a seventh embodiment of the present disclosure. The present embodiment is applicable to the scenario where the interaction with a verifier is through a DID wallet, based on the verification on DID and claim, the user logs in to the verifier using the DID.


The apparatus may be configured in the verifier, and may implement the method for verifying digital identity described in any embodiment of the present disclosure. The apparatus 1600 specifically includes the following:


a claim acquisition module 1610, configured to acquire a target claim of the target user from an identity hub of the target user, in response to a login request including a target user decentralized identity, DID, of a target user sent by a target DID wallet;


a claim verification module 1620, configured to the target user DID and the target claim; and


a user login module 1630, configured to determine that the target user successfully logs in using the target user DID, in response to the target user DID and the target claim passing the verification.


Alternatively, the claim acquisition module 1610 is specifically configured to: acquire a target site address storing the target claim, based on an authorization result of the target DID wallet for the verifier; and access a target site of the identity hub based on the target site address to obtain the target claim.


Alternatively, the claim acquisition module 1610 is specifically configured to: access the target site of the identity hub based on the target site address, to obtain an encrypted target claim and a re-encrypted ciphertext, where the encrypted target claim and the re-encrypted ciphertext are encrypted and generated based on a proxy re-encryption mechanism; decrypt the re-encrypted ciphertext using a verifier private key, to obtain a symmetric encryption key; and decrypt the encrypted target claim using the symmetric encryption key, to obtain the target claim.


Alternatively, the claim verification module 1620 is specifically configured to: verify whether the target user is a holder of the target user DID, according to a user signature of the target user; in response to verifying that the target user is the holder of the target user DID, verify the target claim based on at least one of: an issuer issuing the target claim, a claim type, a validity period, or a revocation status of the target claim.


Alternatively, the claim verification module 1620 is specifically configured to: acquire a DID document associated with the target user DID from a blockchain network, based on the target user DID; and verify the user signature of the target user, based on a target user public key in the DID document associated with the target user DID, to verify whether the target user is the holder of the target user DID.


The technical solution of the present embodiment realizes functions such as claim acquisition, claim decryption, DID verification, claim verification, and user login, through the cooperation between various functional modules. Embodiments of the present disclosure, by adding and defining architectures such as the DID wallet and the identity hub to a DID standard formulated by W3C, the working process and access method of the entire digital identity verification system is clarified based on the interaction between the DID wallet, the identity hub and other existing structures, and a complete digital identity verification system is realized, providing users or enterprises with the DID wallet that uses and manages DID accounts, and ensuring an absolute ownership and control of digital identities.


Eighth Embodiment

According to an embodiment of the present disclosure, the present disclosure also provides an electronic device and a readable storage medium.


As shown in FIG. 17, which is a block diagram of an electronic device of a method for verifying digital identity according to an embodiment of the present disclosure. The electronic device is intended to represent various forms of digital computers, such as laptop computers, desktop computers, workbenches, personal digital assistants, servers, blade servers, mainframe computers, and other suitable computers. The electronic device may also represent various forms of mobile apparatuses, such as personal digital processing, cellular phones, smart phones, wearable devices, and other similar computing apparatuses. The components shown herein, their connections and relationships, and their functions are merely examples, and are not intended to limit the implementation of the present disclosure described and/or claimed herein.


As shown in FIG. 17, the electronic device includes: one or more processors 1701, a memory 1702, and interfaces for connecting various components, including high-speed interfaces and low-speed interfaces. The various components are connected to each other using different buses, and may be installed on a common motherboard or in other methods as needed. The processor may process instructions executed within the electronic device, including instructions stored in or on the memory to display graphic information of GUI on an external input/output apparatus (such as a display device coupled to the interface). In other embodiments, a plurality of processors and/or a plurality of buses may be used together with a plurality of memories if desired. Similarly, a plurality of electronic devices may be connected, and the devices provide some necessary operations (for example, as a server array, a set of blade servers, or a multi-processor system). In FIG. 17, one processor 1701 is used as an example.


The memory 1702 is a non-transitory computer readable storage medium provided by some embodiments of the present disclosure. The memory stores instructions executable by at least one processor, so that the at least one processor performs the method for verifying digital identity provided by embodiments of the present disclosure. The non-transitory computer readable storage medium of some embodiments of the present disclosure stores computer instructions for causing a computer to perform the method for verifying digital identity provided by embodiments of the present disclosure.


The memory 1702, as a non-transitory computer readable storage medium, may be used to store non-transitory software programs, non-transitory computer executable programs and modules, such as program instructions/modules corresponding to the method for processing parking in embodiments of the present disclosure (for example, the login information acquisition module 1510, the claim authorization module 1520, and the verifier login module 1530, the encryption module 1540, the claim application module 1550, the revocation query module 1560, and the DID creation module 1570 shown in FIG. 15, and the claim acquisition module 1610, the claim verification module 1620, the user login module 1630 shown in FIG. 16). The processor 1701 executes the non-transitory software programs, instructions, and modules stored in the memory 1702 to execute various functional applications and data processing of the server, that is, to implement the method for verifying digital identity in the foregoing method embodiment.


The memory 1702 may include a storage program area and a storage data area, where the storage program area may store an operating system and at least one function required application program; and the storage data area may store data created by the use of the electronic device according to the method for verifying digital identity, etc. In addition, the memory 1702 may include a high-speed random access memory, and may also include a non-transitory memory, such as at least one magnetic disk storage device, a flash memory device, or other non-transitory solid-state storage devices. In some embodiments, the memory 1702 may optionally include memories remotely provided with respect to the processor 1701, and these remote memories may be connected to the electronic device of the method for processing parking through a network. Examples of the above network include but are not limited to the Internet, intranet, local area network, mobile communication network, and combinations thereof.


The electronic device of the method for verifying digital identity may further include: an input apparatus 1703 and an output apparatus 1704. The processor 1701, the memory 1702, the input apparatus 1703, and the output apparatus 1704 may be connected through a bus or in other methods. In FIG. 17, connection through a bus is used as an example.


The input apparatus 1703 may receive input digital or character information, and generate key signal inputs related to user settings and function control of the electronic device of the method for verifying digital identity, such as touch screen, keypad, mouse, trackpad, touchpad, pointing stick, one or more mouse buttons, trackball, joystick and other input apparatuses. The output apparatus 1704 may include a display device, an auxiliary lighting apparatus (for example, LED), a tactile feedback apparatus (for example, a vibration motor), and the like. The display device may include, but is not limited to, a liquid crystal display (LCD), a light emitting diode (LED) display, and a plasma display. In some embodiments, the display device may be a touch screen.


Various embodiments of the systems and technologies described herein may be implemented in digital electronic circuit systems, integrated circuit systems, dedicated ASICs (application specific integrated circuits), computer hardware, firmware, software, and/or combinations thereof. These various embodiments may include: being implemented in one or more computer programs that can be executed and/or interpreted on a programmable system that includes at least one programmable processor. The programmable processor may be a dedicated or general-purpose programmable processor, and may receive data and instructions from a storage system, at least one input apparatus, and at least one output apparatus, and transmit the data and instructions to the storage system, the at least one input apparatus, and the at least one output apparatus.


These computing programs (also referred to as programs, software, software applications, or codes) include machine instructions of the programmable processor and may use high-level processes and/or object-oriented programming languages, and/or assembly/machine languages to implement these computing programs. As used herein, the terms “machine readable medium” and “computer readable medium” refer to any computer program product, device, and/or apparatus (for example, magnetic disk, optical disk, memory, programmable logic apparatus (PLD)) used to provide machine instructions and/or data to the programmable processor, including machine readable medium that receives machine instructions as machine readable signals. The term “machine readable signal” refers to any signal used to provide machine instructions and/or data to the programmable processor.


In order to provide interaction with a user, the systems and technologies described herein may be implemented on a computer, the computer has: a display apparatus for displaying information to the user (for example, CRT (cathode ray tube) or LCD (liquid crystal display) monitor); and a keyboard and a pointing apparatus (for example, mouse or trackball), and the user may use the keyboard and the pointing apparatus to provide input to the computer. Other types of apparatuses may also be used to provide interaction with the user; for example, feedback provided to the user may be any form of sensory feedback (for example, visual feedback, auditory feedback, or tactile feedback); and any form (including acoustic input, voice input, or tactile input) may be used to receive input from the user.


The systems and technologies described herein may be implemented in a computing system that includes backend components (e.g., as a data server), or a computing system that includes middleware components (e.g., application server), or a computing system that includes frontend components (for example, a user computer having a graphical user interface or a web browser, through which the user may interact with the implementations of the systems and the technologies described herein), or a computing system that includes any combination of such backend components, middleware components, or frontend components. The components of the system may be interconnected by any form or medium of digital data communication (e.g., communication network). Examples of the communication network include: local area networks (LAN), wide area networks (WAN), the Internet, and blockchain networks.


The computer system may include a client and a server. The client and the server are generally far from each other and usually interact through the communication network. The relationship between the client and the server is generated by computer programs that run on the corresponding computer and have a client-server relationship with each other.


According to the technical solution of embodiments of the present disclosure, by adding and defining architectures such as the DID wallet and the identity hub to a DID standard formulated by W3C, the working process and access method of the entire digital identity verification system is clarified based on the interaction between the DID wallet, the identity hub and other existing structures, and a complete digital identity verification system is realized, providing the users or enterprises with the DID wallet that uses and manages DID accounts, and ensuring an absolute ownership and control of digital identities.


In addition, the blockchain network may store DID and related information to provide information services for various participants. Correspondingly, the DID wallet may acquire the DID document associated with the target verifier DID through the blockchain network for data encryption and sharing.


In addition, the target site address is used to instruct the target verifier to acquire the designated claim from the identity hub, and then send the target site address to achieve the purpose of authorizing the target verifier, realizing the sharing of the claim.


In addition, the proxy re-encryption mechanism is used to realize the sharing of the claim, avoiding the leakage of the claim and ensuring data security.


In addition, the purpose of the proxy re-encryption mechanism lies in that the data encrypted based on the target user public key may be decrypted by a sharing party, i.e., the target verifier, using the target verifier private key to acquire the data, ensuring the safe sharing of the data.


In addition, the target site address is used to instruct the target verifier to acquire the designated claim.


Correspondingly, under the protection of the proxy re-encryption mechanism, the target verifier is required to decrypt the acquired claim to ensure the safe sharing of the data.


In addition, based on business requirements, the user may apply to the corresponding issuer to obtain the claim through the DID wallet, so that the user may log in to the verifier through the claim.


In addition, since the issuance of a claim is also a data sharing process, the issuer may also use the proxy re-encryption technology when issuing a claim, to share the issued claim with the DID wallet.


In addition, during the interaction between participants, any participant may perform verification on DID digital identity on the other party based on the digital identity and related information stored in the blockchain network, based on the known DID of the other party, to determine that the other party is the true owner of the known DID, avoiding theft or forgery of digital identities by the party involved in the interaction, and ensuring the safety of the interaction.


In addition, the issuer may also revoke an issued claim. Correspondingly, other participants may query the revocation status of a claim using the revocation list address recorded in the claim to avoid using invalid claims.


In addition, the DID wallet provides the user with the DID creation service to provide the user with a globally unique digital identity.


It should be understood that the various forms of processes shown above may be used to reorder, add, or delete steps. For example, the steps described in embodiments of the present disclosure may be performed in parallel, sequentially, or in different orders. As long as the desired results of the technical solution disclosed in embodiments of the present disclosure can be achieved, no limitation is made herein.


The above embodiments do not constitute limitation on the protection scope of the present disclosure. Those skilled in the art should understand that various modifications, combinations, sub-combinations and substitutions may be made according to design requirements and other factors. Any modification, equivalent replacement and improvement made within the spirit and principle of the present disclosure shall be included in the protection scope of the present disclosure.

Claims
  • 1. A method for verifying digital identity, executed by a decentralized identity (DID) wallet, the method comprising: acquiring target login information of a target verifier, in response to a login operation of a target user on the target verifier;sending, based on the target login information, a login request including a target user DID of a target user to the target verifier, to authorize the target verifier to acquire a target claim of the target user from an identity hub of the target user and verify the target user DID and the target claim; andlogging in to the target verifier using the target user DID, in response to the target user DID and the target claim passing the verification.
  • 2. The method according to claim 1, wherein the acquiring the target login information of the target verifier, in response to the login operation of the target user on the target verifier, comprises: acquiring the target login information including at least a target verifier DID in response to the login operation of the target user on the target verifier, for acquiring, from a blockchain network, a DID document associated with the target verifier DID based on the target verifier DID.
  • 3. The method according to claim 1, wherein the authorize the target verifier to acquire the target claim of the target user from the identity hub of the target user, comprises: sending a target site address storing the target claim in the identity hub to the target verifier, to authorize the target verifier to access a target site of the identity hub based on the target site address to acquire the target claim.
  • 4. The method according to claim 3, wherein, before sending the target site address storing the target claim in the identity hub to the target verifier, the method further comprises: encrypting the target claim based on a proxy re-encryption mechanism.
  • 5. The method according to claim 4, wherein the encrypting the target claim based on the proxy re-encryption mechanism, comprises: encrypting the target claim using an advanced encryption standard (AES) key, to obtain an encrypted target claim;encrypting the AES key using a target user public key, to obtain a symmetric key ciphertext;calculating to obtain a re-encryption key, based on a target user private key, and a target verifier public key acquired from the DID document associated with a target verifier DID; andstoring the encrypted target claim, the symmetric key ciphertext, and the re-encryption key into the target site address of the identity hub, to control the identity hub to re-encrypt the symmetric key ciphertext using the re-encryption key to generate and store a re-encrypted ciphertext.
  • 6. The method according to claim 5, wherein the target site address is used by the target verifier to: acquire the encrypted target claim and the re-encrypted ciphertext based on the target site address, and decrypt the re-encrypted ciphertext based on a target verifier private key to obtain a symmetric encryption key, and decrypt the encrypted target claim based on the symmetric encryption key to obtain the target claim.
  • 7. The method according to claim 1, wherein, before the acquiring the target login information of the target verifier, in response to the login operation of the target user on the target verifier, the method further comprises: searching for a target issuer that issues a claim, based on service information of issuers in a claim issuer registry;sending a claim application request to the target issuer, to control the target issuer to generate the target claim of the target user; andobtaining the target claim issued by the target issuer responding to the claim application request.
  • 8. The method according to claim 7, wherein the obtaining the target claim issued by the target issuer responding to the claim application request, comprises: receiving a target site address fed back by the target issuer responding to the claim application request;wherein, the target site address is located in the identity hub of the target user for storing a target claim proxy re-encrypted by the target issuer;accessing, based on the target site address, a target site in the identity hub to obtain the proxy re-encrypted target claim; anddecrypting the proxy re-encrypted target claim using a target user private key to obtain the target claim.
  • 9. The method according to claim 8, wherein, before the accessing, based on the target site address, the target site in the identity hub to obtain the proxy re-encrypted target claim, the method further comprises: sending the target user DID to the identity hub, for the identity hub to: acquire a DID document associated with the target user DID from a blockchain network, and verify a user signature of the target user using a target user public key in the DID document, to verify whether the target user is a holder of the target user DID.
  • 10. The method according to claim 7, wherein, after the obtaining the target claim issued by the target issuer responding to the claim application request, the method further comprises: acquiring a revocation list address from the target claim;accessing the revocation list address and obtaining a revocation list, from a personal revocation service site of the issuer that issues the target claim; andquerying a revocation status of the target claim based on the revocation list.
  • 11. The method according to claim 1, wherein, before the acquiring the target login information of the target verifier, in response to the login operation of the target user on the target verifier, the method further comprises: creating the target user DID and at least one public and private key pair for the target user, in response to a DID creation request of the target user.
  • 12. A method for verifying digital identity, executed by a verifier, the method comprising: in response to a login request including a target user decentralized identity, DID, of a target user sent by a target DID wallet, acquiring a target claim of the target user from an identity hub of the target user;verifying a target user DID and the target claim; anddetermining that the target user successfully logs in using the target user DID, in response to the target user DID and the target claim passing the verification.
  • 13. The method according to claim 12, wherein the acquiring the target claim of the target user from the identity hub of the target user, comprises: acquiring a target site address storing the target claim, based on an authorization result of the target DID wallet for the verifier; andaccessing a target site of the identity hub based on the target site address to obtain the target claim.
  • 14. The method according to claim 13, wherein the accessing the target site of the identity hub based on the target site address to obtain the target claim, comprises: accessing the target site of the identity hub based on the target site address, to obtain an encrypted target claim and a re-encrypted ciphertext; wherein the encrypted target claim and the re-encrypted ciphertext are encrypted and generated based on a proxy re-encryption mechanism;decrypting the re-encrypted ciphertext using a verifier private key, to obtain a symmetric encryption key; anddecrypting the encrypted target claim using the symmetric encryption key, to obtain the target claim.
  • 15. The method according to claim 12, wherein the verifying the target user DID and the target claim, comprises: verifying whether the target user is a holder of the target user DID, according to a user signature of the target user; andin response to verifying that the target user is the holder of the target user DID, verifying the target claim based on at least one of: an issuer issuing the target claim, a claim type, a validity period, or a revocation status of the target claim.
  • 16. The method according to claim 15, wherein the verifying whether the target user is the holder of the target user DID, according to the user signature of the target user, comprises: acquiring a DID document associated with the target user DID from a blockchain network, based on the target user DID; andverifying the user signature of the target user, based on a target user public key in the DID document associated with the target user DID, to verify whether the target user is the holder of the target user DID.
  • 17. An electronic device, comprising: at least one processor; anda memory, communicatively connected to the at least one processor, the memory, storing instructions executable by the at least one processor, the instructions, when executed by the at least one processor, causing the at least one processor to perform operations, the operations comprising:acquiring target login information of a target verifier, in response to a login operation of a target user on the target verifier;sending, based on the target login information, a login request including a target user DID of a target user to the target verifier, to authorize the target verifier to acquire a target claim of the target user from an identity hub of the target user and verify the target user DID and the target claim; andlogging in to the target verifier using the target user DID, in response to the target user DID and the target claim passing the verification.
  • 18. An electronic device, comprising: at least one processor; anda memory, communicatively connected to the at least one processor, the memory, storing instructions executable by the at least one processor, the instructions, when executed by the at least one processor, causing the at least one processor to perform the method for verifying digital identity according to claim 12.
  • 19. A non-transitory computer readable storage medium, storing computer instructions, the computer instructions, being used to cause the computer to perform the method for verifying digital identity according to claim 1.
  • 20. A non-transitory computer readable storage medium, storing computer instructions, the computer instructions, being used to cause the computer to perform the method for verifying digital identity according to claim 12.
Priority Claims (1)
Number Date Country Kind
202010037958.3 Jan 2020 CN national