Nothing Special   »   [go: up one dir, main page]

WO2018222211A1 - Secure biometric authentication using electronic identity - Google Patents

Secure biometric authentication using electronic identity Download PDF

Info

Publication number
WO2018222211A1
WO2018222211A1 PCT/US2017/035783 US2017035783W WO2018222211A1 WO 2018222211 A1 WO2018222211 A1 WO 2018222211A1 US 2017035783 W US2017035783 W US 2017035783W WO 2018222211 A1 WO2018222211 A1 WO 2018222211A1
Authority
WO
WIPO (PCT)
Prior art keywords
derivative
biometric template
user
server computer
electronic identity
Prior art date
Application number
PCT/US2017/035783
Other languages
French (fr)
Inventor
Quan Wang
Original Assignee
Visa International Service Association
Priority date (The priority date is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the date listed.)
Filing date
Publication date
Application filed by Visa International Service Association filed Critical Visa International Service Association
Priority to PCT/US2017/035783 priority Critical patent/WO2018222211A1/en
Priority to US16/618,741 priority patent/US11190355B2/en
Priority to CN201780091522.9A priority patent/CN110741369B/en
Priority to EP17911928.4A priority patent/EP3631664B1/en
Publication of WO2018222211A1 publication Critical patent/WO2018222211A1/en
Priority to US17/513,467 priority patent/US20220052852A1/en

Links

Classifications

    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F21/00Security arrangements for protecting computers, components thereof, programs or data against unauthorised activity
    • G06F21/30Authentication, i.e. establishing the identity or authorisation of security principals
    • G06F21/31User authentication
    • G06F21/32User authentication using biometric data, e.g. fingerprints, iris scans or voiceprints
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L9/00Cryptographic mechanisms or cryptographic arrangements for secret or secure communications; Network security protocols
    • H04L9/32Cryptographic mechanisms or cryptographic arrangements for secret or secure communications; Network security protocols including means for verifying the identity or authority of a user of the system or for message authentication, e.g. authorization, entity authentication, data integrity or data verification, non-repudiation, key authentication or verification of credentials
    • H04L9/3226Cryptographic mechanisms or cryptographic arrangements for secret or secure communications; Network security protocols including means for verifying the identity or authority of a user of the system or for message authentication, e.g. authorization, entity authentication, data integrity or data verification, non-repudiation, key authentication or verification of credentials using a predetermined code, e.g. password, passphrase or PIN
    • H04L9/3231Biological data, e.g. fingerprint, voice or retina
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L63/00Network architectures or network communication protocols for network security
    • H04L63/08Network architectures or network communication protocols for network security for authentication of entities
    • H04L63/0861Network architectures or network communication protocols for network security for authentication of entities using biometrical features, e.g. fingerprint, retina-scan
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L9/00Cryptographic mechanisms or cryptographic arrangements for secret or secure communications; Network security protocols
    • H04L9/32Cryptographic mechanisms or cryptographic arrangements for secret or secure communications; Network security protocols including means for verifying the identity or authority of a user of the system or for message authentication, e.g. authorization, entity authentication, data integrity or data verification, non-repudiation, key authentication or verification of credentials
    • H04L9/3236Cryptographic mechanisms or cryptographic arrangements for secret or secure communications; Network security protocols including means for verifying the identity or authority of a user of the system or for message authentication, e.g. authorization, entity authentication, data integrity or data verification, non-repudiation, key authentication or verification of credentials using cryptographic hash functions
    • H04L9/3239Cryptographic mechanisms or cryptographic arrangements for secret or secure communications; Network security protocols including means for verifying the identity or authority of a user of the system or for message authentication, e.g. authorization, entity authentication, data integrity or data verification, non-repudiation, key authentication or verification of credentials using cryptographic hash functions involving non-keyed hash functions, e.g. modification detection codes [MDCs], MD5, SHA or RIPEMD
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L9/00Cryptographic mechanisms or cryptographic arrangements for secret or secure communications; Network security protocols
    • H04L9/32Cryptographic mechanisms or cryptographic arrangements for secret or secure communications; Network security protocols including means for verifying the identity or authority of a user of the system or for message authentication, e.g. authorization, entity authentication, data integrity or data verification, non-repudiation, key authentication or verification of credentials
    • H04L9/3247Cryptographic mechanisms or cryptographic arrangements for secret or secure communications; Network security protocols including means for verifying the identity or authority of a user of the system or for message authentication, e.g. authorization, entity authentication, data integrity or data verification, non-repudiation, key authentication or verification of credentials involving digital signatures
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L9/00Cryptographic mechanisms or cryptographic arrangements for secret or secure communications; Network security protocols
    • H04L9/50Cryptographic mechanisms or cryptographic arrangements for secret or secure communications; Network security protocols using hash chains, e.g. blockchains or hash trees
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04WWIRELESS COMMUNICATION NETWORKS
    • H04W12/00Security arrangements; Authentication; Protecting privacy or anonymity
    • H04W12/06Authentication
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L2209/00Additional information or applications relating to cryptographic mechanisms or cryptographic arrangements for secret or secure communication H04L9/00
    • H04L2209/56Financial cryptography, e.g. electronic payment or e-cash

Definitions

  • the identification cards may be issued by a government agency or financial institution, which may assign an identification number or account number to a user.
  • An identification card may have an identification number, the user's name, and possibly a photograph of the user printed, embossed, and/or stored on the card.
  • the user may present the card, and any credentials on the card may be verified to authenticate the user.
  • a number of issues may arise from the use of identification cards as a means of identification.
  • users often have to carry around multiple identification cards in order to receive a variety of good and/or services.
  • a user may carry a driver's license, multiple credit/debit cards, a social security card, a medical insurance card, etc. This may be inconvenient for the user, and may further increase the chances of a user's identity being stolen.
  • the use of identification cards may be especially inconvenient when presenting credentials online, when users often need to scan or even manually enter their information.
  • the validity of an identification card is often subject to human evaluation, which can be inconsistent and assumes that a person evaluating an identification card is trustworthy.
  • Embodiments of the invention are directed to a method.
  • the method may comprise receiving a second biometric template of a user, and providing an
  • the authentication request message comprising an electronic identity and a derivative of the second biometric template of the user to a resource provider computer to conduct an interaction.
  • the authentication request may be forwarded to a processing server computer by the resource provider computer, and the user device may receive an authentication response message comprising an authentication result from the processing server computer.
  • the authentication result may be determined by the processing server computer based on a comparison of the derivative of the second biometric template to a derivative of a first biometric template accessible to the processing server computer.
  • the authentication result may also be based on the validity of the electronic identity.
  • the method may further comprise receiving the first biometric template of the user, generating the derivative of the first biometric template, and generating an identity request message for an electronic identity for the user.
  • the identity request message may comprise the derivative of the first biometric template and an account identifier of the user.
  • the method may comprise sending the identity request message to a verification server, wherein the verification server verifies the account identifier and generates the electronic identity.
  • the electronic identity may be linked to the derivative of the first biometric template in a database by the processing server computer.
  • the method may also comprise receiving an identity response message comprising the electronic identity, and storing the electronic identity in a memory of the user device for later use in an interaction.
  • FIG. 1 shows a block diagram of a system for implementing secure biometric authentication.
  • FIGS. 2A and 2B show a process flow diagram for implementing secure biometric authentication.
  • FIG. 3 shows a block diagram of a processing server computer for
  • FIG. 4 shows a block diagram of a user device for implementing biometric authentication.
  • a "server computer” may include a powerful computer or cluster of computers.
  • the server computer can be a large mainframe, a minicomputer cluster, or a group of servers functioning as a unit.
  • the server computer may be a database server coupled to a Web server.
  • a server computer may be coupled to a database and may include any hardware, software, other logic, or combination of the preceding for servicing the requests from one or more client computers.
  • a server computer may comprise one or more computational apparatuses and may use any of a variety of computing structures, arrangements, and compilations for servicing the requests from one or more client computers.
  • An "application program interface” or “API” may refer to software specifying how components of a system should interact.
  • the API may comprise a set of routines, protocols, and tools on which software applications may built.
  • An API may be for a web-based system, operating system, database system, computer hardware or software library, and may include specifications for routines, data structures, object classes, variables and/or remote calls.
  • the term “gateway” may refer to hardware or software that allows for the interfacing of network nodes using different protocols.
  • the interface can include protocol converters, proxy servers, routers, firewalls, etc.
  • a gateway may also be referred to as a "network gateway.”
  • a computer that controls the traffic from an Internet Service Provider (ISP) may be a network gateway.
  • ISP Internet Service Provider
  • authentication may refer to the process of verifying the identity of something (e.g., a user).
  • One form of authentication can be biometric authentication.
  • a “biometric” may be any human characteristic that is unique to an individual.
  • a biometric may be a person's fingerprint, face, DNA, etc.
  • a “biometric reader” may refer to a device for capturing data from an individual's biometric sample. Examples of biometric readers may include fingerprint readers, front-facing cameras, microphones, and iris scanners.
  • a “biometric sample” may refer to data obtained by a biometric reader.
  • the data may be either an analog or digital representation of the user's biometric, generated prior to determining distinct features needed for matching.
  • a biometric sample of a user's face may be image data.
  • a biometric sample of a user's voice may be an audio file.
  • a "biometric template” may refer to a file containing distinct characteristics extracted from a biometric sample that may be used during a biometric authentication process.
  • a biometric template may be a binary mathematical file representing the unique features of an individual's fingerprint, eye, hand or voice needed for performing accurate authentication of the individual.
  • zero-knowledge proof or "zero-knowledge protocol” may refer to a method of proving information is true without conveying the actual information itself.
  • secret information can be verified without be revealed. More information regarding zero-knowledge proofs may be found at:
  • the comparison of derivatives of biometric templates to verify the authenticity of a particular person may employ a zero-knowledge protocol.
  • a blockchain can be a distributed database that maintains a continuously-growing list of records secured from tampering and revision.
  • a blockchain may include a number of blocks of interaction records. Each block in the blockchain can contain also include a timestamp and a link to a previous block. For example, each block may include or be appended to a hash of the previous block. Stated differently, interaction records in a blockchain may be stored as a series of "blocks," or permanent files that include a record of a number of transactions occurring over a given period of time. Blocks may be appended to a blockchain by an appropriate node after it completes the block and the block is validated. In embodiments of the invention, a blockchain may be distributed, and a copy of the blockchain may be maintained at each node in a verification network. Any node within the verification network may
  • the security of a blockchain may be obtained using a cryptographic scheme.
  • a "digital signature” may refer to data used to provide assurance or evidence as to the origin and identity of an electronic record or message.
  • Digital signatures can be based on public key cryptography (i.e. asymmetric cryptography).
  • Digital signatures may be generated using a public key algorithm such as RSA.
  • signing software may be used to create a one-way hash of electronic data that is to be signed by a signing entity.
  • a private key of the signing entity is then used to encrypt the hash and form the digital signature.
  • validation may refer to the act of checking or affirming that information is legitimate.
  • An example may be the act of checking that a digital signature appended to an electronic record is, in fact, legitimate and of the signing entity.
  • Digital signatures may be validated according to a verification algorithm in conjunction with a signing entity's public key.
  • an “electronic identity” or “elD” may refer to a unique string of characters or symbols used to identify an individual.
  • the electronic identity may be mathematically derived from information associated with a user.
  • an electronic identity may be a value calculated by hashing one or more input values (customer name, country code, etc.) available to multiple entities. In this way, the electronic identity may be independently generated by any entity that has the prerequisite information.
  • An electronic identity may be altered (e.g., hashed and/or encrypted) information associated with a user. For example, in some
  • an electronic identity may be derived from a combination of a country code, customer name, date of birth, and last four digits of a social security number such as SHA256(USA*JOHN SMITH*19700101*1234). Hashing this value may result in a seemingly random string of characters, such as
  • an electronic identity is associated with a passphrase that is provided in order to access any interaction record associated with the electronic identity.
  • An electronic identity may sometimes be referred to as an "elD," electronic identifier, or electronic identification data.
  • An "account identifier" may refer to a sequence of numbers and/or letters for identifying an account.
  • the account can be a bank account, credit card account, government benefit account, health insurance account, etc.
  • One example of an account identifier may be a primary account number (PAN), which may be a 16-digit number used to identify that a user may use to conduct transactions.
  • PAN primary account number
  • a "know your customer” or “KYC” process may refer to the process of a business identifying and verifying the identity of its clients. The term is also used to refer to the bank and anti-money laundering regulations which govern these activities. A KYC process may be used to verify information of a user and generate an electronic identity for the user. DETAILED DESCRIPTION
  • a biometric may be any human characteristic that is unique to an individual.
  • a biometric may be a person's fingerprint, face, DNA, etc.
  • Biometric authentication may be used to identify individuals in a manner that is more convenient and efficient than typical identification methods. It may be used to identify individuals in a variety of scenarios such as logging into a network, accessing a building, or conducting a transaction. Because biometric authentication uses human characteristics rather than account information or identification cards, users of biometric authentication do not need to worry about remembering usernames and passwords or keeping track of ID cards.
  • a problem associated with implementing biometric authentication systems is privacy and security. Users often distrust biometric authentication for fear of their biometric data might be stolen or misused. In addition, entities that need to verify a user's identity (e.g. for the purpose of authorizing a transaction) also have a stake in the accuracy of authentication, and may wish to limit the proliferation of identity theft and fake identity creation.
  • Embodiments of the invention described herein address these issues by passing a user's biometric template through a derivation formula, and linking the derived biometric template to an electronic identity that is validated by trusted parties.
  • the electronic identity may be validated against records stored in a blockchain and according to a digital signature algorithm.
  • Embodiments combine blockchain technology with other biometric authentication techniques to provide a secure authentication system available through an application on a user's mobile device.
  • embodiments of the invention described herein are more secure, more efficient, and more convenient than other identification methods.
  • FIG. 1 shows a block diagram of a system for implementing secure biometric authentication.
  • System 100 may comprise processing server computer 150 for processing authentication requests in secure biometric authentication.
  • Processing server computer 150 may connect to a plurality of servers, computers, and devices across a number of protocols through a network gateway, such as gateway 130.
  • System 100 may also comprise mobile device 1 10, which may comprise authentication application 1 12.
  • Authentication application 1 12 may be an application stored on mobile device 1 10 that comprises instructions for implementing biometric authentication. This may include instructions for communicating with verification server 140, processing server computer 150, and resource provider computer 120. Authentication application 1 12 may further comprise instructions for requesting an electronic identity, which may be provided by verification server 140 through identity request API 142.
  • a computer of a resource provider such as resource provider computer 120, may comprise authentication API 122 for
  • Resource provider computer 120 may authenticate the user by receiving user data from mobile device 1 10, which may be forwarded to processing server computer 150 to receive an authentication result.
  • the processing server computer 150 may determine the authentication result through communications with authentication server 160, and based on data stored in
  • Mobile device 1 10 may be any mobile device for communicating and storing user data of a user.
  • mobile device 1 10 may be a smart phone, smart wearable device (e.g. smart watch or eyewear), or any other portable communications device owned by the user.
  • Mobile device 1 10 may store and communicate user data by way of one or more applications such as authentication application 1 12.
  • the user data may include a user's electronic identity and a derivative of the user's biometric template.
  • mobile device 1 10 may also comprise a resource provider application for connecting to resource provider computer 120.
  • mobile device 1 10 may comprise a merchant application, which a user may access to connect to a merchant server computer and make purchases online. Elements of mobile device 1 10 can be further seen in Fig. 4, further described below.
  • Authentication application 1 12 may comprise instructions for receiving user data from a user, storing user data in a memory of mobile device 1 10, and sending user data over a communication interface such as a wireless interface (e.g. WiFI, Bluetooth, near-field communications, RFID, etc.).
  • a wireless interface e.g. WiFI, Bluetooth, near-field communications, RFID, etc.
  • authentication application 1 12 may be a mobile payments application that a user may access in order to present his or her credentials when making a purchase.
  • authentication may be a mobile payments application that a user may access in order to present his or her credentials when making a purchase.
  • the application 1 12 may comprise instructions for generating a biometric template from biometric sample data.
  • the biometric template may be data comprising features of a biometric sample required for accurate matching.
  • the biometric template may comprise minutiae information such as position, type, and angle and/or may comprise pattern information (ridge structure) as described in ISO/IEC JTC 1/SC 37.
  • the biometric template may comprise features of a user's fingerprint data that consistently appear in biometric sample data. This may include features that may be detected no matter where a user's finger is positioned on the fingerprint reader when a sample is taken, such as the relative position that lines (i.e. contours) that make up the user's fingerprint are to one another.
  • a user may present his or her biometric sample multiple times, and a statistical model may be used to generate a biometric template that captures the top features that have the greatest probability of appearing in a next biometric sample taken from the user.
  • mobile device 1 10 or authentication application 1 12 stored on mobile device may comprise a biometric template generation algorithm, from which identical biometric templates are generated each time a user captures a sample from a specific biometric (e.g. each time he or she presents the same finger, iris, etc.).
  • Authentication application 1 12 may further comprise instructions for creating a derivative of a biometric template.
  • authentication application 1 12 may comprise instructions for passing the biometric template through an algorithm that mathematically alters its data values or removes certain data values to form a derivative of the biometric template.
  • biometric template may include a string of data, while the derivative of the biometric template may remove or convert some of the data in the string of data at predetermined locations.
  • the derivative of the biometric template may relate to the biometric template, but may not be the entire biometric template.
  • the algorithm for altering data values may be a one way function in which it is computationally difficult to reverse the operation performed, thus making it nearly impossible to obtain the original template.
  • biometric template data may be expressed as a string, in which unique and consistent features of the users biometric having a high probability of appearance in a captured sample are converted into a unique sequence of characters.
  • the string including the unique sequence of characters may be passed through a hashing algorithm to generate a unique hash.
  • the biometric template may be split into multiple parts and the multiple parts each may be passed through the one way function and collected together to form the derivative. For example, a string of characters representing a user's fingerprint template may be divided into 20 strings of equal length, which may each be hashed and the resulting hashes may be appended together to form a derivative.
  • Resource provider computer 120 may be a computer used to provide resources to a user.
  • the resource may be provided to the user upon
  • resource provider computer 120 may be a computer that controls entrance/exit into a building or terminal.
  • resource provider computer 120 may be a server computer of a merchant, that may be used to authorize access to goods or services.
  • the server computer of the merchant may be accessed from mobile device 1 10 using a resource provider application.
  • resource provider computer 120 may be a computer of a government agency, that may be used to confirm an individual's identity (e.g. for the purpose of authorizing access to social security benefits).
  • Resource provider computer 120 may be any computing device for performing computer functions according to embodiments of the invention, such as a personal computer, laptop, tablet, point-of-sale terminal, smart phone, smart wearable device, etc.
  • Resource provider computer 120 may comprise authentication API 122 for authenticating a user in an interaction (e.g. during a transaction, login attempt, security checkpoint, etc.).
  • Authentication API may comprise instructions for communicating with processing server computer 150 through gateway 130.
  • Authentication API may further comprise instructions for receiving user data in an interaction with the user, and for sending user data to processing server computer 150 to receive an authentication result.
  • authentication API 122 may comprise software that is provided by an entity of processing server computer 150.
  • Authentication API 122 may comprise instructions for receiving the user data in an authentication request message, which may comprise a derived biometric template of a user and an electronic identity, and may further comprise instructions for forwarding the authentication request message to processing server computer 150 to receive the authentication result.
  • the authentication result may indicate if a user's credentials (i.e. biometric) are legitimate, and may be based on the verification and validation of data received in the
  • Gateway 130 may be a network node for interfacing two networks operating using different protocols.
  • the network node may be a physical node provided by hardware or may be a virtual node provided by software.
  • gateway 130 may be software that allows a mobile device or computer to connect, via the internet, to an entity's network, such as that of a bank or payment processing network.
  • gateway 130 may allow a device comprising
  • authentication application 112 or authentication API 122 to communicate with verification server 140 and/or processing server computer 150.
  • Verification server 140 may be a server for verifying a user's information to generate an electronic identity for the user.
  • verification server 140 may be a server of a financial institution that may verify a user's bank account information and/or financial documents.
  • verification server 140 may be a server of a government institution that may verify government documents presented by a user, such as the user's passport, social security number, birth certificate, driver's license, etc.
  • Verification server 140 may generate an electronic identity for a user by way of identity request API 142, which may comprise instructions for receiving identity request messages from a user device.
  • verification server 140 may be any server of an entity possessing the means to verify a user's identity so that the user may be enrolled in a biometric authentication program.
  • processing server computer 150 may be a server computer for processing data in a network.
  • the network may be, for example, a payment processing network, such as VisaNet.
  • Processing server computer 150 may comprise means for determining an authentication result based on user data, such as a user's electronic identity, biometric, or derivatives thereof.
  • processing server computer 150 may determine the authentication result by comparing data in an authentication request message to data stored in authentication data database 160B and in public blockchain 170C.
  • Processing server computer 150 may authenticate a user by comparing a derivative of a first biometric template of a user to a derivative of a second biometric template of the user. Processing server computer 150 may further authenticate a user by identifying records in a blockchain relating to the electronic identity of the user, and validating digital signatures appended to said records.
  • processing server computer 150 may further be seen in Fig. 3, further described below.
  • Authentication server 160 may be a server for authenticating user credentials.
  • the user credentials may include a derivative of a user's biometric template, which may be compared to data stored in authentication data database 160B to authenticate the user.
  • authentication server 160 may receive, from processing server computer 150, a request for a derivative of a biometric template of a user to be authenticated in an interaction.
  • the request may comprise an identifier for a derivative of a first biometric template of the user registered during enrollment.
  • the derivative of the first biometric template may be retrieved from authentication data database 160B, and sent to processing server computer 150 for comparison against a derivative of a second biometric template of the user during authentication.
  • authentication server 160 may compare the derivative of the first and second biometric templates during authentication. For example, during a request to access a building, processing server computer 150 may forward an authentication request message comprising a derivative of a user's iris data.
  • the derivative may be user iris data that has been passed through an algorithm in order to prevent the user's iris data from being transmitted in the clear.
  • Authentication server 160 may receive the derivative in the authentication request message and may query authentication data database 160 for a matching derivative of the user's iris data.
  • Authentication server 160 may determine if a match exists, and send the result to processing server computer. Depending on the match results, the user may be authenticated for access to the building. In yet another embodiment, authentication server 160 and processing server computer 150 may be the same server or may be of the same entity. [0043] In addition to the comparison of data relating to biometrics, authentication of a user in system 100 may also comprise validating records of a distributed database.
  • the distributed database may be a blockchain, such as public blockchain 170C.
  • Public blockchain 170C may be a public ledger of immutable blocks. Each immutable block in public blockchain 170C may reference a previous block, such that the blocks are linked in a chain.
  • public blockchain 170 may comprise signed records for validating an electronic identity of a user.
  • the signed records may be validated by trusted nodes.
  • public blockchain may comprise data blocks that may be verified by trusted server computers, capable of verifying digital signatures in a public key encryption scheme.
  • the digital signatures may be digital signatures of banks or government institutions that may have facilitated the creation of an electronic identity for the user.
  • Flows 1 through 24 show the flow of data in implementing a biometric authentication process carried out by system 100. This may include both enrollment and execution of a biometric authentication program.
  • a user may first enroll into a biometric authentication from his or her mobile device. Enrollment may involve verifying the user's identity at verification server 140 (flows 1 through 3), which may then generate an electronic identity for the user. The electronic identity may then be sent to processing server computer 150 (flows 4 through 6) so that the identity may be linked to user authentication data (e.g. a derivative of the user's biometric template).
  • the authentication data may be stored in authentication data database 160B (flows 7 through 9), and a record of the electronic identity and authentication data being linked may be written into public blockchain 170C (flows 10 through 1 1 ).
  • the electronic identity may then be sent to the user's mobile device 1 10 for later use in an interaction (flows 12 through 13).
  • the user may send his or her authentication data from mobile device 1 10 to resource provider computer 120 (flow 14).
  • the resource provider computer may then send the user's data to processing server computer 150 (flow 16), and the processing server computer may compare the data against data in authentication data database 160B (flows 17 through 19) and against records published to public blockchain 170C (flows 20 through 21 ) to determine an authentication result.
  • Flows 1 to 3 may correspond to steps S201 through S206 of Fig. 2A.
  • Flows 3 to 6 may correspond to steps S207 through S210.
  • Flows 6 to 9 may correspond to steps S21 1 through S212.
  • Flows 9 to 1 1 may correspond to step S213.
  • Flows 1 1 through 13 may correspond to steps S214 through S215.
  • Flows 14 to 16 may correspond to steps S216 through S221 .
  • Flow 16 may correspond to step S222.
  • Flows 16 to 19 may correspond to steps S223 through S225.
  • Flows 19 to 22 may correspond to steps S226 through S228.
  • And flows 22 through 24 may correspond to step S229.
  • FIGS. 2A and 2B show a process flow diagram for implementing secure biometric authentication.
  • steps S201 through S229 describe a process for enrolling and using an electronic identity in conjunction with biometric authentication software stored on a user device.
  • steps S201 through S229 may be performed by the system components of system 100 in Fig. 1 .
  • a user of a mobile device may initiate enrollment into a biometric authentication program. In one embodiment, this may be done using an authentication application stored on the user's mobile device.
  • the authentication application may be an application that may be installed onto a user's mobile device.
  • the authentication application may further store application data in memory, which may include data for generating a biometric template, data for a derivation formula, and data for an electronic identity of a user.
  • a user may open/load the authentication application from his or her mobile device and the authentication application may prompt the user to select an option to enroll into a biometric authentication program (e.g. by selecting the option using an input element of the mobile device).
  • the user may provide his or her biometric sample to the mobile device so that a biometric template of the user may be created.
  • the authentication application may prompt the user to provide his or her biometric sample, which may be used to generate a template containing distinct features of the individual's biometric.
  • biometric samples may include a sample of a user's fingerprint, a current picture of the user, or a sample of the user's voice. Other examples may include the user's iris, the user's palm, or any other distinguishing feature of the individual.
  • a biometric sample may be read using a biometric reader, which can include a fingerprint reader, front-facing camera, microphone, etc.
  • a biometric template When a biometric sample is taken from the user, distinctive features of the sample may be represented in digital form as a biometric template.
  • a data file may be created from the capture of electromagnetic signals generated by a biometric reader during sample reading, in which the signals may be binned into discrete bits according to a pre-defined resolution (i.e. as expressed by the number of pixels in an image or by the sample rate of an audio file).
  • Software stored on the mobile device may then be used to identify features of the data file that are needed to accurately authenticate the user. For example, the user may be asked to present his or her biometric multiple times, and a mathematical model may be used to determine features that consistently appear.
  • the features may be represented as a binary digital file, which may form the biometric template.
  • the authentication application stored on the mobile device may generate a derivative of the biometric template of the user.
  • the derivative may be a representation of the biometric template in which the data has been altered, so as to conceal the original feature data of an original biometric template.
  • a binary file representing characteristic features of a user's fingerprint may be passed through a mathematical function that alters each data value in a seemingly random manner.
  • data values at predetermined locations of a data string representing a biometric template may be removed so obscure the original biometric template.
  • the mathematical function may be a one-way function based on a zero-knowledge protocol, such as a one-way hashing function.
  • the authentication application may comprise code for recognizing features of a user's fingerprint sample that have a high probability of being captured and identical each time a sample is taken, and may express the features as a unique string of characters that can be identical each time the string of characters is formed.
  • the string may then be passed through a hashing algorithm (e.g. SHA256()), to generate a unique hash.
  • the unique hash may be used as a derivative of the biometric template that cannot be reproduced from any biometric other than the user's.
  • the biometric template may be split into multiple parts and the multiple parts each may be passed through the one way function and collected together to form the derivative.
  • a string of characters representing a user's fingerprint template may be divided into 20 strings of equal length, which may each be hashed and the resulting hashes may be appended together to form a derivative.
  • a derivative may be verified if the consistent features of the user's biometric are captured by a reader and the resulting biometric template or parts of the biometric template match expected results after being passed through the one-way function.
  • the derivative cannot be reversed engineered to obtain the consistent features of the user's biometric sample.
  • a derivative may be generated by tokenizing a biometric template and transporting the derivative through a zero-knowledge security layer.
  • the zero-knowledge security layer may be an additional blockchain layer that uses a zero- knowledge proof to shield the source and anonymize the contents of data published to the blockchain.
  • a biometric template may be derived by generating a token, in which the token is committed to specific conditions such as a specific time of use and/or specific receiving address in order to be valid.
  • the token may be, for example, a string of characters that can be verified using a zero-knowledge proof, and that can only be used for its committed purpose and if a hidden and random number, r, is known.
  • the token may then be used as a record in place of the template data, such that the derivatives may be anonymized.
  • the mobile device may retrieve an account identifier of the user.
  • the account identifier may be an identifier for an account issued to the user, such as a bank account or social security account.
  • the account identifier may be a primary account number (PAN), driver's license number, passport ID number, username and password, etc.
  • the account identifier may be entered into the mobile device by the user or may be retrieved from a memory of the mobile device, such as from a secure element of the device or from application data. In other embodiments, the account identifier may be retrieved from a cloud-based server, or may be provided through another application on the mobile device, such as a digital wallet application. [0052]
  • the mobile device may generate an identity request message.
  • the identity request message may comprise the derivative of the biometric template of the user and the account identifier.
  • the identity request message may be generated after the biometric template of the user has been derived and after the account identifier has been retrieved. In one embodiment, the message may be sent upon indication by the user.
  • the authentication application may comprise instructions for displaying a selectable option to the user, which when selected may result in the generation and sending of the identity request message.
  • the identity request message may comprise additional information of the user such as his or her name, address, date of birth, etc.
  • the identity request message may be sent from the mobile device to a verification server.
  • the verification server may be a server of a verification entity, such as a government agency or bank.
  • the identity request message may be sent from the mobile device to the verification server by way of a network gateway, such as gateway 130 of Fig. 1.
  • the gateway may be a network node capable of receiving the identity request message over the Internet and forwarding the message to a bank's server.
  • the verification server may be able to receive and send messages over the network gateway via an API, such as identity request API 142 of Fig.1.
  • the verification server may verify the account identifier of the user.
  • the verification server may receive the identity request message and may identify data fields for the account identifier and derivative of the biometric template. The verification server may then compare the account identifier to an account identifier stored in an account database, and may verify the validity of the account identifier and any additional user information.
  • a bank server may receive a bank account number and a user's name in the identity request message and may verify that the bank account number exists, is under the user's name, and is in good standing.
  • the verification server may further perform other checks on the user such as credit inquiries, criminal background checks, etc. , which may affect whether or not the user is verified into the authentication program.
  • the user's information may be verified according to a "know your customer" or KYC process.
  • the verification server may generate an electronic identity for the user if the account identifier has been verified.
  • the electronic identity or elD, may be mathematically derived from information associated with the user.
  • the electronic identity may be a value calculated by hashing one or more input values.
  • the electronic identity may be derived from a combination of a country code, customer name, date of birth, and last four digits of a social security number of a user, such as SHA256(USA*JOHN SMITHS 9700101 *1234). Hashing this value may result in a seemingly random string of characters, such as
  • the verification server may generate a record for the electronic identity and derivative of the first biometric template being linked or associated with one another, and may sign the record using its private key.
  • the record may serve as a certificate of enrollment into the biometric authentication program.
  • the record may comprise hashes of the electronic identity and the derivative of the biometric template of the user.
  • the record may comprise a hash that is the result of concatenating strings for the electronic identity and derivative and inputting the concatenated string into SHA256().
  • the record may also comprise time information relating to the time at which the verification verified the user's information.
  • the record may then be signed by the verification server according to a digital signature algorithm.
  • a Federal Information Processing Standard Digital Signature Algorithm may be used in conjunction with a bank's private key to generate a verifiable digital signature that may be appended to a hash record.
  • the record may be identified by a record identifier, such as a transaction ID.
  • a record identifier such as a transaction ID.
  • the verification server may insert the signed record into the identity request message, and may then forward the identity request message to a processing server computer for processing.
  • the processing server computer may be processing server computer 150 of Fig. 1 .
  • an allocated data field may be used to store the signed record in the message, so that it may be received and read by the processing server computer.
  • the verification server may send the identity request message to the processing server computer using instructions stored in an identity request API, and by way of a network gateway.
  • the processing server computer may receive the identity request message, and may link the electronic identity and derivative of the biometric template in a database.
  • the processing server computer may read allocated data fields for the electronic identity (elD) and for the derivative of the biometric template, and may then store the elD or copy of the elD along with an identifier for the derivative of the biometric template in a database where they may be linked.
  • the electronic identity, 754WD2E2513BF546050C2D079FF5D65AB6E318E' and the derivative ID, 'derivative #129578190' may be linked together in a row of a relational database or of a mapping table.
  • the processing server computer may submit the derivative of the biometric template to an authentication server for storage.
  • the derivative of the biometric template may be stored in the authentication data database, where it may be later accessed and retrieved during authentication of a user.
  • the authentication server may be authentication server 160 and the authentication data database may be authentication data database 160B of Fig. 1 .
  • the processing server computer and authentication server may be the same server or of the same entity.
  • the processing server computer may also attach an identifier for the derivative, which the authentication server may receive and link to the derivative in the authentication data database. The identifier may be used as a reference at a later point in time when querying for the derivative.
  • the processing server computer may sign the record generated by the verification server and may then publish the record to a public blockchain.
  • the blockchain may be public blockchain 170C of Fig. 1 .
  • the record may be signed using the processing server computer's private key, and according to a digital signature algorithm.
  • the processing server computer may append its digital signature to the record, and may then initiate the writing of the record into a data block and the publishing of the data block to a blockchain.
  • the data block may later be read during authentication of a user in an interaction, such that the validity of the user's electronic identity and its certification into the biometric authentication program may be verified.
  • the processing server computer may send the electronic identity to the mobile device.
  • the processing server computer may generate an identity response message comprising the electronic identity, which it may send to the mobile device over a network such as the internet (e.g. via the network gateway).
  • the identity response message may also comprise data indicating the successful enrollment for the user into the biometric authentication program, such as data for a confirmation message.
  • the mobile device may receive the identity response message and may store the electronic identity in memory.
  • the memory be application memory of the authentication application or may be a secure element of the mobile device.
  • the memory may be a cloud-based memory which may allow the mobile device to access the electronic identity from servers across a network.
  • the user may present the mobile device in an interaction with a resource provider computer.
  • the user may interact with an access device using a communications interface of the mobile device, such as through Bluetooth or near-field communications.
  • the user may interact with the resource provider through a resource provider application stored on the user's mobile device.
  • the resource provider application may allow for the exchange of data between the mobile device and the resource provider's server computers such that the user may be authenticated and granted resources, such as merchandise or requested services.
  • the resource provider computer may be resource provider computer 120 of Fig. 1 .
  • the user may provide a second biometric sample to the mobile device.
  • the biometric sample may be of the same biometric used during enrollment into the authentication program, taken at step S202. For example, if the user used an image of his or her face as a biometric during enrollment, the user may then take a current picture of his or herself during the interaction with the resource provider. In another example, if the user took a sample of his or her right index finger during enrollment, the user may then use the mobile device to take a sample of his or her right index finger during the interaction. The mobile device may take the biometric sample of the user and generate a second biometric template.
  • the authentication application stored on the mobile device may generate a derivative of the second biometric template of the user.
  • the derivative of the second biometric template may be generated in the same manner as the derivative of the first biometric template generated at step S203. This may be done such that matching samples should result in matching derivatives within a predetermined threshold.
  • the mobile device may retrieve the electronic identity from memory.
  • the memory may be the memory in which the electronic identity was stored in at step S215.
  • access to the electronic identity may be protected using a passphrase or username and password.
  • the electronic identity may be stored in a secure memory, in which access can only be granted to an application if the user enters his or her pin.
  • the authentication application may append the electronic identity (elD) to the derivative of the second biometric template of the user.
  • the electronic identity and the derivative of the second biometric template may both be represented as a string of characters of predefined length.
  • the electronic identity may be a hash of 30 letters and numbers
  • the derivative of the second biometric template may be a string of 100 characters representing mathematically derived feature data of a user's biometric sample.
  • the appended elD and derivative may then be a string of 130 characters in length.
  • the mobile device may generate an authentication request message comprising the appended electronic identity and derivative, and may send the authentication request message to the resource provider computer.
  • the resource provider computer may then forward the authentication request message to a processing server computer, using an authentication API.
  • the authentication API may be authentication API 122 of Fig. 1 .
  • the processing server computer may receive the authentication request message.
  • the processing server computer may decouple the electronic identity from the derivative of the second biometric template. In one embodiment, this may be done by determining the length of the electronic identity and the length of the derivative of the second biometric template, and then splitting the appended electronic identity and derivative into two separate data elements based on the length. For example, the processing server computer may determine that the electronic identity should be a string of 30 characters and that the derivative of the second biometric template should be a string of 100 characters. When the processing server computer receives a 130 character string in an authentication request message, it may declare a variable for the electronic identity to which it allocates the first 30 characters of the string, and may declare a variable for the derivative of the second biometric template to which it allocates the remaining 100 characters. In other embodiments, one or more designated characters may separate the electronic identity data and the derivative of the second biometric template. In yet other embodiments, these two pieces of data may be provided in known data fields.
  • the processing server computer may determine from records, a derivative of a first biometric template linked to the electronic identity. This may be the derivative linked to the electronic identity at step S21 1 .
  • the record may be in the form of a mapping table or relational database, which the processing server computer may query for the electronic identity (elD) and identity derivatives and other data linked to the queried electronic identity.
  • the elD may be linked in a row of a relational database to an identifier for a derivative of a first biometric template of a user and to other additional information of the user such as name, address, etc.
  • the identified derivative may be retrieved, by the processing server computer, from an authentication data database by sending a request to an authentication server.
  • the processing server computer may send a request comprising an identifier for the derivative of the first biometric template of the user (e.g. 'derivative #129578190').
  • the identifier may be used by the authentication server to query for the derivative, which the authentication server may submit to the processing server computer for comparison to the derivative of the second biometric template of the user.
  • the processing server computer may compare the derivative of the second biometric template with the derivative of the first biometric template for a match. In one embodiment, this may be done, by comparing each data element of the derivative of the second biometric template to a corresponding data element of the derivative of the first biometric template. In some embodiments, two derivatives may be considered a match if less than a predetermined number of data elements differ. For example, the derivatives may be expressed as a string of equal length, and the processing server computer may compare each corresponding character (first, second, third, etc.) from each string to one another, and may determine a match if less than 10 characters differ.
  • the processing server computer may search for a record on the public blockchain relating to the electronic identity and first biometric template.
  • the processing server computer may search the blockchain for a data block that comprises the electronic identity. In one embodiment, this may be done by scanning the blockchain for a data block comprising the record identifier generated at step S209.
  • the processing server computer may be coupled to a relational database, in which electronic identities are linked to entries for a transaction ID and transaction timestamp relating to the time at which an electronic identity was used to enroll a user into the biometric authentication program.
  • the processing server computer may then search the blockchain for a record that comprises the transaction ID and transaction timestamp.
  • the record may comprise hashes of the electronic identity and of the derivative of the first biometric template, and the
  • processing server computer may verify that the hashes of the electronic identity and of the derivative of the first biometric template match expected results. For example, the processing server computer may concatenate strings for the electronic identity and for the derivative and input the concatenated string into SHA256(). The processing server computer may then determine if the resulting output matches a corresponding record identified on the blockchain. In embodiments, this type of verification may be seen as a first validation check.
  • the processing server computer may validate the record by verifying one or more digital signatures appended to the record.
  • a digital signature may be verified by inputting the digital signature and the public key of the alleged signing entity into a verification algorithm and determining if the output matches expected results.
  • the processing server computer may determine an authentication result based at least upon the comparison of the
  • the authentication result may be considered positive (i.e. authentic user), if both of the derivatives of the biometric templates match and if the digital signatures appended to the record of the elD and derivative being linked (i.e. certificate of enrollment) are validated.
  • the processing server computer may send the authentication result to the mobile device in an authentication response message.
  • the authentication result may first be sent to the resource provider computer and then forwarded to the mobile device. If the authentication result is positive, then the resource provider computer may consider the user's credentials authentic and may grant access to a requested resource.
  • the resource provider computer may be a computer that unlocks the door of a building, and a positive authentication result may initiate actuators to disable the door's locking mechanism.
  • the process described by Figs. 2A and 2B may allow a user to prove his or her identity using secure biometric
  • the biometric may be a fingerprint, image of the user's face, recording of the user's voice, etc. as provided by a biometric reader of the user's mobile device.
  • a derived template of the user's biometrics may be first registered during enrollment and linked to an electronic identity unique to the user.
  • the generation of the electronic identity and its association with the derivative of the biometric template may be represented as a record published on a public blockchain.
  • the record may serve as a certificate of enrollment, and may be digitally signed by trusted entities (banks, government institutions, etc.) so as to provide greater validation checks.
  • the electronic identity may be stored on the user's mobile device, and may be sent to a processing server computer to authenticate the user during an interaction with a resource provider.
  • the authentication process may further comprise taking a second sample of a user's biometric to generate a derivative of a second biometric template that may be compared to the derivative generated during enrollment.
  • the method provided can be more secure than other biometric authentication systems, in that a user's biometric template is derived so as to conceal the nature of data stored therein. Furthermore, the validity of the biometric template is also dependent on the validity of the electronic identity, as determined by the verification of digital signatures appended to a record on a
  • embodiments of the invention provide a method of authentication that is both more secure and more convenient than other means of proving one's identity.
  • FIG. 3 shows a block diagram of a processing server computer for
  • Processing server computer 300 shown may be processing server computer 150 of Fig. 1.
  • Processing server computer 300 may comprise a processor 310 for executing instructions, and a network interface 320 for communicating over a network.
  • Processing server computer 300 may further comprise a computer readable medium 330.
  • Computer readable medium 330 may be a memory storing executable instructions in the form of code.
  • Computer readable medium 330 may comprise modules of code that may be executed by processor 310 such as communication module 330A, mapping module 330B, authentication data storage module 330C, signing module 330D, block writing module 330E, authentication request module 330F, data lookup module 330G, derivative comparison module 330H, signature validation module 3301, and authentication response module 330J.
  • Processor server computer 330 may further be coupled to one or more databases such as elD mapping database 300A, authentication data database 300B, and public blockchain 300C.
  • ElD mapping database 300A may be a database in which electronic identities are linked to user data.
  • the user data may include a derivative of a biometric template of the user.
  • processing server computer 300A may receive an identity request message comprising an electronic identity and a derivative of a biometric template of the user. Processing server computer 300A may then link the electronic identity to the derivative of the biometric template of the user in a mapping table (i.e. lookup table) of elD mapping database 300A, which may later be queried during authentication of the user.
  • elD mapping database 300A may be a relational database in which electronic identities in a column are each linked in a row to one or more identifiers for one or more derivatives of biometric templates.
  • an electronic identity may be a hash that is mathematically derived from information associated with a user.
  • a derivative of a biometric template may also be represented as a string, such as a string of altered pixel values for an image (e.g. "255 232 45 678 56 23....345 76 44 767 433 345").
  • an identifier for the derivative of the biometric template may be stored in elD mapping database, rather than the derivative of the biometric template itself. Meanwhile, the derivative itself may be stored in
  • a derivative may be identified by a derivative identifier, 'derivative #129578190,' which may be referenced by an
  • authentication server to query for and retrieve the derivative from authentication data database 300B.
  • Authentication data database 300B may be a database in which user authentication data may be stored.
  • the user authentication data may comprise a derivative of a biometric template of a user.
  • authentication data database 300B may be accessible by processing server computer 300, by way of an authentication server.
  • processing server computer 300 may send a request for authentication data to the authentication server, which may retrieve the authentication data from authentication data database 300B.
  • the request may comprise an identifier for the authentication data, such as a derivative ID identifying a derivative of a biometric template of a user (e.g. 'derivative #129578190').
  • Public blockchain 300C may be a distributed database in which immutable records are stored and chained together.
  • the immutable records may comprise records for the certification of an electronic identity into a biometric authentication program.
  • the immutable records may further be verifiable through a distributed verification network, in which records may be validated by trusted entities.
  • the trusted entities may validate an immutable record by comparing digital signatures appended to the record using public keys of the signing entities.
  • a server computer of a payment processing network may validate a record by inputting the record and a public key of a bank that allegedly notarized the record into a verification algorithm, and then checking if the output matches expected results.
  • processing server computer 300 may comprise a plurality of software modules, which may comprise instructions for executing tasks according to embodiments.
  • Communication module 330A may comprise instructions for sending, receiving, and reformatting messages. The messages may be sent and received by processing server computer 300 over network interface 320.
  • processing server computer 300 may receive identity request messages and authentication request messages, and may send identity response messages and authentication messages over network interface 320.
  • Mapping module 330B may comprise instructions for mapping electronic identities to user data.
  • the user data may include a derivative of a biometric template of a user.
  • a verification server may generate an electronic identity (elD) for a user upon verification of an account identifier of the user.
  • the verification server may forward an identity request message comprising the elD and a derivative of a biometric template of the user to processing server computer 300.
  • Mapping module 330B may comprise instructions for identifying data fields in an identity request message allocated for an elD and for a derivative. Mapping module 330B may further comprise instructions for reading the data fields, and storing data of the fields (or identifiers thereof) in a database.
  • the electronic identity and a derivative identifier may be stored in elD mapping database 300A, where they may be linked to each other in a mapping table.
  • the processing server computer may store in a row of a relational database, an electronic identity for:
  • the electronic identity may further be linked to an identifier for a record of the elD and derivative being linked, such as a transaction ID or certificate ID, which may be used to identify the record on public blockchain 300C.
  • Authentication data storage module 330C may comprise instructions for storing user authentication data in a database.
  • the authentication data may comprise a derivative of a biometric template of a user.
  • authentication data storage module 330C may comprise instructions for attaching an identifier to the derivative of the biometric template of the user, and may further comprise instructions for sending the derivative to an authentication server.
  • the authentication server may store the derivative in authentication data database 300B along with its identifier, so that it may be identified and retrieved at a later time.
  • Signing module 330D may comprise instructions for signing a record using a private key.
  • records may be signed by trusted entities in a distributed verification network according to a digital signature algorithm.
  • Processing server computer 300 may be a node of the distributed verification network, and signing module 330D may comprise code instructing processor 310 to sign a received record using its private key, in conjunction with the digital signature algorithm.
  • Block writing module 330E may comprise instructions for initiating of writing data to public blockchain 300C.
  • public blockchain 300C may be used to store records relating to the enrollment of a user into a biometric authentication program. Each record may comprise an indication of an electronic identity and a derivative of a biometric template of a user being linked. Each record may further comprise one or more digital signatures of trusted entities.
  • processing server computer 300 may initiate the publishing of records to public blockchain 300C by broadcasting a new data block.
  • block writing module 330E may comprise code instructing processor 310 to generate a new data block for a record.
  • Block writing module 330E may further comprise instructions for broadcasting the new data block to public blockchain 300C so that a node of a distributed network storing copies of public blockchain 300C may publish the new data block.
  • the method for writing to a public blockchain may vary according to the method of consensus established for the blockchain.
  • Example methods of consensus governing the writing of blocks in a blockchain may include proof-of-work, proof-of- stake, proof-of-space, proof-of-authority, etc.
  • Authentication request module 330F may comprise instructions for decoding data received in an authentication request message.
  • an authentication request message may be received by processing server computer 300 from a resource provider computer so that processing server computer 300 may authenticate a user.
  • the authentication request message may comprise an electronic identity and derivative of a biometric template of the user. The electronic identity and the derivative may be included together in the authentication request message (e.g. as an appended string), and authentication request module 330F may comprise instructions for decoupling the electronic identity and derivative.
  • Authentication request module 330F may comprise instructions for processor 310 to identify one or more data fields allocated for the electronic identity and derivative, read the one or more data fields, and to declare variables to which the electronic identity and derivative should be assigned. For example, processor 310 may determine that the first 30 characters of an appended string should be assigned and allocated as an electronic identity, and that the remaining 100 characters are assigned and allocated as a derivative.
  • Data lookup module 330G may comprise instructions for looking up data in a database, such as elD mapping database 300A.
  • processing server computer 300 may identify an electronic identity received in the message, and may determine a derivative of a biometric template linked to the electronic identity.
  • the derivative linked to the electronic identity may be linked in elD mapping database 300A
  • data lookup module 330G may comprise instructions for querying elD mapping database 300A for the electronic identity and any data linked to it.
  • elD mapping database 300A may be a relational database
  • data lookup module 330G may include instructions for retrieving a row of data in the relational database that comprises an electronic identity received in an authentication request message.
  • the row of data may further comprise an identifier for a derivative of a biometric template of a user (e.g. 'derivative #129578190').
  • Derivative comparison module 330H may comprise instructions for comparing derivatives for a first and second biometric template.
  • a derivative of a first biometric template stored during enrollment may be compared to a derivative of a second biometric template to authenticate a user.
  • two derivatives may be considered a match if a predetermined number of data elements of the derivatives match.
  • derivatives of feature data for a user's fingerprint may be expressed as a string of characters representing a sequence of values.
  • the sequence of values may be values for biometric template data that have been mathematically derived.
  • a match may be determined by comparing each corresponding characters between two strings and determining if a predetermined number of characters match.
  • a derivative of a sample of a user's face may be represented as a matrix of altered pixel values.
  • a match may be determined by comparing each corresponding matrix element between two matrices and determining if a predetermined number of elements match.
  • a derivative may be expressed as a series of bits, bytes in an array, etc.
  • Derivative comparison module 330H may comprise instructions for comparing data elements of two derivatives and determining a match if the data elements match within a predetermined threshold (e.g. at least 90% of characters matching between two strings).
  • the derivatives of the biometric templates can be compared by using less data than the entire biometric template, and the comparison process can use a "zero-knowledge proof" protocol in some embodiments.
  • Signature validation module 3301 may comprise instructions for validating one or more digital signatures using one or more public keys.
  • a record on public blockchain 300C may be searched and may comprise one or more digital signatures.
  • signature validation module 3301 may comprise code instructing processing server computer 300 to validate the one or more signatures according to a digital signature algorithm (DSA).
  • the code may comprise instructions for retrieving or obtaining one or more public keys of the signing entities, and verifying the one or more digital signatures with the one or more public keys, in conjunction with a verification algorithm.
  • the signing entities may include banks and governments, whom may allow access to their public keys in a distributed verification network.
  • the public keys may be retrieved by processing server computer 300 and used to determine if the digital signatures appended to a record are valid.
  • Authentication response module 330J may comprise instructions for generating an authentication response comprising an authentication result. According to some embodiments, a user may be authenticated during an interaction upon the
  • processing server computer 300 may determine an authentication result based on both the comparison of derivatives for a first and second biometric template of a user and based on the validity of an electronic identity.
  • the comparison of derivatives may be determined using instructions from derivative comparison module 330H and the validity of the electronic identity (elD) may be based on the validation of one or more digital signatures appended to a record relating to the elD.
  • Authentication response module 330 J may comprise code for determining the authentication result, and for inserting the authentication result into an authentication response message.
  • authentication response module 330J may comprise instructions for generating a positive authentication result if a match occurs between compared derivatives and if an electronic identity is determined to be valid.
  • Authentication response module 330J may further comprise code for inserting the positive authentication result in an authentication response message.
  • authentication response message comprising the authentication result may be then be sent to a resource provider computer and forwarded to a user device to authenticate the user of the device (e.g. for the purpose of gaining access to a network).
  • processing server computer 300 may process data to implement biometric authentication for users.
  • the users may enroll into a biometric authentication program using a user device.
  • the user device may be used to generate a derivative of a first biometric template of a user, and to request an electronic identity that may be certified in a record published to public blockchain 300C.
  • the user device may store the user's electronic identity for later use in an interaction.
  • the user device may generate a derivative of a second biometric template of the user, which may be sent to processing server computer 300.
  • Processing server computer 300 may then authenticate the user based on the comparison of derivatives for the first and second biometric template of the user, and based on the validity of the electronic identity generated for the user.
  • FIG. 4 shows a block diagram of a user device for implementing biometric authentication.
  • User device 410 may be mobile device 1 10 of Fig. 1.
  • User device 410 may comprise memory 41 1 .
  • Memory 41 1 may store data, such as data for one or more applications.
  • the one or more applications may include authentication application 412 and resource provider application 420.
  • User device 410 may further comprise biometric reader 414 for reading biometric samples of a user and biometric interface 413 for transmitting data between biometric reader 414 and an application of the user device. Examples of biometric reader 414 may include a fingerprint reader, a front-facing camera, a microphone, etc.
  • User device 410 may further comprise communications element 415 for allowing communications between user device 410 and other devices, such as through wireless communications (e.g.
  • user device 410 may also comprise data input/output 416 for receiving inputs from a user.
  • data input/output 416 may be an input element of a touchscreen from which display icons may be selected, and from which a virtual keyboard may be displayed to receive user commands.
  • User device 410 may also comprise display 417 for displaying data to a user and processor 418 for processing data and executing instructions to complete tasks.
  • a user may enroll into a biometric authentication program for proving his or her identity in an interaction with a resource provider. The interaction, may be, for example, a transaction with a merchant or a login attempt into a network.
  • a user may enroll via authentication application 412, which may connect the user to one or more server computers over a network.
  • Authentication application 412 may be used to derive a biometric template of the user taken from biometric interface 413 and biometric reader 414, which may be linked by one of the server computers to an electronic identity (elD) generated for the user.
  • the elD may be stored on user device 410, and during an interaction, user device 410 may send the elD and a derivative of a second biometric template (e.g. via communications element 415 and antenna 419) to the server computer for authentication.
  • An authentication result may be determined based on the comparison of the derivative of the second biometric template to the derivative of the first biometric template recorded during enrollment, and based on the validity of the electronic identity.
  • User device 410 may then receive the authentication result, indicating if the user's identity has been successfully proven.
  • Embodiments of the invention allow a user to identify his or herself in an interaction using his or her mobile device. This eliminates the need to carry around physical identification cards, which may be inconvenient for users. According to embodiments, a user may simply identify his or herself using a biometric (e.g. by taking a current picture of his or her face, or by reading his or her fingerprint). Furthermore, embodiments of the invention are more secure than other biometric authentication methods previously conceived. For example, a user's biometric data is derived rather than sent in the clear, yet may still be verified without revealing a user's original biometric.
  • embodiments of the invention subject the use of a user's biometric data to numerous validation checks involving digital signatures of trusted parties and immutable records. This may prevent a criminal actor from successfully using fake or stolen identities in the authentication system.
  • embodiments of the invention provide APIs that allow for compatibility with a plurality of verification entities, thus allowing for ease of performing validation checks and providing greater security as needed.
  • a computer system includes a single computer apparatus, where the subsystems can be the components of the computer apparatus.
  • a computer system can include multiple computer apparatuses, each being a subsystem, with internal components.
  • a computer system can include a plurality of the same components or subsystems, e.g., connected together by an external interface.
  • computer systems, subsystem, or apparatuses can communicate over a network.
  • one computer can be considered a client and another computer a server.
  • a client and a server can each include multiple systems, subsystems, or components, mentioned herein.
  • any of the software components or functions described in this application may be implemented as software code to be executed by a processor using any suitable computer language such as, for example, Java, C++ or Perl using, for example, conventional or object-oriented techniques.
  • the software code may be stored as a series of instructions, or commands on a computer readable medium for storage and/or transmission, suitable media include random access memory (RAM), a read only memory (ROM), a magnetic medium such as a hard-drive or a floppy disk, or an optical medium such as a compact disk (CD) or DVD (digital versatile disk), flash memory, and the like.
  • RAM random access memory
  • ROM read only memory
  • magnetic medium such as a hard-drive or a floppy disk
  • an optical medium such as a compact disk (CD) or DVD (digital versatile disk), flash memory, and the like.
  • CD compact disk
  • DVD digital versatile disk
  • flash memory and the like.
  • the computer readable medium may be any combination of such storage or transmission devices.
  • Such programs may also be encoded and transmitted using carrier signals adapted for transmission via wired, optical, and/or wireless networks conforming to a variety of protocols, including the Internet.
  • a computer readable medium according to an embodiment of the present invention may be created using a data signal encoded with such programs.
  • Computer readable media encoded with the program code may be packaged with a compatible device or provided separately from other devices (e.g., via Internet download). Any such computer readable medium may reside on or within a single computer program product (e.g. a hard drive, a CD, or an entire computer system), and may be present on or within different computer program products within a system or network.
  • a computer system may include a monitor, printer, or other suitable display for providing any of the results mentioned herein to a user.

Landscapes

  • Engineering & Computer Science (AREA)
  • Computer Security & Cryptography (AREA)
  • Signal Processing (AREA)
  • Computer Networks & Wireless Communication (AREA)
  • Theoretical Computer Science (AREA)
  • Computer Hardware Design (AREA)
  • General Engineering & Computer Science (AREA)
  • General Health & Medical Sciences (AREA)
  • Health & Medical Sciences (AREA)
  • Biomedical Technology (AREA)
  • General Physics & Mathematics (AREA)
  • Physics & Mathematics (AREA)
  • Software Systems (AREA)
  • Computing Systems (AREA)
  • Life Sciences & Earth Sciences (AREA)
  • Biodiversity & Conservation Biology (AREA)
  • Financial Or Insurance-Related Operations Such As Payment And Settlement (AREA)
  • Collating Specific Patterns (AREA)

Abstract

Embodiments of the invention are directed to a method. The method may comprise receiving a second biometric template of a user, and providing an authentication request message comprising an electronic identity and a derivative of the second biometric template of the user to a resource provider computer to conduct an interaction. The authentication request may be forwarded to a processing server computer by the resource provider computer, and the user device may receive an authentication response message comprising an authentication result from the processing server computer. The authentication result may be determined by the processing server computer based on a comparison of the derivative of the second biometric template to a derivative of a first biometric template accessible to the processing server computer. The authentication result may also be based on the validity of the electronic identity.

Description

SECURE BIOMETRIC AUTHENTICATION USING ELECTRONIC IDENTITY
CROSS-REFERENCES TO RELATED APPLICATIONS
[0001] NONE.
BACKGROUND [0002] In today's technological environment, it is typical for individuals to carry around identification cards for proving their identity. The identification cards may be issued by a government agency or financial institution, which may assign an identification number or account number to a user. An identification card may have an identification number, the user's name, and possibly a photograph of the user printed, embossed, and/or stored on the card. When a user wants to prove his or her identity, the user may present the card, and any credentials on the card may be verified to authenticate the user.
[0003] A number of issues may arise from the use of identification cards as a means of identification. Firstly, users often have to carry around multiple identification cards in order to receive a variety of good and/or services. For example, a user may carry a driver's license, multiple credit/debit cards, a social security card, a medical insurance card, etc. This may be inconvenient for the user, and may further increase the chances of a user's identity being stolen. In addition, the use of identification cards may be especially inconvenient when presenting credentials online, when users often need to scan or even manually enter their information. Secondly, the validity of an identification card is often subject to human evaluation, which can be inconsistent and assumes that a person evaluating an identification card is trustworthy. This may lead to further inconveniences for a user, such as an employee that may steal a user's information, or an employee that may view an identification card as invalid due to a slight change in a user's appearance. Lastly, the human factor of identification is often lacking or unsatisfactory in its implementation when it comes to identification cards. That is to say, that identification systems that utilize cards often do not require biometric
authentication, and those that do expect users to trust that their biometric data cannot be stolen and used in unwanted ways. [0004] What is needed in the art, is a secure method for proving one's identity.
BRIEF SUMMARY
[0005] Embodiments of the invention are directed to a method. The method may comprise receiving a second biometric template of a user, and providing an
authentication request message comprising an electronic identity and a derivative of the second biometric template of the user to a resource provider computer to conduct an interaction. The authentication request may be forwarded to a processing server computer by the resource provider computer, and the user device may receive an authentication response message comprising an authentication result from the processing server computer. The authentication result may be determined by the processing server computer based on a comparison of the derivative of the second biometric template to a derivative of a first biometric template accessible to the processing server computer. The authentication result may also be based on the validity of the electronic identity. [0006] The method may further comprise receiving the first biometric template of the user, generating the derivative of the first biometric template, and generating an identity request message for an electronic identity for the user. The identity request message may comprise the derivative of the first biometric template and an account identifier of the user. In addition, the method may comprise sending the identity request message to a verification server, wherein the verification server verifies the account identifier and generates the electronic identity. The electronic identity may be linked to the derivative of the first biometric template in a database by the processing server computer. The method may also comprise receiving an identity response message comprising the electronic identity, and storing the electronic identity in a memory of the user device for later use in an interaction.
[0007] Other embodiments of the invention are directed to systems, apparatuses, portable consumer devices, and computer readable media associated with methods described herein. [0008] A better understanding of the nature and advantages of the present invention may be gained with reference to the following detailed description and the
accompanying drawings.
BRIEF DESCRIPTION OF THE DRAWINGS
[0009] FIG. 1 shows a block diagram of a system for implementing secure biometric authentication.
[0010] FIGS. 2A and 2B show a process flow diagram for implementing secure biometric authentication.
[0011] FIG. 3 shows a block diagram of a processing server computer for
implementing biometric authentication.
[0012] FIG. 4 shows a block diagram of a user device for implementing biometric authentication.
TERMS
[0013] A "server computer" may include a powerful computer or cluster of computers. For example, the server computer can be a large mainframe, a minicomputer cluster, or a group of servers functioning as a unit. In one example, the server computer may be a database server coupled to a Web server. A server computer may be coupled to a database and may include any hardware, software, other logic, or combination of the preceding for servicing the requests from one or more client computers. A server computer may comprise one or more computational apparatuses and may use any of a variety of computing structures, arrangements, and compilations for servicing the requests from one or more client computers.
[0014] An "application program interface" or "API" may refer to software specifying how components of a system should interact. The API may comprise a set of routines, protocols, and tools on which software applications may built. An API may be for a web-based system, operating system, database system, computer hardware or software library, and may include specifications for routines, data structures, object classes, variables and/or remote calls. [0015] The term "gateway" may refer to hardware or software that allows for the interfacing of network nodes using different protocols. The interface can include protocol converters, proxy servers, routers, firewalls, etc. A gateway may also be referred to as a "network gateway." For example, a computer that controls the traffic from an Internet Service Provider (ISP) may be a network gateway.
[0016] The term "authentication" may refer to the process of verifying the identity of something (e.g., a user). One form of authentication can be biometric authentication.
[0017] A "biometric" may be any human characteristic that is unique to an individual. For example, a biometric may be a person's fingerprint, face, DNA, etc. [0018] A "biometric reader" may refer to a device for capturing data from an individual's biometric sample. Examples of biometric readers may include fingerprint readers, front-facing cameras, microphones, and iris scanners.
[0019] A "biometric sample" may refer to data obtained by a biometric reader. The data may be either an analog or digital representation of the user's biometric, generated prior to determining distinct features needed for matching. For example, a biometric sample of a user's face may be image data. In another example, a biometric sample of a user's voice may be an audio file.
[0020] A "biometric template" may refer to a file containing distinct characteristics extracted from a biometric sample that may be used during a biometric authentication process. For example, a biometric template may be a binary mathematical file representing the unique features of an individual's fingerprint, eye, hand or voice needed for performing accurate authentication of the individual.
[0021] The term "zero-knowledge proof" or "zero-knowledge protocol" may refer to a method of proving information is true without conveying the actual information itself. In a zero-knowledge protocol, secret information can be verified without be revealed. More information regarding zero-knowledge proofs may be found at:
J. Camenisch and M. Stadler. Proof systems for general statements about discrete logarithms. Technical Report TR 260, Institute for Theoretical Computer Science, ETH Zurich, Mar. 1997. In some embodiments, the comparison of derivatives of biometric templates to verify the authenticity of a particular person may employ a zero-knowledge protocol.
[0022] The term "blockchain" can be a distributed database that maintains a continuously-growing list of records secured from tampering and revision. A blockchain may include a number of blocks of interaction records. Each block in the blockchain can contain also include a timestamp and a link to a previous block. For example, each block may include or be appended to a hash of the previous block. Stated differently, interaction records in a blockchain may be stored as a series of "blocks," or permanent files that include a record of a number of transactions occurring over a given period of time. Blocks may be appended to a blockchain by an appropriate node after it completes the block and the block is validated. In embodiments of the invention, a blockchain may be distributed, and a copy of the blockchain may be maintained at each node in a verification network. Any node within the verification network may
subsequently use the blockchain to verify transactions. The security of a blockchain may be obtained using a cryptographic scheme.
[0023] A "digital signature" may refer to data used to provide assurance or evidence as to the origin and identity of an electronic record or message. Digital signatures can be based on public key cryptography (i.e. asymmetric cryptography). Digital signatures may be generated using a public key algorithm such as RSA. To create a digital signature, signing software may be used to create a one-way hash of electronic data that is to be signed by a signing entity. A private key of the signing entity is then used to encrypt the hash and form the digital signature.
[0024] The term "validation" may refer to the act of checking or affirming that information is legitimate. An example may be the act of checking that a digital signature appended to an electronic record is, in fact, legitimate and of the signing entity. Digital signatures may be validated according to a verification algorithm in conjunction with a signing entity's public key.
[0025] An "electronic identity" or "elD" may refer to a unique string of characters or symbols used to identify an individual. In preferred embodiments, the electronic identity may be mathematically derived from information associated with a user. For example, in some embodiments, an electronic identity may be a value calculated by hashing one or more input values (customer name, country code, etc.) available to multiple entities. In this way, the electronic identity may be independently generated by any entity that has the prerequisite information. An electronic identity may be altered (e.g., hashed and/or encrypted) information associated with a user. For example, in some
embodiments, an electronic identity may be derived from a combination of a country code, customer name, date of birth, and last four digits of a social security number such as SHA256(USA*JOHN SMITH*19700101*1234). Hashing this value may result in a seemingly random string of characters, such as
754WD2E2513BF546050C2D079FF5D65AB6E318E and this can be an electronic identity. In some embodiments, the electronic identity is associated with a passphrase that is provided in order to access any interaction record associated with the electronic identity. An electronic identity may sometimes be referred to as an "elD," electronic identifier, or electronic identification data. [0026] An "account identifier" may refer to a sequence of numbers and/or letters for identifying an account. The account can be a bank account, credit card account, government benefit account, health insurance account, etc. One example of an account identifier may be a primary account number (PAN), which may be a 16-digit number used to identify that a user may use to conduct transactions. [0027] A "know your customer" or "KYC" process may refer to the process of a business identifying and verifying the identity of its clients. The term is also used to refer to the bank and anti-money laundering regulations which govern these activities. A KYC process may be used to verify information of a user and generate an electronic identity for the user. DETAILED DESCRIPTION
[0028] Embodiments provide systems, apparatus, and methods for implementing secure biometric authentication. A biometric may be any human characteristic that is unique to an individual. For example, a biometric may be a person's fingerprint, face, DNA, etc. Biometric authentication may be used to identify individuals in a manner that is more convenient and efficient than typical identification methods. It may be used to identify individuals in a variety of scenarios such as logging into a network, accessing a building, or conducting a transaction. Because biometric authentication uses human characteristics rather than account information or identification cards, users of biometric authentication do not need to worry about remembering usernames and passwords or keeping track of ID cards.
[0029] A problem associated with implementing biometric authentication systems is privacy and security. Users often distrust biometric authentication for fear of their biometric data might be stolen or misused. In addition, entities that need to verify a user's identity (e.g. for the purpose of authorizing a transaction) also have a stake in the accuracy of authentication, and may wish to limit the proliferation of identity theft and fake identity creation.
[0030] Embodiments of the invention described herein address these issues by passing a user's biometric template through a derivation formula, and linking the derived biometric template to an electronic identity that is validated by trusted parties. The electronic identity may be validated against records stored in a blockchain and according to a digital signature algorithm. In this manner, a user's biometric data remains confidential and goes through multiple validation checks, thus preventing abuse of the authentication system by a fraudulent individual. Embodiments combine blockchain technology with other biometric authentication techniques to provide a secure authentication system available through an application on a user's mobile device. Thus, embodiments of the invention described herein are more secure, more efficient, and more convenient than other identification methods.
[0031] FIG. 1 shows a block diagram of a system for implementing secure biometric authentication. System 100 may comprise processing server computer 150 for processing authentication requests in secure biometric authentication. Processing server computer 150 may connect to a plurality of servers, computers, and devices across a number of protocols through a network gateway, such as gateway 130.
System 100 may also comprise mobile device 1 10, which may comprise authentication application 1 12. Authentication application 1 12 may be an application stored on mobile device 1 10 that comprises instructions for implementing biometric authentication. This may include instructions for communicating with verification server 140, processing server computer 150, and resource provider computer 120. Authentication application 1 12 may further comprise instructions for requesting an electronic identity, which may be provided by verification server 140 through identity request API 142. [0032] According to embodiments, a computer of a resource provider, such as resource provider computer 120, may comprise authentication API 122 for
authenticating a user of mobile device 1 10. Resource provider computer 120 may authenticate the user by receiving user data from mobile device 1 10, which may be forwarded to processing server computer 150 to receive an authentication result. The processing server computer 150 may determine the authentication result through communications with authentication server 160, and based on data stored in
authentication data database 160B and in public blockchain 170C.
[0033] Mobile device 1 10 may be any mobile device for communicating and storing user data of a user. For example, mobile device 1 10 may be a smart phone, smart wearable device (e.g. smart watch or eyewear), or any other portable communications device owned by the user. Mobile device 1 10 may store and communicate user data by way of one or more applications such as authentication application 1 12. The user data may include a user's electronic identity and a derivative of the user's biometric template. In one embodiment, mobile device 1 10 may also comprise a resource provider application for connecting to resource provider computer 120. For example, mobile device 1 10 may comprise a merchant application, which a user may access to connect to a merchant server computer and make purchases online. Elements of mobile device 1 10 can be further seen in Fig. 4, further described below.
[0034] Authentication application 1 12 may comprise instructions for receiving user data from a user, storing user data in a memory of mobile device 1 10, and sending user data over a communication interface such as a wireless interface (e.g. WiFI, Bluetooth, near-field communications, RFID, etc.). For example, authentication application 1 12 may be a mobile payments application that a user may access in order to present his or her credentials when making a purchase. In one embodiment, authentication
application 1 12 may comprise instructions for generating a biometric template from biometric sample data. The biometric template may be data comprising features of a biometric sample required for accurate matching. The biometric template may comprise minutiae information such as position, type, and angle and/or may comprise pattern information (ridge structure) as described in ISO/IEC JTC 1/SC 37. For example, the biometric template may comprise features of a user's fingerprint data that consistently appear in biometric sample data. This may include features that may be detected no matter where a user's finger is positioned on the fingerprint reader when a sample is taken, such as the relative position that lines (i.e. contours) that make up the user's fingerprint are to one another. In another example, a user may present his or her biometric sample multiple times, and a statistical model may be used to generate a biometric template that captures the top features that have the greatest probability of appearing in a next biometric sample taken from the user. In one embodiment, mobile device 1 10 or authentication application 1 12 stored on mobile device may comprise a biometric template generation algorithm, from which identical biometric templates are generated each time a user captures a sample from a specific biometric (e.g. each time he or she presents the same finger, iris, etc.).
[0035] Authentication application 1 12 may further comprise instructions for creating a derivative of a biometric template. For example, authentication application 1 12 may comprise instructions for passing the biometric template through an algorithm that mathematically alters its data values or removes certain data values to form a derivative of the biometric template. For example, in some embodiments, biometric template may include a string of data, while the derivative of the biometric template may remove or convert some of the data in the string of data at predetermined locations. The derivative of the biometric template may relate to the biometric template, but may not be the entire biometric template. In one embodiment, the algorithm for altering data values may be a one way function in which it is computationally difficult to reverse the operation performed, thus making it nearly impossible to obtain the original template. For example, in one embodiment, biometric template data may be expressed as a string, in which unique and consistent features of the users biometric having a high probability of appearance in a captured sample are converted into a unique sequence of characters. To derive the biometric template, the string including the unique sequence of characters may be passed through a hashing algorithm to generate a unique hash. In another embodiment, the biometric template may be split into multiple parts and the multiple parts each may be passed through the one way function and collected together to form the derivative. For example, a string of characters representing a user's fingerprint template may be divided into 20 strings of equal length, which may each be hashed and the resulting hashes may be appended together to form a derivative.
[0036] Resource provider computer 120 may be a computer used to provide resources to a user. In embodiments, the resource may be provided to the user upon
authentication of the user's credentials (e.g. user biometric). For example, resource provider computer 120 may be a computer that controls entrance/exit into a building or terminal. In another example, resource provider computer 120 may be a server computer of a merchant, that may be used to authorize access to goods or services. In one embodiment, the server computer of the merchant may be accessed from mobile device 1 10 using a resource provider application. In yet another example, resource provider computer 120 may be a computer of a government agency, that may be used to confirm an individual's identity (e.g. for the purpose of authorizing access to social security benefits). Resource provider computer 120 may be any computing device for performing computer functions according to embodiments of the invention, such as a personal computer, laptop, tablet, point-of-sale terminal, smart phone, smart wearable device, etc.
[0037] Resource provider computer 120 may comprise authentication API 122 for authenticating a user in an interaction (e.g. during a transaction, login attempt, security checkpoint, etc.). Authentication API may comprise instructions for communicating with processing server computer 150 through gateway 130. Authentication API may further comprise instructions for receiving user data in an interaction with the user, and for sending user data to processing server computer 150 to receive an authentication result. In one embodiment, authentication API 122 may comprise software that is provided by an entity of processing server computer 150. Authentication API 122 may comprise instructions for receiving the user data in an authentication request message, which may comprise a derived biometric template of a user and an electronic identity, and may further comprise instructions for forwarding the authentication request message to processing server computer 150 to receive the authentication result. The authentication result may indicate if a user's credentials (i.e. biometric) are legitimate, and may be based on the verification and validation of data received in the
authentication request message. [0038] In embodiments, messages between devices during authentication may pass through gateway 130. Gateway 130 may be a network node for interfacing two networks operating using different protocols. The network node may be a physical node provided by hardware or may be a virtual node provided by software. For example, gateway 130 may be software that allows a mobile device or computer to connect, via the internet, to an entity's network, such as that of a bank or payment processing network. In one embodiment, gateway 130 may allow a device comprising
authentication application 112 or authentication API 122 to communicate with verification server 140 and/or processing server computer 150.
[0039] Verification server 140 may be a server for verifying a user's information to generate an electronic identity for the user. For example, verification server 140 may be a server of a financial institution that may verify a user's bank account information and/or financial documents. In another example, verification server 140 may be a server of a government institution that may verify government documents presented by a user, such as the user's passport, social security number, birth certificate, driver's license, etc. Verification server 140 may generate an electronic identity for a user by way of identity request API 142, which may comprise instructions for receiving identity request messages from a user device. In embodiments, verification server 140 may be any server of an entity possessing the means to verify a user's identity so that the user may be enrolled in a biometric authentication program. [0040] According to embodiments, processing server computer 150 may be a server computer for processing data in a network. The network may be, for example, a payment processing network, such as VisaNet. Processing server computer 150 may comprise means for determining an authentication result based on user data, such as a user's electronic identity, biometric, or derivatives thereof. In embodiments, processing server computer 150 may determine the authentication result by comparing data in an authentication request message to data stored in authentication data database 160B and in public blockchain 170C. Processing server computer 150 may authenticate a user by comparing a derivative of a first biometric template of a user to a derivative of a second biometric template of the user. Processing server computer 150 may further authenticate a user by identifying records in a blockchain relating to the electronic identity of the user, and validating digital signatures appended to said records.
Elements of processing server computer 150 may further be seen in Fig. 3, further described below.
[0041] Authentication server 160 may be a server for authenticating user credentials. In embodiments, the user credentials may include a derivative of a user's biometric template, which may be compared to data stored in authentication data database 160B to authenticate the user. In one embodiment, authentication server 160 may receive, from processing server computer 150, a request for a derivative of a biometric template of a user to be authenticated in an interaction. The request may comprise an identifier for a derivative of a first biometric template of the user registered during enrollment. The derivative of the first biometric template may be retrieved from authentication data database 160B, and sent to processing server computer 150 for comparison against a derivative of a second biometric template of the user during authentication.
[0042] In another embodiment, authentication server 160 may compare the derivative of the first and second biometric templates during authentication. For example, during a request to access a building, processing server computer 150 may forward an authentication request message comprising a derivative of a user's iris data. The derivative may be user iris data that has been passed through an algorithm in order to prevent the user's iris data from being transmitted in the clear. Authentication server 160 may receive the derivative in the authentication request message and may query authentication data database 160 for a matching derivative of the user's iris data.
Authentication server 160 may determine if a match exists, and send the result to processing server computer. Depending on the match results, the user may be authenticated for access to the building. In yet another embodiment, authentication server 160 and processing server computer 150 may be the same server or may be of the same entity. [0043] In addition to the comparison of data relating to biometrics, authentication of a user in system 100 may also comprise validating records of a distributed database. Specifically, the distributed database may be a blockchain, such as public blockchain 170C. Public blockchain 170C may be a public ledger of immutable blocks. Each immutable block in public blockchain 170C may reference a previous block, such that the blocks are linked in a chain. Copies of the public blockchain 170C may be distributed to multiple nodes in a network. According to embodiments, public blockchain 170 may comprise signed records for validating an electronic identity of a user. The signed records may be validated by trusted nodes. For example, public blockchain may comprise data blocks that may be verified by trusted server computers, capable of verifying digital signatures in a public key encryption scheme. The digital signatures may be digital signatures of banks or government institutions that may have facilitated the creation of an electronic identity for the user.
[0044] Flows 1 through 24 show the flow of data in implementing a biometric authentication process carried out by system 100. This may include both enrollment and execution of a biometric authentication program. A user may first enroll into a biometric authentication from his or her mobile device. Enrollment may involve verifying the user's identity at verification server 140 (flows 1 through 3), which may then generate an electronic identity for the user. The electronic identity may then be sent to processing server computer 150 (flows 4 through 6) so that the identity may be linked to user authentication data (e.g. a derivative of the user's biometric template). The authentication data may be stored in authentication data database 160B (flows 7 through 9), and a record of the electronic identity and authentication data being linked may be written into public blockchain 170C (flows 10 through 1 1 ). The electronic identity may then be sent to the user's mobile device 1 10 for later use in an interaction (flows 12 through 13). When a user wants to prove his or her identity (e.g. during a transaction) the user may send his or her authentication data from mobile device 1 10 to resource provider computer 120 (flow 14). The resource provider computer may then send the user's data to processing server computer 150 (flow 16), and the processing server computer may compare the data against data in authentication data database 160B (flows 17 through 19) and against records published to public blockchain 170C (flows 20 through 21 ) to determine an authentication result. The authentication result may then be sent to the resource provider computer 120 and mobile device 1 10, so that the user and resource provider can be informed as to whether or not the user's identity has been successfully authenticated (flows 22 through 24). [0045] More detail about the processing steps that occur during the flow shown in Fig. 1 are explained in the description of Fig. 2A and Fig. 2B further below. Flows 1 to 3 may correspond to steps S201 through S206 of Fig. 2A. Flows 3 to 6 may correspond to steps S207 through S210. Flows 6 to 9 may correspond to steps S21 1 through S212. Flows 9 to 1 1 may correspond to step S213. Flows 1 1 through 13 may correspond to steps S214 through S215. Flows 14 to 16 may correspond to steps S216 through S221 . Flow 16 may correspond to step S222. Flows 16 to 19 may correspond to steps S223 through S225. Flows 19 to 22 may correspond to steps S226 through S228. And flows 22 through 24 may correspond to step S229.
[0046] FIGS. 2A and 2B show a process flow diagram for implementing secure biometric authentication. Specifically, steps S201 through S229 describe a process for enrolling and using an electronic identity in conjunction with biometric authentication software stored on a user device. According to embodiments, steps S201 through S229 may be performed by the system components of system 100 in Fig. 1 .
[0047] At step S201 , a user of a mobile device may initiate enrollment into a biometric authentication program. In one embodiment, this may be done using an authentication application stored on the user's mobile device. The authentication application may be an application that may be installed onto a user's mobile device. The authentication application may further store application data in memory, which may include data for generating a biometric template, data for a derivation formula, and data for an electronic identity of a user. To initiate enrollment, a user may open/load the authentication application from his or her mobile device and the authentication application may prompt the user to select an option to enroll into a biometric authentication program (e.g. by selecting the option using an input element of the mobile device).
[0048] At step S202, upon initiation of enrollment, the user may provide his or her biometric sample to the mobile device so that a biometric template of the user may be created. The authentication application may prompt the user to provide his or her biometric sample, which may be used to generate a template containing distinct features of the individual's biometric. Examples of biometric samples may include a sample of a user's fingerprint, a current picture of the user, or a sample of the user's voice. Other examples may include the user's iris, the user's palm, or any other distinguishing feature of the individual. A biometric sample may be read using a biometric reader, which can include a fingerprint reader, front-facing camera, microphone, etc. When a biometric sample is taken from the user, distinctive features of the sample may be represented in digital form as a biometric template. For example, a data file may be created from the capture of electromagnetic signals generated by a biometric reader during sample reading, in which the signals may be binned into discrete bits according to a pre-defined resolution (i.e. as expressed by the number of pixels in an image or by the sample rate of an audio file). Software stored on the mobile device may then be used to identify features of the data file that are needed to accurately authenticate the user. For example, the user may be asked to present his or her biometric multiple times, and a mathematical model may be used to determine features that consistently appear. The features may be represented as a binary digital file, which may form the biometric template.
[0049] At step S203, the authentication application stored on the mobile device may generate a derivative of the biometric template of the user. The derivative may be a representation of the biometric template in which the data has been altered, so as to conceal the original feature data of an original biometric template. For example, a binary file representing characteristic features of a user's fingerprint may be passed through a mathematical function that alters each data value in a seemingly random manner. In another embodiment, data values at predetermined locations of a data string representing a biometric template may be removed so obscure the original biometric template. In one embodiment, the mathematical function may be a one-way function based on a zero-knowledge protocol, such as a one-way hashing function. For example, the authentication application may comprise code for recognizing features of a user's fingerprint sample that have a high probability of being captured and identical each time a sample is taken, and may express the features as a unique string of characters that can be identical each time the string of characters is formed. The string may then be passed through a hashing algorithm (e.g. SHA256()), to generate a unique hash. The unique hash may be used as a derivative of the biometric template that cannot be reproduced from any biometric other than the user's. In another
embodiment, the biometric template may be split into multiple parts and the multiple parts each may be passed through the one way function and collected together to form the derivative. For example, a string of characters representing a user's fingerprint template may be divided into 20 strings of equal length, which may each be hashed and the resulting hashes may be appended together to form a derivative. During matching, a derivative may be verified if the consistent features of the user's biometric are captured by a reader and the resulting biometric template or parts of the biometric template match expected results after being passed through the one-way function. According to embodiments, the derivative cannot be reversed engineered to obtain the consistent features of the user's biometric sample. [0050] In one embodiment, a derivative may be generated by tokenizing a biometric template and transporting the derivative through a zero-knowledge security layer. The zero-knowledge security layer may be an additional blockchain layer that uses a zero- knowledge proof to shield the source and anonymize the contents of data published to the blockchain. For example, a biometric template may be derived by generating a token, in which the token is committed to specific conditions such as a specific time of use and/or specific receiving address in order to be valid. The token may be, for example, a string of characters that can be verified using a zero-knowledge proof, and that can only be used for its committed purpose and if a hidden and random number, r, is known. The token may then be used as a record in place of the template data, such that the derivatives may be anonymized.
More information regarding zero-knowledge security layers may be found at:
Eli Ben Sasson, Alessandro Chiesa, Christina Garman, Matthew Green, Ian Miers, Eran Tromer, Madars Virza, "Zerocash: Decentralized Anonymous Payments from Bitcoin", Security and Privacy (SP) 2014 IEEE Symposium on, pp. 459-474, 2014, ISSN 1081 - 601 1 . [0051] At step S204, the mobile device may retrieve an account identifier of the user. The account identifier may be an identifier for an account issued to the user, such as a bank account or social security account. In other examples, the account identifier may be a primary account number (PAN), driver's license number, passport ID number, username and password, etc. The account identifier may be entered into the mobile device by the user or may be retrieved from a memory of the mobile device, such as from a secure element of the device or from application data. In other embodiments, the account identifier may be retrieved from a cloud-based server, or may be provided through another application on the mobile device, such as a digital wallet application. [0052] At step S205, the mobile device may generate an identity request message. The identity request message may comprise the derivative of the biometric template of the user and the account identifier. The identity request message may be generated after the biometric template of the user has been derived and after the account identifier has been retrieved. In one embodiment, the message may be sent upon indication by the user. For example, the authentication application may comprise instructions for displaying a selectable option to the user, which when selected may result in the generation and sending of the identity request message. In some embodiments, the identity request message may comprise additional information of the user such as his or her name, address, date of birth, etc. [0053] At step S206, the identity request message may be sent from the mobile device to a verification server. The verification server may be a server of a verification entity, such as a government agency or bank. The identity request message may be sent from the mobile device to the verification server by way of a network gateway, such as gateway 130 of Fig. 1. For example, the gateway may be a network node capable of receiving the identity request message over the Internet and forwarding the message to a bank's server. The verification server may be able to receive and send messages over the network gateway via an API, such as identity request API 142 of Fig.1.
[0054] At step S207, the verification server may verify the account identifier of the user. According to embodiments, the verification server may receive the identity request message and may identify data fields for the account identifier and derivative of the biometric template. The verification server may then compare the account identifier to an account identifier stored in an account database, and may verify the validity of the account identifier and any additional user information. For example, a bank server may receive a bank account number and a user's name in the identity request message and may verify that the bank account number exists, is under the user's name, and is in good standing. In one embodiment, the verification server may further perform other checks on the user such as credit inquiries, criminal background checks, etc. , which may affect whether or not the user is verified into the authentication program. In one embodiment, the user's information may be verified according to a "know your customer" or KYC process.
[0055] At step S208, the verification server may generate an electronic identity for the user if the account identifier has been verified. In one embodiment, the electronic identity, or elD, may be mathematically derived from information associated with the user. The electronic identity may be a value calculated by hashing one or more input values. For example, the electronic identity may be derived from a combination of a country code, customer name, date of birth, and last four digits of a social security number of a user, such as SHA256(USA*JOHN SMITHS 9700101 *1234). Hashing this value may result in a seemingly random string of characters, such as
754WD2E2513BF546050C2D079FF5D65AB6E318E, and this can be an electronic identity, or elD, for the user.
[0056] At step S209, the verification server may generate a record for the electronic identity and derivative of the first biometric template being linked or associated with one another, and may sign the record using its private key. According to embodiments, the record may serve as a certificate of enrollment into the biometric authentication program. The record may comprise hashes of the electronic identity and the derivative of the biometric template of the user. For example, the record may comprise a hash that is the result of concatenating strings for the electronic identity and derivative and inputting the concatenated string into SHA256(). The record may also comprise time information relating to the time at which the verification verified the user's information. The record may then be signed by the verification server according to a digital signature algorithm. For example, a Federal Information Processing Standard Digital Signature Algorithm (DSA) may be used in conjunction with a bank's private key to generate a verifiable digital signature that may be appended to a hash record. In one embodiment, the record may be identified by a record identifier, such as a transaction ID. According to embodiments, by providing a record of the electronic identity and derivative being linked that is signed by the verification server, criminal actors may be prevented from enrolling fake or stolen identities into the authentication system.
[0057] At step S210, the verification server may insert the signed record into the identity request message, and may then forward the identity request message to a processing server computer for processing. The processing server computer may be processing server computer 150 of Fig. 1 . In one embodiment, an allocated data field may be used to store the signed record in the message, so that it may be received and read by the processing server computer. The verification server may send the identity request message to the processing server computer using instructions stored in an identity request API, and by way of a network gateway. [0058] At step S21 1 , the processing server computer may receive the identity request message, and may link the electronic identity and derivative of the biometric template in a database. In one embodiment, the processing server computer may read allocated data fields for the electronic identity (elD) and for the derivative of the biometric template, and may then store the elD or copy of the elD along with an identifier for the derivative of the biometric template in a database where they may be linked. For example, the electronic identity, 754WD2E2513BF546050C2D079FF5D65AB6E318E' and the derivative ID, 'derivative #129578190' may be linked together in a row of a relational database or of a mapping table.
[0059] At step S212, the processing server computer may submit the derivative of the biometric template to an authentication server for storage. According to embodiments, the derivative of the biometric template may be stored in the authentication data database, where it may be later accessed and retrieved during authentication of a user. The authentication server may be authentication server 160 and the authentication data database may be authentication data database 160B of Fig. 1 . In one embodiment, the processing server computer and authentication server may be the same server or of the same entity. In one embodiment, the processing server computer may also attach an identifier for the derivative, which the authentication server may receive and link to the derivative in the authentication data database. The identifier may be used as a reference at a later point in time when querying for the derivative. [0060] At step S213, the processing server computer may sign the record generated by the verification server and may then publish the record to a public blockchain. The blockchain may be public blockchain 170C of Fig. 1 . The record may be signed using the processing server computer's private key, and according to a digital signature algorithm. The processing server computer may append its digital signature to the record, and may then initiate the writing of the record into a data block and the publishing of the data block to a blockchain. The data block may later be read during authentication of a user in an interaction, such that the validity of the user's electronic identity and its certification into the biometric authentication program may be verified.
[0061] At step S214, the processing server computer may send the electronic identity to the mobile device. The processing server computer may generate an identity response message comprising the electronic identity, which it may send to the mobile device over a network such as the internet (e.g. via the network gateway). The identity response message may also comprise data indicating the successful enrollment for the user into the biometric authentication program, such as data for a confirmation message.
[0062] At step S215, the mobile device may receive the identity response message and may store the electronic identity in memory. The memory be application memory of the authentication application or may be a secure element of the mobile device. In one embodiment, the memory may be a cloud-based memory which may allow the mobile device to access the electronic identity from servers across a network. Once the enrollment and provisioning process has been completed, the user may later use his or her mobile device to prove his or her identity in an interaction.
[0063] At step S216, the user may present the mobile device in an interaction with a resource provider computer. For example, the user may interact with an access device using a communications interface of the mobile device, such as through Bluetooth or near-field communications. In one embodiment, the user may interact with the resource provider through a resource provider application stored on the user's mobile device. The resource provider application may allow for the exchange of data between the mobile device and the resource provider's server computers such that the user may be authenticated and granted resources, such as merchandise or requested services. The resource provider computer may be resource provider computer 120 of Fig. 1 .
[0064] At step S217, the user may provide a second biometric sample to the mobile device. The biometric sample may be of the same biometric used during enrollment into the authentication program, taken at step S202. For example, if the user used an image of his or her face as a biometric during enrollment, the user may then take a current picture of his or herself during the interaction with the resource provider. In another example, if the user took a sample of his or her right index finger during enrollment, the user may then use the mobile device to take a sample of his or her right index finger during the interaction. The mobile device may take the biometric sample of the user and generate a second biometric template.
[0065] At step S218, the authentication application stored on the mobile device may generate a derivative of the second biometric template of the user. The derivative of the second biometric template may be generated in the same manner as the derivative of the first biometric template generated at step S203. This may be done such that matching samples should result in matching derivatives within a predetermined threshold.
[0066] At step S219, the mobile device may retrieve the electronic identity from memory. The memory may be the memory in which the electronic identity was stored in at step S215. In one embodiment, access to the electronic identity may be protected using a passphrase or username and password. For example, the electronic identity may be stored in a secure memory, in which access can only be granted to an application if the user enters his or her pin.
[0067] At step S220, the authentication application may append the electronic identity (elD) to the derivative of the second biometric template of the user. In one embodiment, the electronic identity and the derivative of the second biometric template may both be represented as a string of characters of predefined length. For example, the electronic identity may be a hash of 30 letters and numbers, and the derivative of the second biometric template may be a string of 100 characters representing mathematically derived feature data of a user's biometric sample. The appended elD and derivative may then be a string of 130 characters in length.
[0068] At step S221 , the mobile device may generate an authentication request message comprising the appended electronic identity and derivative, and may send the authentication request message to the resource provider computer. The resource provider computer may then forward the authentication request message to a processing server computer, using an authentication API. The authentication API may be authentication API 122 of Fig. 1 . At step S222, the processing server computer may receive the authentication request message.
[0069] At step S223, the processing server computer may decouple the electronic identity from the derivative of the second biometric template. In one embodiment, this may be done by determining the length of the electronic identity and the length of the derivative of the second biometric template, and then splitting the appended electronic identity and derivative into two separate data elements based on the length. For example, the processing server computer may determine that the electronic identity should be a string of 30 characters and that the derivative of the second biometric template should be a string of 100 characters. When the processing server computer receives a 130 character string in an authentication request message, it may declare a variable for the electronic identity to which it allocates the first 30 characters of the string, and may declare a variable for the derivative of the second biometric template to which it allocates the remaining 100 characters. In other embodiments, one or more designated characters may separate the electronic identity data and the derivative of the second biometric template. In yet other embodiments, these two pieces of data may be provided in known data fields.
[0070] At step S224, the processing server computer may determine from records, a derivative of a first biometric template linked to the electronic identity. This may be the derivative linked to the electronic identity at step S21 1 . The record may be in the form of a mapping table or relational database, which the processing server computer may query for the electronic identity (elD) and identity derivatives and other data linked to the queried electronic identity. For example, the elD may be linked in a row of a relational database to an identifier for a derivative of a first biometric template of a user and to other additional information of the user such as name, address, etc. The identified derivative may be retrieved, by the processing server computer, from an authentication data database by sending a request to an authentication server. For example, the processing server computer may send a request comprising an identifier for the derivative of the first biometric template of the user (e.g. 'derivative #129578190'). The identifier may be used by the authentication server to query for the derivative, which the authentication server may submit to the processing server computer for comparison to the derivative of the second biometric template of the user.
[0071] At step S225, the processing server computer may compare the derivative of the second biometric template with the derivative of the first biometric template for a match. In one embodiment, this may be done, by comparing each data element of the derivative of the second biometric template to a corresponding data element of the derivative of the first biometric template. In some embodiments, two derivatives may be considered a match if less than a predetermined number of data elements differ. For example, the derivatives may be expressed as a string of equal length, and the processing server computer may compare each corresponding character (first, second, third, etc.) from each string to one another, and may determine a match if less than 10 characters differ. In other embodiments, two derivatives are a match if there is an exact match (e.g., as with two hashes of identical data derived from biometric samples obtained at different times). [0072] Meanwhile, at step S226, the processing server computer may search for a record on the public blockchain relating to the electronic identity and first biometric template. The processing server computer may search the blockchain for a data block that comprises the electronic identity. In one embodiment, this may be done by scanning the blockchain for a data block comprising the record identifier generated at step S209. For example, the processing server computer may be coupled to a relational database, in which electronic identities are linked to entries for a transaction ID and transaction timestamp relating to the time at which an electronic identity was used to enroll a user into the biometric authentication program. The processing server computer may then search the blockchain for a record that comprises the transaction ID and transaction timestamp. In one embodiment, the record may comprise hashes of the electronic identity and of the derivative of the first biometric template, and the
processing server computer may verify that the hashes of the electronic identity and of the derivative of the first biometric template match expected results. For example, the processing server computer may concatenate strings for the electronic identity and for the derivative and input the concatenated string into SHA256(). The processing server computer may then determine if the resulting output matches a corresponding record identified on the blockchain. In embodiments, this type of verification may be seen as a first validation check.
[0073] At step S227, the processing server computer may validate the record by verifying one or more digital signatures appended to the record. In one embodiment, a digital signature may be verified by inputting the digital signature and the public key of the alleged signing entity into a verification algorithm and determining if the output matches expected results. At step S228, the processing server computer may determine an authentication result based at least upon the comparison of the
derivatives and the validity of the electronic identity. According to embodiments, the authentication result may be considered positive (i.e. authentic user), if both of the derivatives of the biometric templates match and if the digital signatures appended to the record of the elD and derivative being linked (i.e. certificate of enrollment) are validated.
[0074] At step S229, the processing server computer may send the authentication result to the mobile device in an authentication response message. The authentication result may first be sent to the resource provider computer and then forwarded to the mobile device. If the authentication result is positive, then the resource provider computer may consider the user's credentials authentic and may grant access to a requested resource. For example, the resource provider computer may be a computer that unlocks the door of a building, and a positive authentication result may initiate actuators to disable the door's locking mechanism. [0075] According to embodiments of the invention, the process described by Figs. 2A and 2B may allow a user to prove his or her identity using secure biometric
authentication. The biometric may be a fingerprint, image of the user's face, recording of the user's voice, etc. as provided by a biometric reader of the user's mobile device. A derived template of the user's biometrics may be first registered during enrollment and linked to an electronic identity unique to the user. The generation of the electronic identity and its association with the derivative of the biometric template may be represented as a record published on a public blockchain. The record may serve as a certificate of enrollment, and may be digitally signed by trusted entities (banks, government institutions, etc.) so as to provide greater validation checks. The electronic identity may be stored on the user's mobile device, and may be sent to a processing server computer to authenticate the user during an interaction with a resource provider. The authentication process may further comprise taking a second sample of a user's biometric to generate a derivative of a second biometric template that may be compared to the derivative generated during enrollment. The method provided can be more secure than other biometric authentication systems, in that a user's biometric template is derived so as to conceal the nature of data stored therein. Furthermore, the validity of the biometric template is also dependent on the validity of the electronic identity, as determined by the verification of digital signatures appended to a record on a
blockchain. Thus, embodiments of the invention provide a method of authentication that is both more secure and more convenient than other means of proving one's identity.
[0076] FIG. 3 shows a block diagram of a processing server computer for
implementing biometric authentication. Processing server computer 300 shown may be processing server computer 150 of Fig. 1. Processing server computer 300 may comprise a processor 310 for executing instructions, and a network interface 320 for communicating over a network. Processing server computer 300 may further comprise a computer readable medium 330. Computer readable medium 330 may be a memory storing executable instructions in the form of code. Computer readable medium 330 may comprise modules of code that may be executed by processor 310 such as communication module 330A, mapping module 330B, authentication data storage module 330C, signing module 330D, block writing module 330E, authentication request module 330F, data lookup module 330G, derivative comparison module 330H, signature validation module 3301, and authentication response module 330J. Processor server computer 330 may further be coupled to one or more databases such as elD mapping database 300A, authentication data database 300B, and public blockchain 300C.
[0077] ElD mapping database 300A may be a database in which electronic identities are linked to user data. In embodiments, the user data may include a derivative of a biometric template of the user. During enrollment of a user into a biometric
authentication program, processing server computer 300A may receive an identity request message comprising an electronic identity and a derivative of a biometric template of the user. Processing server computer 300A may then link the electronic identity to the derivative of the biometric template of the user in a mapping table (i.e. lookup table) of elD mapping database 300A, which may later be queried during authentication of the user. For example, elD mapping database 300A may be a relational database in which electronic identities in a column are each linked in a row to one or more identifiers for one or more derivatives of biometric templates. As explained above, an electronic identity may be a hash that is mathematically derived from information associated with a user.
[0078] A derivative of a biometric template may also be represented as a string, such as a string of altered pixel values for an image (e.g. "255 232 45 678 56 23....345 76 44 767 433 345"). In one embodiment, an identifier for the derivative of the biometric template may be stored in elD mapping database, rather than the derivative of the biometric template itself. Meanwhile, the derivative itself may be stored in
authentication data database 300B. For example, a derivative may be identified by a derivative identifier, 'derivative #129578190,' which may be referenced by an
authentication server to query for and retrieve the derivative from authentication data database 300B.
[0079] Authentication data database 300B may be a database in which user authentication data may be stored. In embodiments, the user authentication data may comprise a derivative of a biometric template of a user. In one embodiment, authentication data database 300B may be accessible by processing server computer 300, by way of an authentication server. For example, processing server computer 300 may send a request for authentication data to the authentication server, which may retrieve the authentication data from authentication data database 300B. The request may comprise an identifier for the authentication data, such as a derivative ID identifying a derivative of a biometric template of a user (e.g. 'derivative #129578190').
[0080] Public blockchain 300C may be a distributed database in which immutable records are stored and chained together. In one embodiment, the immutable records may comprise records for the certification of an electronic identity into a biometric authentication program. The immutable records may further be verifiable through a distributed verification network, in which records may be validated by trusted entities. The trusted entities may validate an immutable record by comparing digital signatures appended to the record using public keys of the signing entities. For example, a server computer of a payment processing network may validate a record by inputting the record and a public key of a bank that allegedly notarized the record into a verification algorithm, and then checking if the output matches expected results.
[0081] As explained above, processing server computer 300 may comprise a plurality of software modules, which may comprise instructions for executing tasks according to embodiments. Communication module 330A may comprise instructions for sending, receiving, and reformatting messages. The messages may be sent and received by processing server computer 300 over network interface 320. For example, processing server computer 300 may receive identity request messages and authentication request messages, and may send identity response messages and authentication messages over network interface 320. [0082] Mapping module 330B may comprise instructions for mapping electronic identities to user data. The user data may include a derivative of a biometric template of a user. According to embodiments, a verification server may generate an electronic identity (elD) for a user upon verification of an account identifier of the user. The verification server may forward an identity request message comprising the elD and a derivative of a biometric template of the user to processing server computer 300. Mapping module 330B may comprise instructions for identifying data fields in an identity request message allocated for an elD and for a derivative. Mapping module 330B may further comprise instructions for reading the data fields, and storing data of the fields (or identifiers thereof) in a database. For example, the electronic identity and a derivative identifier may be stored in elD mapping database 300A, where they may be linked to each other in a mapping table. In one example, the processing server computer may store in a row of a relational database, an electronic identity for:
754WD2E2513BF546050C2D079FF5D65AB6E318E along with an identifier for a derivative of a biometric template, such as: 'derivative #129578190.' In another embodiment, the electronic identity may further be linked to an identifier for a record of the elD and derivative being linked, such as a transaction ID or certificate ID, which may be used to identify the record on public blockchain 300C.
[0083] Authentication data storage module 330C may comprise instructions for storing user authentication data in a database. According to embodiments, the authentication data may comprise a derivative of a biometric template of a user. In one embodiment, authentication data storage module 330C may comprise instructions for attaching an identifier to the derivative of the biometric template of the user, and may further comprise instructions for sending the derivative to an authentication server. The authentication server may store the derivative in authentication data database 300B along with its identifier, so that it may be identified and retrieved at a later time.
[0084] Signing module 330D may comprise instructions for signing a record using a private key. According to embodiments, records may be signed by trusted entities in a distributed verification network according to a digital signature algorithm. Processing server computer 300 may be a node of the distributed verification network, and signing module 330D may comprise code instructing processor 310 to sign a received record using its private key, in conjunction with the digital signature algorithm.
[0085] Block writing module 330E may comprise instructions for initiating of writing data to public blockchain 300C. According to embodiments, public blockchain 300C may be used to store records relating to the enrollment of a user into a biometric authentication program. Each record may comprise an indication of an electronic identity and a derivative of a biometric template of a user being linked. Each record may further comprise one or more digital signatures of trusted entities. In one embodiment, processing server computer 300 may initiate the publishing of records to public blockchain 300C by broadcasting a new data block. For example, block writing module 330E may comprise code instructing processor 310 to generate a new data block for a record. Block writing module 330E may further comprise instructions for broadcasting the new data block to public blockchain 300C so that a node of a distributed network storing copies of public blockchain 300C may publish the new data block. The method for writing to a public blockchain may vary according to the method of consensus established for the blockchain. Example methods of consensus governing the writing of blocks in a blockchain may include proof-of-work, proof-of- stake, proof-of-space, proof-of-authority, etc.
[0086] Authentication request module 330F may comprise instructions for decoding data received in an authentication request message. According to embodiments, an authentication request message may be received by processing server computer 300 from a resource provider computer so that processing server computer 300 may authenticate a user. In one embodiment, the authentication request message may comprise an electronic identity and derivative of a biometric template of the user. The electronic identity and the derivative may be included together in the authentication request message (e.g. as an appended string), and authentication request module 330F may comprise instructions for decoupling the electronic identity and derivative.
Authentication request module 330F may comprise instructions for processor 310 to identify one or more data fields allocated for the electronic identity and derivative, read the one or more data fields, and to declare variables to which the electronic identity and derivative should be assigned. For example, processor 310 may determine that the first 30 characters of an appended string should be assigned and allocated as an electronic identity, and that the remaining 100 characters are assigned and allocated as a derivative.
[0087] Data lookup module 330G may comprise instructions for looking up data in a database, such as elD mapping database 300A. According to embodiments, when an authentication request message is received by processing server computer 300, processing server computer 300 may identify an electronic identity received in the message, and may determine a derivative of a biometric template linked to the electronic identity. The derivative linked to the electronic identity may be linked in elD mapping database 300A, and data lookup module 330G may comprise instructions for querying elD mapping database 300A for the electronic identity and any data linked to it. For example, elD mapping database 300A may be a relational database, and data lookup module 330G may include instructions for retrieving a row of data in the relational database that comprises an electronic identity received in an authentication request message. The row of data may further comprise an identifier for a derivative of a biometric template of a user (e.g. 'derivative #129578190').
[0088] Derivative comparison module 330H may comprise instructions for comparing derivatives for a first and second biometric template. According to some embodiments, a derivative of a first biometric template stored during enrollment may be compared to a derivative of a second biometric template to authenticate a user. In one embodiment, two derivatives may be considered a match if a predetermined number of data elements of the derivatives match. For example, derivatives of feature data for a user's fingerprint may be expressed as a string of characters representing a sequence of values. The sequence of values may be values for biometric template data that have been mathematically derived. A match may be determined by comparing each corresponding characters between two strings and determining if a predetermined number of characters match. In another example, a derivative of a sample of a user's face may be represented as a matrix of altered pixel values. A match may be determined by comparing each corresponding matrix element between two matrices and determining if a predetermined number of elements match. In other examples, a derivative may be expressed as a series of bits, bytes in an array, etc. Derivative comparison module 330H may comprise instructions for comparing data elements of two derivatives and determining a match if the data elements match within a predetermined threshold (e.g. at least 90% of characters matching between two strings). In some embodiments, the derivatives of the biometric templates can be compared by using less data than the entire biometric template, and the comparison process can use a "zero-knowledge proof" protocol in some embodiments. [0089] Signature validation module 3301 may comprise instructions for validating one or more digital signatures using one or more public keys. According to embodiments, during authentication, a record on public blockchain 300C may be searched and may comprise one or more digital signatures. In one embodiment, signature validation module 3301 may comprise code instructing processing server computer 300 to validate the one or more signatures according to a digital signature algorithm (DSA). The code may comprise instructions for retrieving or obtaining one or more public keys of the signing entities, and verifying the one or more digital signatures with the one or more public keys, in conjunction with a verification algorithm. For example, the signing entities may include banks and governments, whom may allow access to their public keys in a distributed verification network. The public keys may be retrieved by processing server computer 300 and used to determine if the digital signatures appended to a record are valid.
[0090] Authentication response module 330J may comprise instructions for generating an authentication response comprising an authentication result. According to some embodiments, a user may be authenticated during an interaction upon the
determination of a positive authentication result (i.e. user credentials determined to be authentic). In one embodiment, processing server computer 300 may determine an authentication result based on both the comparison of derivatives for a first and second biometric template of a user and based on the validity of an electronic identity. The comparison of derivatives may be determined using instructions from derivative comparison module 330H and the validity of the electronic identity (elD) may be based on the validation of one or more digital signatures appended to a record relating to the elD. Authentication response module 330 J may comprise code for determining the authentication result, and for inserting the authentication result into an authentication response message. For example, authentication response module 330J may comprise instructions for generating a positive authentication result if a match occurs between compared derivatives and if an electronic identity is determined to be valid.
Authentication response module 330J may further comprise code for inserting the positive authentication result in an authentication response message. The
authentication response message comprising the authentication result may be then be sent to a resource provider computer and forwarded to a user device to authenticate the user of the device (e.g. for the purpose of gaining access to a network).
[0091] According to some embodiments of the invention, processing server computer 300 may process data to implement biometric authentication for users. The users may enroll into a biometric authentication program using a user device. The user device may be used to generate a derivative of a first biometric template of a user, and to request an electronic identity that may be certified in a record published to public blockchain 300C. The user device may store the user's electronic identity for later use in an interaction. During an interaction, the user device may generate a derivative of a second biometric template of the user, which may be sent to processing server computer 300. Processing server computer 300 may then authenticate the user based on the comparison of derivatives for the first and second biometric template of the user, and based on the validity of the electronic identity generated for the user.
[0092] FIG. 4 shows a block diagram of a user device for implementing biometric authentication. User device 410 may be mobile device 1 10 of Fig. 1. User device 410 may comprise memory 41 1 . Memory 41 1 may store data, such as data for one or more applications. The one or more applications may include authentication application 412 and resource provider application 420. User device 410 may further comprise biometric reader 414 for reading biometric samples of a user and biometric interface 413 for transmitting data between biometric reader 414 and an application of the user device. Examples of biometric reader 414 may include a fingerprint reader, a front-facing camera, a microphone, etc. User device 410 may further comprise communications element 415 for allowing communications between user device 410 and other devices, such as through wireless communications (e.g. via antenna 419). [0093] In addition, user device 410 may also comprise data input/output 416 for receiving inputs from a user. For example, data input/output 416 may be an input element of a touchscreen from which display icons may be selected, and from which a virtual keyboard may be displayed to receive user commands. User device 410 may also comprise display 417 for displaying data to a user and processor 418 for processing data and executing instructions to complete tasks. [0094] According to embodiments, a user may enroll into a biometric authentication program for proving his or her identity in an interaction with a resource provider. The interaction, may be, for example, a transaction with a merchant or a login attempt into a network. A user may enroll via authentication application 412, which may connect the user to one or more server computers over a network. Authentication application 412 may be used to derive a biometric template of the user taken from biometric interface 413 and biometric reader 414, which may be linked by one of the server computers to an electronic identity (elD) generated for the user. The elD may be stored on user device 410, and during an interaction, user device 410 may send the elD and a derivative of a second biometric template (e.g. via communications element 415 and antenna 419) to the server computer for authentication. An authentication result may be determined based on the comparison of the derivative of the second biometric template to the derivative of the first biometric template recorded during enrollment, and based on the validity of the electronic identity. User device 410 may then receive the authentication result, indicating if the user's identity has been successfully proven.
[0095] A number technical advantages are provided by the described embodiments over prior art. Embodiments of the invention allow a user to identify his or herself in an interaction using his or her mobile device. This eliminates the need to carry around physical identification cards, which may be inconvenient for users. According to embodiments, a user may simply identify his or herself using a biometric (e.g. by taking a current picture of his or her face, or by reading his or her fingerprint). Furthermore, embodiments of the invention are more secure than other biometric authentication methods previously conceived. For example, a user's biometric data is derived rather than sent in the clear, yet may still be verified without revealing a user's original biometric. In addition, embodiments of the invention subject the use of a user's biometric data to numerous validation checks involving digital signatures of trusted parties and immutable records. This may prevent a criminal actor from successfully using fake or stolen identities in the authentication system. In terms of the distributed nature of the identity verification and biometric authentication servers, embodiments of the invention provide APIs that allow for compatibility with a plurality of verification entities, thus allowing for ease of performing validation checks and providing greater security as needed.
[0096] Any of the computer systems mentioned herein may utilize any suitable number of subsystems. In some embodiments, a computer system includes a single computer apparatus, where the subsystems can be the components of the computer apparatus. In other embodiments, a computer system can include multiple computer apparatuses, each being a subsystem, with internal components.
[0097] A computer system can include a plurality of the same components or subsystems, e.g., connected together by an external interface. In some embodiments, computer systems, subsystem, or apparatuses can communicate over a network. In such instances, one computer can be considered a client and another computer a server. A client and a server can each include multiple systems, subsystems, or components, mentioned herein.
[0098] The specific details of particular embodiments may be combined in any suitable manner without departing from the spirit and scope of embodiments of the invention. However, other embodiments of the invention may be directed to specific embodiments relating to each individual aspect, or specific combinations of these individual aspects.
[0099] It should be understood that the present invention as described above can be implemented in the form of control logic using hardware and/or using computer software in a modular or integrated manner. Based on the disclosure and teachings provided herein, a person of ordinary skill in the art will know and appreciate other ways and/or methods to implement the present invention using hardware and a combination of hardware and software
[0100] Any of the software components or functions described in this application, may be implemented as software code to be executed by a processor using any suitable computer language such as, for example, Java, C++ or Perl using, for example, conventional or object-oriented techniques. The software code may be stored as a series of instructions, or commands on a computer readable medium for storage and/or transmission, suitable media include random access memory (RAM), a read only memory (ROM), a magnetic medium such as a hard-drive or a floppy disk, or an optical medium such as a compact disk (CD) or DVD (digital versatile disk), flash memory, and the like. The computer readable medium may be any combination of such storage or transmission devices.
[0101] Such programs may also be encoded and transmitted using carrier signals adapted for transmission via wired, optical, and/or wireless networks conforming to a variety of protocols, including the Internet. As such, a computer readable medium according to an embodiment of the present invention may be created using a data signal encoded with such programs. Computer readable media encoded with the program code may be packaged with a compatible device or provided separately from other devices (e.g., via Internet download). Any such computer readable medium may reside on or within a single computer program product (e.g. a hard drive, a CD, or an entire computer system), and may be present on or within different computer program products within a system or network. A computer system may include a monitor, printer, or other suitable display for providing any of the results mentioned herein to a user.
[0102] The above description of exemplary embodiments of the invention has been presented for the purposes of illustration and description. It is not intended to be exhaustive or to limit the invention to the precise form described, and many
modifications and variations are possible in light of the teaching above. The
embodiments were chosen and described in order to best explain the principles of the invention and its practical applications to thereby enable others skilled in the art to best utilize the invention in various embodiments and with various modifications as are suited to the particular use contemplated.

Claims

WHAT IS CLAIMED IS: 1 . A method comprising:
receiving, by a user device, a second biometric template of a user;
providing, by the user device, an authentication request message comprising an electronic identity and a derivative of the second biometric template of the user to a resource provider computer to conduct an interaction, the authentication request being forwarded to a processing server computer by the resource provider computer; and
receiving, by the user device, an authentication response message comprising an authentication result from the processing server computer,
wherein the authentication result is determined by the processing server computer based on a comparison of the derivative of the second biometric template to a derivative of a first biometric template accessible to the processing server computer, and wherein the authentication result is also based on a validity of the electronic identity.
2. The method of claim 1 , further comprising:
receiving, by the user device, the first biometric template of the user;
generating, by the user device, the derivative of the first biometric template;
generating, by the user device, an identity request message for an electronic identity for the user, the identity request message comprising the derivative of the first biometric template and an account identifier of the user;
sending, by the user device, the identity request message to a verification server, wherein the verification server verifies the account identifier and generates the electronic identity, and wherein the electronic identity is linked to the derivative of the first biometric template in a database by the processing server computer;
receiving, by the user device, an identity response message comprising the electronic identity; and
storing, by the user device, the electronic identity in a memory of the user device for later use in an interaction.
3. The method of claim 2, wherein the processing server computer initiates the publishing of a record to a blockchain, the record comprising a record of the electronic identity and the derivative of the first biometric template of the user being linked.
4. The method of claim 3, wherein the validity of the electronic identity is based at least upon the record published on the blockchain of the electronic identity and the derivative of the first biometric template of the user being linked.
5. The method of claim 3, wherein the record of the electronic identity and the derivative of the first biometric template being linked is signed by the verification server and the processing server computer using a digital signature encryption scheme.
6. The method of claim 5, wherein the validity of the electronic identity is based at least upon the validation of one or more digital signatures appended to the record of the electronic identity and the derivative of the first biometric template being linked.
7. The method of claim 2, wherein the derivative of the first biometric template and the derivative of the second biometric template are derived from the first biometric template and second biometric template of the user respectively by passing the first and second biometric templates through an algorithm.
8. The method of claim 2, wherein the derivative of the first biometric is stored and retrieved by the processing server computer by communicating with an authentication server.
9. A server computer comprising:
a network interface;
a processor; and
a non-transitory computer-readable medium comprising code for instructing the processor to implement a method, the method comprising: receiving, by the server computer, an authentication request message comprising an electronic identity and a derivative of a second biometric template of a user of a user device;
determining, by the server computer, a derivative of a first biometric template linked to the electronic identity;
retrieving, by the server computer, the derivative of the first biometric template;
comparing, by the server computer, the derivative of the first biometric template to the derivative of the second biometric template; and
determining, by the server computer, an authentication result based at least upon the comparison of the derivative of the first biometric template to the derivative of the second biometric template and at least upon the validity of the electronic identity.
10. The server computer of claim 9, wherein the method further comprises:
receiving, by the server computer, an identity request message comprising the derivative of the first biometric template and the electronic identity, wherein the electronic identity is received from a verification server after the verification server verifies an account identifier of the user;
linking, by the server computer, the derivative of the first biometric template and the electronic identity in a mapping table;
storing, by the server computer, the derivative of the first biometric template in a database; and
generating, by the server computer, an identity response message comprising the electronic identity, wherein the identity response message is received by the user device, and wherein the user device stores the electronic identity in a memory of the user device for later use in an interaction.
1 1 . The server computer of claim 10, wherein the method further comprises: initiating, by the server computer, the publishing of a record to a
blockchain, the record comprising a record of the electronic identity and the derivative of the first biometric template being linked.
12. The server computer of claim 1 1 , wherein determining the authentication result based at least upon the validity of the electronic identity comprises:
comparing, by the server computer, the electronic identity to a record on the blockchain of the electronic identity and the derivative of the first biometric template being linked; and
validating, by the server computer, the electronic identity if the electronic identity matches the record published on the blockchain.
13. The server computer of claim 1 1 , wherein the record on the blockchain of the electronic identity and the derivative of the first biometric template being linked is signed by the verification server and the server computer using a digital signature encryption scheme.
14. The server computer of claim 13, wherein determining the authentication result based at least upon the validity of the electronic identity comprises:
validating, by the server computer, the digital signatures appended to the record published on the blockchain using the public keys of at least the verification server.
15. The server computer of claim 10, wherein the derivative of the first biometric template and derivative of the second biometric template are derived from the first biometric template and second biometric template of the user respectively by passing the first and second biometric template through an algorithm.
16. The server computer of claim 10, wherein storing the derivative of the first biometric template in a database comprises:
sending, by the server computer, the derivative of the first biometric template to an authentication server, wherein the authentication server stores the derivative of the first biometric template in the database, and wherein retrieving the derivative of the first biometric template comprises sending a request to the
authentication server.
17. A resource provider computer comprising:
a network interface;
a processor; and
a non-transitory computer-readable medium comprising code for instructing the processor to implement a method, the method comprising:
receiving, by the resource provider computer, an authentication request message from a user device of a user, the authentication request message comprising an electronic identity and a derivative of a second biometric template of the user;
sending, by the resource provider computer, the authentication request message to a processing server computer, the processing server computer determining an authentication result based at least upon the comparison of the derivative of the second biometric template to a derivative of a first biometric template and based at least upon the validity of the electronic identity;
receiving, by the resource provider computer, from the processing server computer, an authentication response message comprising the authentication result;
sending, by the resource provider computer, the authentication response message to the user device; and
authenticating, by the resource provider computer, the user if the authentication result indicates that the derivative of the second biometric template and the derivative of the first biometric template match, and if the authentication result indicates that the electronic identity is valid, wherein the electronic identity is generated by a verification server upon verification of an account identifier of the user.
18. The resource provider computer of claim 17, wherein the validity of the electronic identity is based at least upon a record published on a blockchain of the electronic identity and the derivative of the first biometric template being linked.
19. The resource provider computer of claim 18, wherein the record published on the blockchain is signed by the verification server and the processing server computer.
20. The resource provider computer of claim 19, wherein the validity of the electronic identity is based at least upon the validation of one or more digital signatures appended to the record published on the blockchain.
PCT/US2017/035783 2017-06-02 2017-06-02 Secure biometric authentication using electronic identity WO2018222211A1 (en)

Priority Applications (5)

Application Number Priority Date Filing Date Title
PCT/US2017/035783 WO2018222211A1 (en) 2017-06-02 2017-06-02 Secure biometric authentication using electronic identity
US16/618,741 US11190355B2 (en) 2017-06-02 2017-06-02 Secure biometric authentication using electronic identity
CN201780091522.9A CN110741369B (en) 2017-06-02 2017-06-02 Secure biometric authentication using electronic identity
EP17911928.4A EP3631664B1 (en) 2017-06-02 2017-06-02 Secure biometric authentication using electronic identity
US17/513,467 US20220052852A1 (en) 2017-06-02 2021-10-28 Secure biometric authentication using electronic identity

Applications Claiming Priority (1)

Application Number Priority Date Filing Date Title
PCT/US2017/035783 WO2018222211A1 (en) 2017-06-02 2017-06-02 Secure biometric authentication using electronic identity

Related Child Applications (2)

Application Number Title Priority Date Filing Date
US16/618,741 A-371-Of-International US11190355B2 (en) 2017-06-02 2017-06-02 Secure biometric authentication using electronic identity
US17/513,467 Continuation US20220052852A1 (en) 2017-06-02 2021-10-28 Secure biometric authentication using electronic identity

Publications (1)

Publication Number Publication Date
WO2018222211A1 true WO2018222211A1 (en) 2018-12-06

Family

ID=64456486

Family Applications (1)

Application Number Title Priority Date Filing Date
PCT/US2017/035783 WO2018222211A1 (en) 2017-06-02 2017-06-02 Secure biometric authentication using electronic identity

Country Status (4)

Country Link
US (2) US11190355B2 (en)
EP (1) EP3631664B1 (en)
CN (1) CN110741369B (en)
WO (1) WO2018222211A1 (en)

Cited By (10)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
WO2020123192A1 (en) * 2018-12-14 2020-06-18 Mastercard International Incorporated Systems, methods, and non-transitory computer-readable media for secure individual identification
FR3091941A1 (en) * 2019-01-22 2020-07-24 Idemia Identity & Security France Biometric authentication verification process
EP3731115A1 (en) * 2019-04-26 2020-10-28 Visa International Service Association Distributed ledger data verification network
WO2021030388A1 (en) * 2019-08-13 2021-02-18 Mastercard International Incorporated Systems and methods for use in provisioning tokens associated with digital identities
WO2021067172A1 (en) * 2019-10-01 2021-04-08 Visa International Service Association Delegated biometric authentication
CN113226864A (en) * 2018-12-19 2021-08-06 戴姆勒股份公司 Processing system
WO2022016278A1 (en) 2020-07-21 2022-01-27 Royal Bank Of Canada Facial recognition tokenization
US11308189B2 (en) 2016-08-23 2022-04-19 Visa International Service Association Remote usage of locally stored biometric authentication data
US20220121730A1 (en) * 2020-10-20 2022-04-21 Mastercard International Incorporated Digital Rights Management Platform
US11823194B2 (en) * 2018-01-27 2023-11-21 Redrock Biometrics, Inc. Decentralized biometric authentication platform

Families Citing this family (29)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US10277400B1 (en) 2016-10-20 2019-04-30 Wells Fargo Bank, N.A. Biometric electronic signature tokens
CN107257340B (en) * 2017-06-19 2019-10-01 阿里巴巴集团控股有限公司 A kind of authentication method, authentication data processing method and equipment based on block chain
US11018870B2 (en) * 2017-08-10 2021-05-25 Visa International Service Association Biometric verification process using certification token
US11405386B2 (en) * 2018-05-31 2022-08-02 Samsung Electronics Co., Ltd. Electronic device for authenticating user and operating method thereof
US11488160B2 (en) 2018-07-30 2022-11-01 Hewlett Packard Enterprise Development Lp Systems and methods for using captured time series of secured representations of distributed ledger addresses and smart contract deployed on distributed ledger network to prove compliance
US11184175B2 (en) 2018-07-30 2021-11-23 Hewlett Packard Enterprise Development Lp Systems and methods for using secured representations of location and user distributed ledger addresses to prove user presence at a location and time
US11270403B2 (en) 2018-07-30 2022-03-08 Hewlett Packard Enterprise Development Lp Systems and methods of obtaining verifiable image of entity by embedding secured representation of entity's distributed ledger address in image
US11403674B2 (en) * 2018-07-30 2022-08-02 Hewlett Packard Enterprise Development Lp Systems and methods for capturing time series dataset over time that includes secured representations of distributed ledger addresses
US11250466B2 (en) 2018-07-30 2022-02-15 Hewlett Packard Enterprise Development Lp Systems and methods for using secured representations of user, asset, and location distributed ledger addresses to prove user custody of assets at a location and time
US11356443B2 (en) 2018-07-30 2022-06-07 Hewlett Packard Enterprise Development Lp Systems and methods for associating a user claim proven using a distributed ledger identity with a centralized identity of the user
US11233641B2 (en) 2018-07-31 2022-01-25 Hewlett Packard Enterprise Development Lp Systems and methods for using distributed attestation to verify claim of attestation holder
US11488161B2 (en) 2018-07-31 2022-11-01 Hewlett Packard Enterprise Development Lp Systems and methods for providing transaction provenance of off-chain transactions using distributed ledger transactions with secured representations of distributed ledger addresses of transacting parties
US11271908B2 (en) 2018-07-31 2022-03-08 Hewlett Packard Enterprise Development Lp Systems and methods for hiding identity of transacting party in distributed ledger transaction by hashing distributed ledger transaction ID using secured representation of distributed ledger address of transacting party as a key
CN109088865B (en) * 2018-08-02 2021-10-12 京东方科技集团股份有限公司 User identity authentication method and device, readable storage medium and computer equipment
US11057377B2 (en) * 2018-08-26 2021-07-06 Ncr Corporation Transaction authentication
JP7206698B2 (en) * 2018-08-28 2023-01-18 セイコーエプソン株式会社 Providing device, processing system and communication method
KR20200100481A (en) * 2019-02-18 2020-08-26 삼성전자주식회사 Electronic device for authenticating biometric information and operating method thereof
US11070379B2 (en) * 2019-04-18 2021-07-20 Advanced New Technologies Co., Ltd. Signature verification for a blockchain ledger
US11165582B2 (en) * 2019-05-20 2021-11-02 Chia Network Inc. Consensus layer architecture for maintaining security with reduced processing power dependency in untrusted decentralized computing platforms
FR3096480B1 (en) * 2019-05-24 2021-04-23 Idemia Identity & Security France Strong authentication process for an individual
US11425165B2 (en) * 2019-06-04 2022-08-23 Mcafee, Llc Methods, systems, articles of manufacture and apparatus to reduce spoofing vulnerabilities
CN111614679B (en) * 2020-05-22 2021-07-27 深圳前海微众银行股份有限公司 Federal learning qualification recovery method, device and readable storage medium
CN112953888B (en) * 2020-12-29 2023-10-31 合肥达朴汇联科技有限公司 Block chain anonymous user auditing method and system applied to block chain client
US11854009B2 (en) 2021-10-07 2023-12-26 Chia Network Inc. Method for pooling in a proof-of-space-based blockchain via singletons
CN114389818B (en) * 2021-12-28 2024-09-10 连连宝(杭州)信息技术有限公司 Encryption authentication management method, device, system and storage medium
US20230336523A1 (en) * 2022-04-13 2023-10-19 Unstoppable Domains, Inc. Domain name registration based on verification of entities of reserved names
CN114896575B (en) * 2022-04-28 2024-04-16 西安电子科技大学 Trusted identity identification method and device based on false attribute detection
WO2024035348A1 (en) * 2022-08-08 2024-02-15 Finema Company Limited Method for secure privacy-preserving device-free biometric signing with multi-party computation and cancelable biometric template
US20240127645A1 (en) * 2022-10-12 2024-04-18 Truist Bank Virtual identification for granting secure access using two forms of authentication

Citations (6)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
JP2011257818A (en) * 2010-06-07 2011-12-22 Hitachi Information & Control Solutions Ltd Bio-information lending system, and bio-information lending method
WO2012124115A1 (en) * 2011-03-17 2012-09-20 富士通株式会社 Biological information acquisition device, biological information comparison device, and program
US20130318359A1 (en) * 2012-05-22 2013-11-28 Partnet, Inc. Systems and methods for verifying uniqueness in anonymous authentication
US8752146B1 (en) * 2012-03-29 2014-06-10 Emc Corporation Providing authentication codes which include token codes and biometric factors
JP2014219711A (en) * 2013-05-01 2014-11-20 富士通株式会社 Biometric authentication system, biometric authentication method, and biometric authentication device
WO2017083016A1 (en) * 2015-11-11 2017-05-18 Visa International Service Association Server based biometric authentication

Family Cites Families (18)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US5872769A (en) * 1995-07-19 1999-02-16 Fujitsu Network Communications, Inc. Linked list structures for multiple levels of control in an ATM switch
JP2003016295A (en) * 2001-06-28 2003-01-17 Nec Corp Method, system and program for online shopping
WO2006055714A2 (en) * 2004-11-19 2006-05-26 Triad Biometrics, Llc Methods and systems for use in biomeiric authentication and/or identification
US7697737B2 (en) * 2005-03-25 2010-04-13 Northrop Grumman Systems Corporation Method and system for providing fingerprint enabled wireless add-on for personal identification number (PIN) accessible smartcards
EP1777641A1 (en) * 2005-10-17 2007-04-25 Saflink Corporation Biometric authentication system
US20080209226A1 (en) * 2007-02-28 2008-08-28 Microsoft Corporation User Authentication Via Biometric Hashing
FR2922396B1 (en) * 2007-10-12 2009-12-25 Compagnie Ind Et Financiere Dingenierie Ingenico BIOMETRIC AUTHENTICATION METHOD, COMPUTER PROGRAM, AUTHENTICATION SERVER, CORRESPONDING TERMINAL AND PORTABLE OBJECT
US8625785B2 (en) * 2008-05-15 2014-01-07 Qualcomm Incorporated Identity based symmetric cryptosystem using secure biometric model
US8365248B2 (en) * 2008-05-30 2013-01-29 Sharp Kabushiki Kaisha Data providing device, operation device, and data processing device
CN104781823B (en) * 2012-11-16 2018-08-10 皇家飞利浦有限公司 Biometric system with body coupled communication interface
US20170055146A1 (en) * 2015-08-19 2017-02-23 Hajoon Ko User authentication and/or online payment using near wireless communication with a host computer
EP4354311A3 (en) * 2015-10-17 2024-05-22 Banqu, Inc. Blockchain-based identity and transaction platform
US10587609B2 (en) * 2016-03-04 2020-03-10 ShoCard, Inc. Method and system for authenticated login using static or dynamic codes
CN105868970B (en) * 2016-03-25 2020-01-31 联想(北京)有限公司 authentication method and electronic equipment
US10425408B2 (en) * 2016-09-07 2019-09-24 Bank Of America Corporation Encrypted biometric authenication
US10484178B2 (en) * 2016-10-26 2019-11-19 Black Gold Coin, Inc. Systems and methods for providing a universal decentralized solution for verification of users with cross-verification features
WO2018089098A1 (en) * 2016-11-08 2018-05-17 Aware, Inc. Decentralized biometric identity authentication
US10560476B2 (en) * 2017-02-22 2020-02-11 International Business Machines Corporation Secure data storage system

Patent Citations (6)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
JP2011257818A (en) * 2010-06-07 2011-12-22 Hitachi Information & Control Solutions Ltd Bio-information lending system, and bio-information lending method
WO2012124115A1 (en) * 2011-03-17 2012-09-20 富士通株式会社 Biological information acquisition device, biological information comparison device, and program
US8752146B1 (en) * 2012-03-29 2014-06-10 Emc Corporation Providing authentication codes which include token codes and biometric factors
US20130318359A1 (en) * 2012-05-22 2013-11-28 Partnet, Inc. Systems and methods for verifying uniqueness in anonymous authentication
JP2014219711A (en) * 2013-05-01 2014-11-20 富士通株式会社 Biometric authentication system, biometric authentication method, and biometric authentication device
WO2017083016A1 (en) * 2015-11-11 2017-05-18 Visa International Service Association Server based biometric authentication

Cited By (24)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US11847199B2 (en) 2016-08-23 2023-12-19 Visa International Service Association Remote usage of locally stored biometric authentication data
US11308189B2 (en) 2016-08-23 2022-04-19 Visa International Service Association Remote usage of locally stored biometric authentication data
US11823194B2 (en) * 2018-01-27 2023-11-21 Redrock Biometrics, Inc. Decentralized biometric authentication platform
US11250161B2 (en) 2018-12-14 2022-02-15 Mastercard International Incorporated Systems, methods, and non-transitory computer-readable media for secure individual identification
US11907404B2 (en) 2018-12-14 2024-02-20 Mastercard International Incorporated Systems, methods, and non-transitory computer-readable media for secure individual identification
US11803662B2 (en) 2018-12-14 2023-10-31 Mastercard International Incorprated Systems, methods, and non-transitory computer-readable media for secure individual identification
US20220129585A1 (en) 2018-12-14 2022-04-28 Mastercard International Incorporated Systems, methods, and non-transitory computer-readable media for secure individual identification
WO2020123192A1 (en) * 2018-12-14 2020-06-18 Mastercard International Incorporated Systems, methods, and non-transitory computer-readable media for secure individual identification
CN113226864A (en) * 2018-12-19 2021-08-06 戴姆勒股份公司 Processing system
US12047509B2 (en) 2018-12-19 2024-07-23 Mercedes-Benz Group AG Processing system using a block-chain for authorizing a user of a building or vehicle
JP2022512497A (en) * 2018-12-19 2022-02-04 ダイムラー・アクチェンゲゼルシャフト Processing system
JP7144615B2 (en) 2018-12-19 2022-09-29 メルセデス・ベンツ グループ アクチェンゲゼルシャフト processing system
US11429702B2 (en) 2019-01-22 2022-08-30 Idemia Identity & Security France Method of verification of a biometric authentication
FR3091941A1 (en) * 2019-01-22 2020-07-24 Idemia Identity & Security France Biometric authentication verification process
EP3686788A1 (en) * 2019-01-22 2020-07-29 Idemia Identity & Security France Method for verifying a biometric authentication
EP3731115A1 (en) * 2019-04-26 2020-10-28 Visa International Service Association Distributed ledger data verification network
US11115420B2 (en) 2019-04-26 2021-09-07 Visa International Service Association Distributed ledger data verification network
WO2021030388A1 (en) * 2019-08-13 2021-02-18 Mastercard International Incorporated Systems and methods for use in provisioning tokens associated with digital identities
US11321445B2 (en) 2019-10-01 2022-05-03 Visa International Service Association Delegated biometric authentication
WO2021067172A1 (en) * 2019-10-01 2021-04-08 Visa International Service Association Delegated biometric authentication
EP4185976A4 (en) * 2020-07-21 2024-01-03 Royal Bank of Canada Facial recognition tokenization
WO2022016278A1 (en) 2020-07-21 2022-01-27 Royal Bank Of Canada Facial recognition tokenization
US20220121730A1 (en) * 2020-10-20 2022-04-21 Mastercard International Incorporated Digital Rights Management Platform
US11977611B2 (en) * 2020-10-20 2024-05-07 Mastercard International Incorporated Digital rights management platform

Also Published As

Publication number Publication date
EP3631664A1 (en) 2020-04-08
US11190355B2 (en) 2021-11-30
EP3631664B1 (en) 2022-04-27
CN110741369B (en) 2023-10-31
EP3631664A4 (en) 2020-05-13
CN110741369A (en) 2020-01-31
US20220052852A1 (en) 2022-02-17
US20200092102A1 (en) 2020-03-19

Similar Documents

Publication Publication Date Title
US20220052852A1 (en) Secure biometric authentication using electronic identity
US20230246842A1 (en) Compact recordation protocol
US20220058655A1 (en) Authentication system
US10484178B2 (en) Systems and methods for providing a universal decentralized solution for verification of users with cross-verification features
US10810290B2 (en) Robust method and an apparatus for authenticating a client in non-face-to-face online interactions based on a combination of live biometrics, biographical data, blockchain transactions and signed digital certificates
US10333706B2 (en) Methods and systems of providing verification of information using a centralized or distributed ledger
US20180343120A1 (en) Systems and methods for providing a universal decentralized solution for verification of users with cross-verification features
EP3132564B1 (en) Identity verification system and associated methods
JP7083892B2 (en) Mobile authentication interoperability of digital certificates
AU2003212617B2 (en) A biometric authentication system and method
US12074973B2 (en) Digital notarization using a biometric identification service
EP3721578A1 (en) Methods and systems for recovering data using dynamic passwords
US20130226813A1 (en) Cyberspace Identification Trust Authority (CITA) System and Method
CN113892099A (en) Information processing apparatus, information processing method, and computer program
US10523654B1 (en) System and method to integrate secure and privacy-preserving biometrics with identification, authentication, and online credential systems
CN112785410A (en) Relying party risk adjustment indicator systems and methods
WO2019209286A1 (en) Systems and methods for providing a universal decentralized solution for verification of users with cross-verification features
US20200204377A1 (en) Digital notarization station that uses a biometric identification service
US20240346501A1 (en) Pseudonymous persona code-based age verification token generation
US20230336523A1 (en) Domain name registration based on verification of entities of reserved names
CN118300807A (en) Electronic seal system for accessing digital mailbox and method for accessing digital mailbox

Legal Events

Date Code Title Description
121 Ep: the epo has been informed by wipo that ep was designated in this application

Ref document number: 17911928

Country of ref document: EP

Kind code of ref document: A1

NENP Non-entry into the national phase

Ref country code: DE

ENP Entry into the national phase

Ref document number: 2017911928

Country of ref document: EP

Effective date: 20200102