SYSTEMS AND METHODS FOR VERIFIED MESSAGING VIA SHORT-RANGE TRANSCEIVER
Systems and methods for verified messaging through the interaction involving a short-range transceiver, such as a contactless card, a client device and a server are presented. Verified messaging may be provided in the context of using a client device to receive a user identifier from the user's short-range transceiver, such as a contactless card, and sending a messaging request with the user identifier to a server, which may look up client device information and compare with data about the client device accompanying the request. Matching received client device information to stored client device data based on a user identifier obtained from a short-range transceiver provides an enhanced ability to verify that the client device corresponds to the user associated with the short-range transceiver.
The present disclosure relates generally to verified messaging and, more specifically, to exemplary systems and methods for establishing a verified message session through the interaction of the short-range transceiver, a client device and a server.
BACKGROUNDThe development of mobile communications has led to the convenience of consumers and businesses alike. Electronic messaging and other communications may be conducted between and among parties from virtually any location and at any time. Electronic commerce has developed in large part based upon the ability to communicate remotely over networks, as consumers may engage in purchase transactions, or conduct other business, merely by providing credentials electronically such as name and credit or debit card information.
But the use of electronic messaging and other electronic communication techniques presents risks to privacy and security. When parties are remotely located, it is more difficult to verify a user's identity or to verify that the device used for communication corresponds to a device registered with the user. For example, messaging using the short message service (SMS) protocol is not secure; communications conducted via SMS channels may be subject to spoofing in which a malevolent party may manipulate address information in order to impersonate another user or business entity. In such a case, if a user sends confidential information or credentials over the SMS channel, the information or credentials could be compromised or stolen.
These and other deficiencies exist. Thus, it may be beneficial to provide exemplary systems and methods which allow for establishing a verified message session, to overcome at least some of the deficiencies described herein.
SUMMARYAspects of the disclosed technology include systems and methods for establishing a verified message session through the interaction involving a user's short-range transceiver, such as a contactless card, a client device and a server. Verified messaging may be provided in the context of using a client device to receive a user identifier and server address from the user's short-range transceiver, such as a contactless card, and sending a messaging request with the user identifier to a server, which may look up client device information and compare with data about the client device accompanying the request. Matching received client device information to stored client device data based on a user identifier obtained from a short-range transceiver, such as a contactless card, provides an enhanced ability to verify that the client device corresponds to the user associated with the short-range transceiver. Security for the user is further enhanced by having a short-range transceiver, such as a contactless card, provided by a trusted service provider which supplies the server address for the verified messaging service.
Embodiments of the present disclosure provide a system for verified messaging, comprising: a database storing user information for a plurality of users, the user information including, for each user, a user identifier and a client device address; a server configured to communicate over a network with a client device, the client device associated with a user; a contactless card associated with the user, the contactless card configured for data communication via a short-range communication field of the client device, the contactless card comprising a processor and a memory, the memory storing data and an applet, wherein the applet is configured to provide a uniform resource identifier (URI) after entry by the contactless card into the short-range communication field of the client device, and wherein the URI comprises a message destination address and a message payload, the message destination address associated with the server; and a processor in data communication with the server and the database, the processor configured to: receive a message session request from the client device, the request including the message payload; determine, based on the message payload, a user identifier corresponding to the user; identify a client device address associated with the user; determine whether the client device address associated with the user corresponds to a source address accompanying the request; and send a response message to the client device, the response message addressed to the client device address.
Embodiments of the present disclosure provide a method for establishing a verified message session, comprising: receiving from a mobile device, via a network, a request to establish a verified message session, the request generated in response to entry by a contactless card into a short-range communication field of the mobile device, the request accompanied by a message payload read from the contactless card, wherein the mobile device and the contactless card are associated with a user; determining, based on the message payload, a user identifier corresponding to the user; identifying a mobile device number associated with the user; establishing a verified message session in response to the request; and transmitting a first message to the mobile device via the mobile device number.
Embodiments of the present disclosure provide a method for verified SMS messaging, comprising: establishing a database storing user information for a plurality of users, the user information including, for each user, a user identifier and a mobile device number; providing a contactless card configured for data communication via a near field communication (NFC) field of a mobile device, the contactless card comprising a processor and a memory, the memory storing data and an applet, wherein the applet is configured to provide a short message service (SMS) uniform resource identifier (URI) after entry by the contactless card into the NFC field of the mobile device, and wherein the URI comprises a short message service (SMS) destination address and a message payload, the SMS destination address associated with the server; receiving from the mobile device, via a network, a request to establish a verified SMS message session, the request generated in response to entry by the contactless card into the NFC field of the mobile device, the request accompanied by a message payload read from the contactless card; determining, based on the message payload, a user identifier corresponding to the user; obtaining from the database a mobile device number associated with the user; determining whether the mobile device number associated with the user corresponds to a caller identification number accompanying the request; establishing a verified SMS message session in response to the request; and transmitting a short message service (SMS) message to the mobile device via the mobile device number.
The following description of embodiments provides non-limiting representative examples referencing numerals to particularly describe features and teachings of different aspects of the invention. The embodiments described should be recognized as capable of implementation separately, or in combination, with other embodiments from the description of the embodiments. A person of ordinary skill in the art reviewing the description of embodiments should be able to learn and understand the different described aspects of the invention. The description of embodiments should facilitate understanding of the invention to such an extent that other implementations, not specifically covered but within the knowledge of a person of skill in the art having read the description of embodiments, would be understood to be consistent with an application of the invention.
Exemplary embodiments of the disclosed systems and methods provide for establishing a verified message session through the interaction involving a user's short-range transceiver, such as a contactless card, a client device and a server. Verified messaging may be provided in the context of using a client device to send a verified messaging request, along with a user identifier obtained from the user's short-range transceiver, to a server, which may look up client device information and compare with data about the client device accompanying the request. Benefits of the disclosed technology may include improved messaging and security, and improved user experience, due to an enhanced ability to verify that the client device corresponds to the user associated with the short-range transceiver via matching received client device information to stored client device data, and due to having a short-range transceiver provided by a trusted service provider which supplies the server address for the verified messaging service.
System 100 may include one or more client devices, such as client device 101, which may each be a network-enabled computer. As referred to herein, a network-enabled computer may include, but is not limited to a computer device, or communications device including, e.g., a server, a network appliance, a personal computer, a workstation, a phone, a handheld PC, a personal digital assistant, a thin client, a fat client, an Internet browser, or other device. Client device 101 also may be a mobile device; for example, a mobile device may include an iPhone, iPod, iPad from Apple® or any other mobile device running Apple's iOS® operating system, any device running Microsoft's Windows® Mobile operating system, any device running Google's Android® operating system, and/or any other smartphone, tablet, or like wearable mobile device. Client device 101 may be capable of handling short message service (SMS) messages, such as text messages (e.g., via a standard SMS messaging application). Many mobile phone devices include a standard SMS messaging application as part of the mobile phone operating system. Additional features that may be included in a client device, such as client device 101, are further described below with reference to
System 100 may include one or more short-range transceivers, such as short-range transceiver 105. Short-range transceiver 105 may be in wireless communication with a client device, such as client device 101, within a short-range communications field such as, for example, near field communication (NFC). Short-range transceiver 105 may include, for example, a contactless card, a smart card, or may include a device with a varying form factor such as a fob, pendant or other device configured to communicate within a short-range communications field. In other embodiments, short-range transceiver 105 may be the same or similar as client device 101. Additional features that may be included in a short-range transceiver, such as such as short-range transceiver 105, are further described below with reference to
As described further below (e.g., with reference to
System 100 may include one or more servers 110. In some example embodiments, server 110 may include one or more processors (such as, e.g., a microprocessor) which are coupled to memory. Server 110 may be configured as a central system, server or platform to control and call various data at different times to execute a plurality of workflow actions. Server 110 may be a dedicated server computer, such as bladed servers, or may be personal computers, laptop computers, notebook computers, palm top computers, network computers, mobile devices, or any processor-controlled device capable of supporting the system 100.
Server 110 may be configured for data communication (such as, e.g., via a connection) with one or more processors, such as processor 120. In some example embodiments, server 110 may incorporate processor 120. In some example embodiments, server 110 may be physically separate and/or remote from processor 120. Processor 120 may be configured to serve as a back-end processor. Processor 120 may be configured for data communication (such as, e.g., via a connection) with database 130 and/or server 110. Processor 120 may include one or more processing devices such as a microprocessor, RISC processor, ASIC, etc., along with associated processing circuitry. Processor 120 may include, or be connected to, memory storing executable instructions and/or data. Processor 120 may communicate, send or receive messages, requests, notifications, data, etc. to/from other devices, such as client devices 101 and/or 103, via server 110.
Server 110 may be configured for data communication (such as, e.g., via a connection) with one or more databases, such as database 130. Database 130 may be a relational or non-relational database, or a combination of more than one database. In some example embodiments, server 110 may incorporate database 130. In some example embodiments, database 130 may be physically separate and/or remote from server 110, located in another server, on a cloud-based platform, or in any storage device that is in data communication with server 110.
Connections between server 110, processor 120 and database 130 may be made via any communications line, link or network, or combination thereof, wired and/or wireless, suitable for communicating between these components. Such network may include network 115 and/or one or more networks of same or similar type as those described herein with reference to network 115. In some example embodiments, connections between server 110, processor 120 and database 130 may include a corporate LAN.
Server 110 and/or database 130 may include user login credentials used to control access to user accounts. The login credentials may include, without limitation, user names, passwords, access codes, security questions, swipe patterns, image recognition, identification scans (e.g., driver's license scan and passport scan), device registrations, telephone numbers, email addresses, social media account access information, and biometric identification (e.g., voice recognition, fingerprint scans, retina scans, and facial scans).
Database 130 may contain data relating to one or more users and one or more accounts. Data relating to a user may include one or more user identifiers (which may include one or more card identifiers), one or more client device addresses, and one or more user keys, and may be maintained or organized in one or more accounts. A client device address may include, e.g., a mobile phone number, an IP address or any other unique address for the client device. Accounts may be maintained by (or on behalf of) and/or relate to any one or more of a variety of entities, such as, for example (and without limitation) a bank, merchant, online retailer, service provider, merchandizer, manufacturer, social media provider, provider or promoter of sporting or entertainment events, or hotel chain. For example, database 130 may include, without limitation, account identification information (e.g., account number, account owner identification number, account owner name and contact information—any one or more of which may comprise an account identifier), account characteristics (e.g., type of account, funding and trading limitations, and restrictions on access and other activity), and may include information and data pertinent to the account, including financial (such as balance information, payment history, and transaction history), social and/or personal information. Data stored in database 130 may be stored in any suitable format, and may be encrypted and stored in a secure format to prevent unauthorized access. Any suitable algorithm/procedure may be used for data encryption and for authorized decryption.
Server 110 may be configured to communicate with one or more client devices, such as such as client device 101, via one or more networks, such as network 115. Network 115 may include one or more of a wireless network, a wired network or any combination of wireless network and wired network, and may be configured to connect client device 101 to server 110. For example, network 115 may include one or more of a fiber optics network, a passive optical network, a cable network, an Internet network, a satellite network, a wireless local area network (LAN), a Global System for Mobile Communication, a Personal Communication Service, a Personal Area Network, Wireless Application Protocol, Multimedia Messaging Service, Enhanced Messaging Service, Short Message Service, Time Division Multiplexing based systems, Code Division Multiple Access based systems, D-AMPS, Wi-Fi, Fixed Wireless Data, IEEE 802.11b, 802.15.1, 802.11n and 802.11g, Bluetooth, NFC, Radio Frequency Identification (RFID), Wi-Fi, and/or the like.
In addition, network 115 may include, without limitation, telephone lines, fiber optics, IEEE Ethernet 902.3, a wide area network, a wireless personal area network, a LAN, or a global network such as the Internet. In addition, network 115 may support an Internet network, a wireless communication network, a cellular network, or the like, or any combination thereof. Network 115 may further include one network, or any number of the exemplary types of networks mentioned above, operating as a stand-alone network or in cooperation with each other. Network 115 may utilize one or more protocols of one or more network elements to which they are communicatively coupled. Network 115 may translate to or from other protocols to one or more protocols of network devices. Although network 115 is depicted as a single network, it should be appreciated that according to one or more example embodiments, network 115 may comprise a plurality of interconnected networks, such as, for example, the Internet, a service provider's network, a cable television network, corporate networks, such as credit card association networks, a LAN, and/or home networks.
In some embodiments, server 110 may be configured to communicate with one or more client devices, such as such as client device 101, via one or more networks, such as network 115, using a messaging gateway (not shown). A messaging gateway may be a standard messaging gateway such as a short message service (SMS) gateway.
In some example embodiments, server 110 may access records, including records in database 130, to determine a method or methods for communicating with client device 101. The communication method may include an actionable push notification, or other appropriate communication techniques, with an application stored on client device 101. Other communication methods may include a text message or an e-mail, or other messaging techniques appropriate in a network-based client/server configuration. Messages or requests by client device 101 may be communicated to server 110 via an application on the client device, or may be sent by a text message or an e-mail, or other messaging techniques appropriate in a network-based client/server configuration. Communications originating with client device 101 may be sent to server 110 using the same communications method as communications originating with server 110, or via a different communications method.
Short-range transceiver 105 may be associated with a user, and may be unique to the user and/or to a specific user account. Short-range transceiver 105 may include, for example, a contactless card, and may include features further described below with reference to
A token may be used to increase security through token authorization. Server 110 may send a validation request to a client device, such as client device 101, receive responsive information from the client device, and if validated, send a validation token back to the client device. The validation token may be based on a pre-determined token, or may be a dynamic token based on an algorithm that can be secret and known only to server 110 and the client device; the algorithm may include live parameters independently verifiable by the participants, such as the temperature at a particular location or the time. The token may be used to verify the identity of the user. The validation request and/or validation token may be based on token 107.
At label 150, the user may launch application 102 running on client device 101. In some embodiments, application 102 may be launched after entry of short-range transceiver 105 into a short-range communication field of client device 101, such as, e.g., in response to a tap action between short-range transceiver 105 and client device 101. For example, if short-range transceiver 105 is a contactless card and client device 101 is a mobile device, the tap action may include tapping the contactless card on a screen or other portion of client device 101. However, a tap action is not limited to a physical tap by short-range transceiver 105 against client device 101, and may include other gestures, such as, e.g., a wave or other movement of short-range transceiver 105 in the vicinity of client device 101 (or vice-versa) such that short-range transceiver 105 enters a short-range communication field of client device 101. In some embodiments, application 102 may be launched at a later time (see label 156 below). In some embodiments, application 102 may require a sign-in or login process, which may be accomplished via, e.g., entering a username and password, or scanning a biometric image such as a fingerprint scan, retina scan, facial scan, etc.
In some example embodiments, application 102 may display an instruction on client device 101 prompting the user to initiate a tap action between short-range transceiver 105 and client device 101. As used herein, a tap action may include tapping short-range transceiver 105 against client device 101 (or vice-versa). For example, if short-range transceiver 105 is a contactless card and client device 101 is a mobile device, the tap action may include tapping the contactless card on a screen or other portion of client device 101. However, a tap action is not limited to a physical tap by short-range transceiver 105 against client device 101, and may include other gestures, such as, e.g., a wave or other movement of short-range transceiver 105 in the vicinity of client device 101 (or vice-versa) such that short-range transceiver 105 enters a short-range communication field of client device 101. An action taken in response to a tap action between short-range transceiver 105 and client device 101 may include any responsive action that is initiated upon or after entry of short-range transceiver 105 into the short-range communication field of client device 101.
At label 152, there may be a first tap action between short-range transceiver 105 and client device 101. The first tap action may be in response to a prompt displayed on client device 101. The first tap action may indicate the user's desire to engage in a message session with server 110.
At label 154, client device 101 may communicate with short-range transceiver 105 (e.g., after short-range transceiver 105 is brought near client device 101). Communication between client device 101 and short-range transceiver 105 may involve short-range transceiver 105 (such as, e.g., a contactless card) being sufficiently close to a card reader (not shown) of the client device 101 to enable NFC data transfer between client device 101 and short-range transceiver 105, and may occur in response to a tap action between short-range transceiver 105 and client device 101 (such as, e.g., the tap action at label 152). The communication may include exchange of data or commands to establish a communication session between application 102 and short-range transceiver 105. The exchange of data may include transfer or exchange of one or more keys or tokens, which may be preexisting keys or generated as session keys, and/or may include token 107. In some example embodiments, the communication may occur upon entry of short-range transceiver 105 into a short-range communication field of client device 101 prior to a tap action between short-range transceiver 105 and client device 101.
At label 156, short-range transceiver 105 may transmit to client device 101 a Uniform Resource Identifier (URI) that includes a message destination and a message payload. The URI with message destination and message payload may be formatted according to the NFC Data Exchange Format (NDEF). The message destination may be a destination address for server 110, and may be stored in memory (not shown) of short-range transceiver 105. The message payload may include a user identifier. In some embodiments, the message payload may also include a request to engage in a verified message session with the server. In some embodiments, a message sent to the server at the destination address may be handled by the server as a request to engage in a verified message session with the server. In some embodiments, transmitting the URI by short-range transceiver 105 may occur in response to a tap action between short-range transceiver 105 and client device 101 (such as, e.g., the tap action at label 152). The URI may be configured for the SMS scheme, and may be of the form sms:+<address>?body=<payload>. The portion denoted <address> may be a destination number for the server to receive SMS messages, and the portion denoted <payload> may be the message payload which may include a user identifier. The <payload> portion may also include a request to engage in a verified message session with the server. Applet 106 of short-range transceiver 105 may read data from short-range transceiver 105, construct the URI and send the URI to client device 101. In some embodiments, the message payload may include token 107, which may include a user key. In some embodiments, token 107 in the message payload may include a data item, such as a counter, stored on the card, and/or a cryptogram generated by applet 106 using the card number, a key on the card and/or the data item (e.g., counter) stored on the card.
Continuing with label 156, upon receiving the URI from short-range transceiver 105, client device 101 may launch, or make active, application 102, which may be a standard messaging application such as, e.g., a standard SMS messaging application. Client device 101 may use the destination address in the URI to address the message via the messaging application, and may use the message payload to pass a user identifier via the messaging application to the destination. In the example of an SMS-styled URI, client device 101 may use the destination address (<address> portion in the preceding example) to address an SMS-compatible message, using the SMS messaging application, to a telephone number corresponding to a destination server, such as server 110; client device 101 may use the message payload (<payload> portion in the preceding example) to pre-populate the SMS-compatible message with the contents of the payload, such as the user identifier and any additional characters or code to serve as a message session request.
At label 158, client device 101 may transmit a message session request to server 110, addressed to the destination address via application 102. In some embodiments, the message session request may be transmitted to server 110 automatically; in some embodiments, the message session request may be transmitted to server 110 after further user interaction, such as, e.g., pressing or selecting a “send” button or icon. The message session request may include (or otherwise be accompanied by) the message payload received from short-range transceiver 105 (label 156). In the example of an SMS-styled URI, client device 101 may send an SMS-compatible message with message payload (described above with reference to label 156), via application 102, to a telephone number corresponding to server 110. In some embodiments, the message payload may include a request to engage in a verified message session; in some embodiments, the transmission of the message to server 110 is itself the message session request, and is treated as such by the receiving server 110. In some embodiments, the message payload may include a cryptogram generated by applet 106 using the card number, a key on the card and/or a counter stored on the card.
In some embodiments, the message session request may include the URI in addition to the message payload. The inclusion of the URI along with the message payload may facilitate verification of the user by the server 110. The user can be verified and a telephone number associated with the user can be looked up and confirmed by the server 110 using one or more accessible databases, and the SMS message may be initiated using the confirmed phone number. The verification and use of a confirmed phone number may provide increased security.
At label 160, processor 120 may obtain a user identifier from the message session request received by server 110 from client device 101. The user identifier may be obtained from the message payload contained in or otherwise accompanying the message session request. In some embodiments, the message session request may be for an SMS message session, and the user identifier may be obtained from the body of the SMS message from client device 101.
At label 162, processor 120 may obtain a client device address corresponding to the user as identified by the user identifier. The client device address may be obtained from data stored in database 130, and may be obtained based on a database lookup using the user identifier. As discussed above, the client device address may comprise a mobile phone number, an IP address or any other unique address corresponding to client device 101.
At label 164, processor 120 may obtain a source address representing the address of the client device 101 that sent the message session request. The source address may be obtained from data, such as metadata, included in or otherwise accompanying the message session request. For example, in the case of an SMS message session request where the request as received may be in the form of an SMS message sent by a mobile phone, the source address may be obtained from caller ID data accompanying the SMS message session request, and may be in the form of a mobile phone number for the sending device.
At label 166, processor 120 may compare the source address with the client device address (label 162) to determine if they correspond to the same client device 101. If the source address and the client device address correspond to the same client device 101, the client device 101 may be deemed verified. In some embodiments, in the case of an SMS message session request where the request as received may be in the form of an SMS message sent by a mobile phone, processor 120 may compare the mobile phone number from the caller ID (label 164) with the mobile phone number obtained from the database lookup based on the user identifier (label 162), and the client device may be verified if these mobile phone numbers match.
In some embodiments, at label 168, if the message payload includes a user key associated with the user (as described above), processor 120 may use the user key to authenticate the user as the user associated with client device 101 and/or short-range transceiver 105. Database 130 may store a copy of the user key, or a key associated with the user that may be used to generate a copy of the user key. Generating a copy of the user key based on the key associated with the user may include using a counter or other data derived or otherwise maintained in synchronization between processor 120, client device 101 and/or short-range transceiver 105.
At label 170, based on the results of the device verification (label 166) and any authentication process (label 168), processor 120 may send a response message to application 102 (via client device 101) confirming that the user's request is accepted and initiating the message session with the user. The response message may be in a form compatible with application 102. In some embodiments, the response message may be routed by the server to a messaging gateway, which may be a standard messaging gateway such as a short message service (SMS) gateway, for delivery to client device 101.
In some embodiments, processor 120 may instead send a denial notification (not shown) to application 102 (via client device 101), indicating that the user's request to engage in a message session with the server has been denied. A denial notification may include, or be accompanied by, additional data that may indicate a reason for the denial (such as, e.g., a failure to verify the client device or failure to authenticate the user). In some embodiments, in case of a denial, a first denial notification may be sent to the client device address (label 162) and a second denial notification may be sent to the source address (label 164).
At label 172, the user may use application 102 (via client device 101) to engage in a message session with server 110 via an application executing on the server, which may include, e.g., a messaging or chat application, a messaging or chat bot, AI (artificial intelligence) bot, etc. During the message session, the user, using application 102, and the server may exchange text or data, such as, e.g., providing questions and answers. The message session may involve the exchange of data or information in any form compatible with application 102 (including, for example multimedia data if application 102 supports exchange of multimedia data, such as via MMS messaging). In some embodiments, as part of the message session the server may provide menu options for the user to select.
In some embodiments, the message session may be of a limited duration. The server may establish that the message session is limited to a predetermined period of time (such as, e.g., 5 minutes, 10 minutes, 30 minutes, etc.). In some embodiments, the server may label the message session as a secure message session. In some embodiments, the server may encrypt/decrypt data or information as part of the message session, and may transmit encrypted information to application 102 so long as application 102 supports encryption/decrpytion.
At label 174, there may be a second tap action between short-range transceiver 105 and client device 101. The second tap action may be in response to a prompt displayed on client device 101. The second tap action may indicate the user's desire to terminate the message session with server 110. In some embodiments, the second tap action may indicate the user's desire to maintain the message session with server 110.
At label 176, client device 101 may transmit a message session end request to server 110. Transmission of the message session end request may occur in response to a tap action between short-range transceiver 105 and client device 101 (such as, e.g., the second tap action at label 174). In some embodiments, transmission of the message session end request may occur as the result of a user entry (such as, e.g., entering the text “GOODBYE,” “END” or the like in application 102 and pressing send).
At label 178, processor 120 may terminate the message session and may transmit a session end (termination) message to client device 101. Termination of the message session may occur in response to a session end (termination) request received from client device 101. In some embodiments, termination of the message session may occur after a period of time has passed without any messages or other input received from client device 101. In some embodiments, the period of time may be a first predetermined period of time (such as, e.g., 2 minutes, 5 minutes, or 15 minutes).
In some embodiments, processor 120 may send a warning message (not shown) to client device 101 alerting the user that the message session may be terminated unless a response is received from client device 101 within a period of time, which may be a second predetermined period of time (such as, e.g., 15 seconds, 30 second, 60 seconds, 90 seconds) In some embodiments, the user may respond by tapping short-range transceiver 105 together with client device 101 to indicate a desire to maintain the message session. In some embodiments, a tap action between client device 101 and short-range transceiver 105 may re-initiate the verification and authentication processes described above.
Processor 202 may include one or more processing devices such as a microprocessor, RISC processor, ASIC, etc., and may include associated processing circuitry. Processor 202 may include, or be connected to, memory storing executable instructions and/or data, as may be necessary or appropriate to control, operate or interface with the other features of client device 200, including application 201. Processor 202 (including any associated processing circuitry) may contain additional components including processors, memories, error and parity/CRC checkers, data encoders, anticollision algorithms, controllers, command decoders, security primitives and tamperproofing hardware, as necessary to perform the functions described herein.
Short-range communications interface 203 may support communication via a short-range wireless communication field, such as NFC, RFID, or Bluetooth. Short-range communications interface 203 may include a reader, such as a mobile device NFC reader. Short-range communications interface 203 may be incorporated into network interface 204, or may be provided as a separate interface.
Network interface 204 may include wired or wireless data communication capability. These capabilities may support data communication with a wired or wireless communication network, including the Internet, a cellular network, a wide area network, a local area network, a wireless personal area network, a wide body area network, a WiFi network, any other wired or wireless network for transmitting and receiving a data signal, or any combination thereof. Such network may include, without limitation, telephone lines, fiber optics, IEEE Ethernet 902.3, a wide area network, a local area network, a wireless personal area network, a wide body area network or a global network such as the Internet.
Client device 200 may also include a display (not shown). Such display may be any type of device for presenting visual information such as a computer monitor, a flat panel display, or a mobile device screen, including liquid crystal displays, light-emitting diode displays, plasma panels, and cathode ray tube displays.
Client device 200 may also include one or more device inputs (not shown). Such inputs may include any device for entering information into the client device that is available and supported by the client device 200, such as a touch-screen, keyboard, mouse, cursor-control device, touch-screen, microphone, digital camera, video recorder, or camcorder. The device inputs may be used to enter information and interact with the client device 200 and, by extension, with the systems described herein.
Processor 301 may include one or more processing devices such as a microprocessor, RISC processor, ASIC, etc., and may include associated processing circuitry. Processor 301 may include, or be connected to, memory storing executable instructions (such as, e.g., applet 303) and/or data, as may be necessary or appropriate to control, operate or interface with the other features of short-range transceiver 300. Processor 301 (including any associated processing circuitry) may contain additional components including processors, memories, error and parity/CRC checkers, data encoders, anticollision algorithms, controllers, command decoders, security primitives and tamperproofing hardware, as necessary to perform the functions described herein.
Memory 302 may be a read-only memory, write-once read-multiple memory and/or read/write memory, e.g., RAM, ROM, and EEPROM. Memory 302 may be configured to store applets 303 and one or more tokens 305. Applet 303 may comprise one or more software applications configured to execute on processor 301, such as a Java Card applet that may be executable on a contactless card. However, it is understood that applet 303 is not limited to a Java Card applet, and instead may be any software application operable on contactless cards or other devices having limited memory. Applet 303 may be configured to respond to one or more requests (such as near field data exchange requests) from a client device, including requests from a device having a reader such as a mobile device NFC reader. Applet 303 may be configured to read (or write) data, including token 305, from (or to) memory 302 and provide such data in response to a request. Applet 303 may be configured to respond to NDEF read commands and provide data according to the NDEF format.
Token 305 may include a unique alphanumeric identifier assigned to a user of the short-range transceiver 300, and the identifier may distinguish the user of the short-range transceiver 300 from other users of other short-range transceivers (such as other contactless card users). In some example embodiments, token 305 may identify both a user and an account assigned to that user and may further identify the short-range transceiver (such as a contactless card) associated with the user's account. In some example embodiments, token 305 may include, or be generated from, a key unique to the user with which the short-range transceiver is associated.
Short-range communications interface 306 may support communication via a short-range wireless communication field, such as NFC, RFID, or Bluetooth. Short-range transceiver 300 may also include one or more antennas (not shown) connected to short-range communications interface 306 to provide connectivity with a short-range wireless communications field.
At block 410, a first tap action may be detected between short-range transceiver 105 and client device 101. The tap action may be in response to a prompt displayed on client device 101. The first tap action may indicate the user's desire to engage in a message session with server 110. As described above, short-range transceiver 105 may be a contactless card.
At block 420, a Uniform Resource Identifier (URI) including a message destination and a message payload, as described above with reference to
At block 430, application 102 of client device 101 may send to server 110 a message session request, as described above with reference to
At block 440, application 102 may receive a message session response from server 110, as described above with reference to
At block 450, the user may, via application 102, engage in a message session with server 110 via an application executing on the server, which may include, e.g., a messaging or chat application, a messaging or chat bot, AI bot, etc., as described above with reference to
At block 460, a second tap action may be detected between short-range transceiver 105 and client device 101. The tap action may be in response to a prompt displayed on client device 101. The second tap action may indicate the user's desire to terminate the message session with server 110.
At block 470, application 102 of client device 101 may send to server 110 a message session termination request, as described above with reference to
At block 480, a message session termination response may be received from server 110, as described above with reference to
At block 510, a message session request may be received from the user's client device 101, as described above with reference to
At block 520, a user identifier may be obtained from the received message session request. The user identifier may be obtained from the message payload contained in or otherwise accompanying the message session request. In some embodiments, the message session request may be for an SMS message session, and the user identifier may be obtained from the body of the received SMS message.
At block 530 a client device address corresponding to the user as identified by the user identifier may be obtained. The client device address may be obtained from data stored in database 130, and may be obtained based on a database lookup using the user identifier. As discussed above, the client device address may comprise a mobile phone number, an IP address or any other unique address corresponding to client device 101.
At block 540, a source address representing the address of the client device 101 that sent the message session request may be obtained, as described above with reference
At block 550, a verification process may be carried out, as described above with reference to
At block 560, based on positive results of the verification process (block 550), a message session response may be sent to client device 101, as described above with reference to
At block 570, server 110 may, via an application executing on the server (which may include, e.g., a messaging or chat application, a messaging or chat bot, AI bot, etc.), engage in a message session with the user via application 102 executing on client device 101, as described above with reference to
At block 580, a message session termination request may be received from client device 101, as described above with reference to
At block 590, the message session with the user may be terminated, as described above with reference to
At block 552, it may be determined that a user token is present in the message payload received from client device 101; the user token may be based on a user key.
At block 555, the user may be authenticated based on a user key obtained from the user token. As described above with reference to label 168 (
At block 565, based on positive results of the verification process (block 550) and positive results of the authentication process (block 555), a message session response may be sent to client device 101, as described above with reference to
Method 501 then proceeds to the activities of blocks 570-590 as described above with reference to
The description of embodiments in this disclosure provides non-limiting representative examples referencing figures and numerals to particularly describe features and teachings of different aspects of the disclosure. The embodiments described should be recognized as capable of implementation separately, or in combination, with other embodiments from the description of the embodiments. A person of ordinary skill in the art reviewing the description of embodiments should be able to learn and understand the different described aspects of the disclosure. The description of embodiments should facilitate understanding of the disclosure to such an extent that other implementations, not specifically covered but within the knowledge of a person of skill in the art having read the description of embodiments, would be understood to be consistent with an application of the disclosure
Throughout the specification and the claims, the following terms take at least the meanings explicitly associated herein, unless the context clearly dictates otherwise. The term “or” is intended to mean an inclusive “or.” Further, the terms “a,” “an,” and “the” are intended to mean one or more unless specified otherwise or clear from the context to be directed to a singular form.
In this description, numerous specific details have been set forth. It is to be understood, however, that implementations of the disclosed technology may be practiced without these specific details. In other instances, well-known methods, structures and techniques have not been shown in detail in order not to obscure an understanding of this description. References to “some examples,” “other examples,” “one example,” “an example,” “various examples,” “one embodiment,” “an embodiment,” “some embodiments,” “example embodiment,” “various embodiments,” “one implementation,” “an implementation,” “example implementation,” “various implementations,” “some implementations,” etc., indicate that the implementation(s) of the disclosed technology so described may include a particular feature, structure, or characteristic, but not every implementation necessarily includes the particular feature, structure, or characteristic. Further, repeated use of the phrases “in one example,” “in one embodiment,” or “in one implementation” does not necessarily refer to the same example, embodiment, or implementation, although it may.
As used herein, unless otherwise specified the use of the ordinal adjectives “first,” “second,” “third,” etc., to describe a common object, merely indicate that different instances of like objects are being referred to, and are not intended to imply that the objects so described must be in a given sequence, either temporally, spatially, in ranking, or in any other manner.
While certain implementations of the disclosed technology have been described in connection with what is presently considered to be the most practical and various implementations, it is to be understood that the disclosed technology is not to be limited to the disclosed implementations, but on the contrary, is intended to cover various modifications and equivalent arrangements included within the scope of the appended claims. Although specific terms are employed herein, they are used in a generic and descriptive sense only and not for purposes of limitation.
This written description uses examples to disclose certain implementations of the disclosed technology, including the best mode, and also to enable any person skilled in the art to practice certain implementations of the disclosed technology, including making and using any devices or systems and performing any incorporated methods. The patentable scope of certain implementations of the disclosed technology is defined in the claims, and may include other examples that occur to those skilled in the art. Such other examples are intended to be within the scope of the claims if they have structural elements that do not differ from the literal language of the claims, or if they include equivalent structural elements with insubstantial differences from the literal language of the claims.
Claims
1-30. (canceled)
31. A method for verified messaging, comprising:
- receiving, by a server, a message session request from a client device associated with a user, the message session request including a message payload;
- determining, by the server based on the message payload, a user identifier corresponding to a user, wherein the server is in data communication with a database storing user information for a plurality of users, the user information including, for each of the plurality of users, a user identifier and a client device address;
- identifying, by the server, a client device address for the user;
- determining, by the server, whether the client device address for the user corresponds to a source address accompanying the message session request; and
- sending, by the server, a response message to the client device, the response message addressed to the client device address.
32. The method of claim 31, wherein the response message is a short message service (SMS) message.
33. The method of claim 32, wherein the server is configured for data communication with an SMS gateway, and the response message is routed by the server to the SMS gateway.
34. The method of claim 31, wherein the message payload includes a token associated with the user.
35. The method of claim 34, further comprising authenticating, by the server, the user based on a user key obtained from the token.
36. The method of claim 31, further comprising:
- providing, by a card applet of a contactless card associated with the user after entry of the contactless card into a communication field of the client device, a uniform resource identifier (URI) into the short-range communication field of the client device,
- wherein the URI comprises a message destination address of the server and the message payload.
37. The method of claim 36, wherein the message payload includes a data item from the contactless card.
38. The method of claim 37, wherein the data item includes at least one selected from the group of a counter and a cryptogram generated using the counter.
39. The method of claim 36, wherein the message payload includes a token associated with the user.
40. The method of claim 36, wherein the message payload includes a request to engage in a verified message session.
41. The method of claim 39, wherein the message session request comprises a short message service (SMS) message.
42. A system for verified messaging, comprising:
- a server in data communication with a client device associated with a user and a database storing user information for a plurality of users, the user information including, for each of the plurality of users, a user identifier and a client device address,
- wherein the server: receives a message session request from the client device, the message session request including a message payload, determines, based on the message payload, the user identifier, identifying a client device address for the user, determining whether the client device address for the user corresponds to a source address accompanying the message session request, and sending a response message to the client device, the response message addressed to the client device address.
43. The system of claim 42, wherein the client device address comprises a mobile phone number.
44. The system of claim 41, further comprising
- a contactless card associated with the user, wherein: the contactless card is configured for data communication via a short-range communication field of the client device, the contactless card comprises at least one card processor and at least one card memory, the at least one card memory stores data and a card applet, and after entry by the contactless card into the short-range communication field of the client device, the card applet provides a uniform resource identifier (URI).
45. The system of claim 44, wherein the URI comprises a message destination address of the server and a message payload.
46. The system of claim 45, wherein the message payload includes a user key and a cryptogram.
47. The system of claim 46, wherein:
- the card memory further includes a card number and a counter, and
- the cryptogram is generated using the user key, the card number, and the counter.
48. A method for verified messaging, comprising:
- providing, by an applet of a contactless card for a user after entry of the contactless card into a communication field of a client device belonging to a user, the contactless card comprising at least one card processor and a card memory storing data and the card applet, a uniform resource identifier (URI) into the short-range communication field of the client device, the URI comprising a message destination address of a server and a message payload;
- receiving, by the server, a message session request from the client device, the message session request including the message payload;
- determining, by the server based on the message payload, a user identifier corresponding to the user;
- identifying, by the server, a client device address for the user;
- determining, by the server, whether the client device address for the user corresponds to a source address accompanying the message session request; and
- sending, by the server, a response message to the client device, the response message addressed to the client device address.
49. The method of claim 48, wherein the message payload includes a user key and a cryptogram.
50. The method of claim 49, wherein:
- the card memory further stores a card number, and
- the cryptogram is generated using the user key and the card number.
Type: Application
Filed: May 19, 2023
Publication Date: Sep 14, 2023
Inventors: Jeffrey RULE (Chevy Chase, MD), Kevin OSBORN (Newton Highlands)
Application Number: 18/199,724