Field
The present invention relates generally to systems, methods, and computer program products for securely managing data on a secure element.
Related Art
Applications stored and functioning on mobile devices are increasingly being used to conduct secure communications which require the transmission of highly critical data. Such applications include mobile wallet applications, which may be used to perform contactless transactions. Contactless transactions may be financial (e.g., payments, commerce) or non-financial (e.g., venue admissions, transit ticketing). These secure communications, including contactless transactions, typically involve the exchange of critical data between mobile devices and other systems such as reader terminals using, for example, near field communication (NFC) technology.
Mobile devices include, or have stored on the mobile device memory, applications used to initiate contactless transactions, as well as those applications' corresponding non-critical data. On the other hand, the applications' critical data (e.g., personal data, security keys, passcodes, identifiers) is stored in a secure element (SE) associated with the mobile device. Secure elements are highly tamper resistant components which securely store data in accordance with specific security requirements. Because of their specialized security mechanisms, secure element storage is more costly than typical memory (e.g., mobile device memory) and thus, storage on secure elements is often exclusively limited to critical data.
Critical data is managed by corresponding applets on the secure element which control, for example, how the data is stored, when the data can be distributed, and which devices, applets and applications can access (e.g., read, write) the data. The applets which manage critical data on secure elements may need, or choose to be, altered or deleted, for example, to update out-of-date or unsupported applet versions or to repair corrupted applet versions. Such alteration or deletion of applets that manage critical data may cause those applets' corresponding critical data to be deleted or be left unmanaged on the secure element during periods in which those managing applets are not yet installed, updated or activated. Deletion of critical data may result in the need for that critical data to be requested and acquired from its source, or worse, that critical data may be lost.
Given the foregoing, it would be beneficial to store critical data on secure elements in a manner which allows for managing applets to be altered (e.g., updated, deleted) without resulting in data loss or minimization of the security of the critical data.
One technical challenge involves securely storing critical data during time periods when managing applets are not fully active (e.g., pending update). Another technical challenge involves managing applets receiving the most up-to-date critical data when those managing applets become fully active (e.g., post-update).
The example embodiments presented herein meet the above-identified needs by providing systems, methods, and computer program products for securely managing data on a secure element.
In one example embodiment, a system for managing applets comprises at least one memory operable to store a first applet including first applet data and a second applet including second applet data. The system also includes a processor coupled to the at least one memory. A first request to personalize the first applet is received, over a communications network. A second request including a command requesting at least a portion of the second applet data is communicated to the second applet. At least a portion of the second applet data is communicated to the first applet. One or more values of the first applet data are replaced with one or more values of at least the portion of the second applet data.
In another example embodiment, a method for managing applets, the method includes: receiving, over a communications network, a first request to personalize a first applet; communicating a second request to a second applet, the second request including a command requesting at least a portion of second applet data; communicating at least the portion of the second applet data to the first applet; and replacing one or more values of first applet data with one or more values of at least the portion of the second applet data.
In another example embodiment, a non-transitory computer-readable medium has stored thereon sequences of instructions that, when executed by a computer processor, cause the processor to: receive, over a communications network, a first request to personalize the first applet; communicate a second request to a second applet, the second request including a command requesting at least a portion of second applet data; communicate at least the portion of the second applet data to the first applet; and replace one or more values of first applet data with one or more values of at least the portion of the second applet data.
The features and advantages of the example embodiments presented herein will become more apparent from the detailed description set forth below when taken in conjunction with the following drawings.
I. Overview
The example embodiments presented herein are directed to systems, methods and computer program products for securely managing data on a secure element, which are described herein in terms of applets and applications for conducting contactless mobile transactions (e.g., commerce and payment) in a mobile wallet environment. This description is not intended to limit the application of the example embodiments presented herein. In fact, after reading the following description, it will be apparent to one skilled in the relevant art(s) how to implement the following example embodiments for any type of applets and/or applications on mobile devices, within or outside of a mobile wallet environment.
In exemplary embodiments presented herein, a wallet companion applet (WCAp) is an applet stored on a secure element and acts as a representative of a mobile wallet application. The mobile wallet application may use the WCAp for, among other things, securely storing and managing data (e.g., critical data) in the secure element on its behalf. A secure assistant applet (ISAp) is an applet stored on the secure element and acts as a secure storage location for data of (or corresponding to) other applets including, for example, the WCAp.
The WCAp is replaced with a new WCAp (or WCAp instance). A WCAp establishes a shareable interface object (SIO) with an ISAp, over which data and communications may be exchanged. The WCAp transmits to the ISAp, over the SIO, data to be stored or backed up on behalf of the WCAp. The WCAp is deleted from the secure element, in accordance with a request received from a trusted service manager (TSM). A new WCAp package is loaded on the secure element and a new WCAp instance is created using the newly loaded WCAp package. The new WCAp (or WCAp instance) is personalized using non-critical data and/or parameters received from the TSM. The WCAp transmits a request to the ISAp to receive critical parameters stored on behalf of the WCAp that was previously deleted and/or replaced. The ISAp transmits critical parameters to the WCAp, which are, in turn, stored in or by the WCAp on the secure element. The WCAp, ISAp and SIO are explained in further detail below with reference to at least
II. System
The mobile device 101 also includes a mobile wallet application 104, which may be stored on the memory 103 of the mobile device. The mobile wallet application 104 includes instructions which, when executed by the processor 102 of the mobile device 101, cause the mobile device 101 to act as an instrument for processing contactless transactions and the like. The mobile wallet application 104 also includes (e.g., uses, operates on, is associated with) non-critical data which may be stored on the memory 103 of the mobile device 101. Non-critical data may include information used by the mobile wallet application 104 during its functionality, including images, system information, preferences, and the like. Each application (e.g., mobile wallet application 104) or entity/provider managing each application have corresponding standards that define which types of data are non-critical (as opposed to critical). The mobile wallet application 104 may also be associated with critical data, which may include codes (e.g., passcodes), credentials, security keys, identifiers, and the like. Critical data is typically stored in a secure element, such as secure element 105.
Secure element 105 may be implemented as a Universal Integrated Circuit Card (UICC), embedded SE card, secure micro digital (microSD) card, and the like. Secure element 105 may also be implemented as a virtual secure element, which can be maintained outside of the mobile device 101 on a memory accessible by the mobile device 101, including but not limited to, for example, a remote server or computer, in a cloud-based architecture, and the like. A secure element (e.g., secure element 105) is generally considered secure because it is a self-contained system, including dedicated memory, and is protected by hardware and software hardening techniques that are verified by independent testing.
The secure element 105 includes a Java Card Runtime Environment (JCRE) 106, which is a secure element card execution environment that allows applets stored therein to run, function and/or communicate, for example, by offering for use classes for input/output (I/O), messaging and cryptography. Such applets may include, for example, a wallet companion applet (WCAp) 107 and a secure assistant applet (ISAp) 108, as shown in
The WCAp 107 is an applet stored on the secure element 105 and acts as a representative of the mobile wallet application 104. The mobile wallet application 104 may use the WCAp 107 for, among other things, securely storing and managing data (e.g., critical data) in the secure element 104 on its behalf. ISAp 108 is an applet stored on the secure element 105 and acts as a secure storage location for data of (or corresponding to) other applets including, for example, WCAp 107.
In one example embodiment, the WCAp 107 maintains and/or stores a list of data (e.g., data objects, data elements) used, or which may be used, by the mobile wallet application 104. Table 1 below lists examples of data stored by the WCAp 107 and corresponding maximum data size in bytes for each data element according to an exemplary embodiment.
Integrated Circuit Card Identifier (ICCID) is a unique serial number or identifier (ID) corresponding to a subscriber identity module (SIM) or other secure element.
International Mobile Equipment Identifier (IMEI) refers to a unique number or identifier corresponding to a mobile device (e.g., mobile phone). A Mobile Equipment Identifier (MEID) or other device ID are similar unique numbers or identifiers corresponding to other types of mobile devices, such as those functioning on code division multiple access (CDMA) networks.
Wallet ID refers to a unique number or identifier corresponding to a wallet client (e.g., mobile wallet application).
Wallet Passcode refers to a unique passcode or password used to authenticate a wallet client user. The Wallet Passcode may be a 4-character code in UNICODE.
Wallet Server Key refers to an authentication key for providing authentication between a wallet client (and/or associated applets (e.g., wallet companion applet (WCAp))) and a wallet server. The Wallet Server Key may be generated, for example, in accordance with a triple data encryption algorithm (TDEA) symmetric key-block cypher or the like.
Wallet Server Key Verification Code (KVC) refers to a value for verifying or authenticating a Wallet Server Key.
Enhanced Wallet Server (WS) Key refers to a key for providing authentication between a wallet client (and/or associated applets) and a wallet server. The Enhanced WS Key may be generated, for example, in accordance with a triple data encryption algorithm (TDEA) symmetric key-block cypher or the like. Enhanced WS KVC refers to a value for verifying or authenticating an Enhanced WS Key.
Enhanced WS HMAC Key and Enhanced WK HMAC KVC refer respectively to a key and key verification code or value developed in accordance with hash message authentication code (HMAC) cryptographic functions.
SIO Authentication Secret refers to a value or code used to authenticate an applet or system requesting the establishment of a Shareable Interface Object (SIO) (e.g., JavaCard SIO). Establishment of an SIO is described in more detail below with reference to
Widget Authentication Blob refers to a set of stored data used to authenticate widgets (e.g., application, component of an interface) requesting access to applets on secure elements. For example, a Widget Authentication Blob may be used to store a widget ID, widget signature and widget version corresponding to one or more widgets. When a widget requests access to an applet on a secure element, the widgets data is compared to the data stored in the Widget Authentication Blob and access may be granted to the applet based on that comparison.
Wallet Client Unique Code refers to a value used by a wallet client for authentication during a transaction.
In one example embodiment, the ISAp 108 maintains and/or stores data for or on behalf of the WCAp 107. Such data maintained by the ISAp 108 typically includes data which is not stored other than in the WCAp 107. That is, the ISAp 108 acts as the sole backup or disaster recovery storage for the WCAp 107 within the secure element 105, thereby making that data accessible to the WCAp 107 in the event that the WCAp 107 is deleted, updated and/or modified and that data is needed and/or used to make the WCAp 107 (or another instance of a WCAp) functional.
Table 2 below lists examples of data stored by the WCAp 107 and an indication of whether that data is stored in the WCAp 107 only or in the WCAp 107 and the ISAp 108.
Applets in the secure element 105, such as WCAp 107 and ISAp 108, may communicate with or among each other to exchange information. For example, WCAp 107 may communicate with ISAp 108 to obtain and/or retrieve data that is needed for the WCAp 107 to be personalized. In one example embodiment, applets may communicate using an SIO or the like.
A. SIO Establishment and Applet Authentication
At step 250, the WCAp 201 transmits a “request SIO” command to the ISAp 202. The “request SIO” message may include an application identifier (AID) corresponding to the transmitting and/or requesting applet, i.e., WCAp 201. At step 252, the ISAp 202 checks whether the received AID corresponds to an expected and/or authorized applet and, if so, transmits a “send SIO” message to the WCAp 201, at step 254. The send SIO message may include information associated with the established SIO.
In turn, at step 256, the WCAp 201 transmits a “get challenge” command to the ISAp 202, requesting that a challenge be returned to the WCAp 201. The ISAp 202, in response to receiving the get challenge command, generates a challenge at step 258. A challenge may be a random value such as an 8-byte random number. At step 260, the ISAp 202 transmits the generated challenge to the WCAp 201.
At step 262, the WCAp 201 uses the received challenge to generate an authentication message. The authentication message may be made up of a combination of all or a portion of data available to or known by the WCAp 201 and the ISAp 202, including the challenge generated at step 258, shared authentication keys, and/or the AID of the WCAp 201. The authentication message may be generated using symmetric key algorithms such as data encryption standard (DES).
In turn, the WCAp 201 transmits to the ISAp 202, at step 264, the generated authentication message. The ISAp 202, at step 266, checks the received authentication message by (1) generating a comparison authentication message using the same data and algorithm expected to have been used by the WCAp 201 at step 262, (2) comparing the comparison authentication message to the authentication message received from the WCAp 201, and (3) determining whether the comparison authentication message and the authentication message received from the WCAp 201 match.
At step 268, the ISAp 202 transmits an authentication response to the WCAp 201. For example, if the two authentication messages are determined to be a match at step 266, the ISAp 202 transmits an authentication response indicating that access by the WCAp 201 to the ISAp 202 is granted. Otherwise, the ISAp 202 may transmit an authentication response indicating access is not granted and/or a reason for why access is not granted.
Data stored by the WCAp 107 in
Once the WCAp 107 is personalized (e.g., loaded with data), the WCAp 107 populates the ISAp 108 with data typically stored (e.g., expected) by the ISAp 108, as discussed above with reference to Table 2. That is, the WCAp 107, when personalized, may transmit data to the ISAp 108, which is operable to store or back up data on behalf of the WCAp 107.
To determine whether the ISAp 108 is populated and/or needs to be populated by the WCAp 107, the WCAp 107 may call a method (or function) such as:
public abstract void ISAaToWCApReport (byte Code)
That method (e.g., ISAaToWCApReport) allows the ISAp 108 to report to the WCAp 107 by returning a code (e.g., byte Code) indicating, for example, whether (1) the ISAp 108 is being installed with no data (i.e., ISAp 108 is empty), (2) the ISAp 108 is being deleted, or (3) data needs to be uploaded, transmitted or provided to the ISAp 108 (i.e., at least some expected data is missing from the ISAp 108).
III. Process
As discussed above with reference to
If the ISAp 302 validates the “request SIO” command received at step 350, in returns, at step 352, an SIO (including associated information) over which the WCAp 301 and the ISAp 302 may communicate. The request SIO command may include the AID of the requesting applet (e.g., WCAp 301). The ISAp 302 may validate the request SIO command by determining whether the AID included in the command matches an authorized or expected AID.
At step 354, the WCAp 301 requests a challenge by transmitting a “get challenge” command to the ISAp 302. The ISAp 302, in turn, returns a challenge to the WCAp 301 at step 356. In turn, WCAp 301 transmits an authentication message to the ISAp 302. The ISAp 302 analyzes the authentication message sent at step 356 and, if authentication is successful (e.g., authentication message matches expected value), the ISAp 302 transmits, at step 360, an authentication response to the WCAp 301 indicating that authentication passed and access to the ISAp 302 is granted.
At step 362, the WCAp 301 transmits a “put data” command (or the like) to the ISAp 302, including information which WCAp 301 would like updated and/or replenished on the ISAp 302. For example, the information in the put data command may include a passcode, WC unique code, or any other information typically stored on the ISAp 302. In turn, at step 364, the ISAp 302 transmits a response to the WCAp 301 indicating whether or not the information transmitted in the put data command was successfully added to and/or stored by the ISAp 302, as requested by the WCAp 301.
At step 380, a trusted service manager (TSM) 305 (or any system having applet management privileges for the WCAp 301) transmits a delete command to the secure element 303, to delete the WCAp 301. The delete command may include an AID corresponding to the applet to be deleted (e.g., WCAp 301). In turn, at step 382, the secure element 303 deletes the WCAp 301. Although not illustrated, the secure element 303 may transmit a notification to the TSM 305 indicating whether or not the WCAp 301 was successfully deleted. In one exemplary embodiment, the TSM 305 may transmit communications to the secure element 303 via a central security domain (not illustrated) on the secure element 303.
In turn, at step 384, the TSM 305 transmits a load command to the secure element 303. The load command includes instructions to load a WCAp package on the secure element 303. The load command may include the WCAp package to be loaded on the secure element 303. At step 386, the package is loaded on the secure element 303. Although not illustrated, the secure element 303 may transmit a notification to the TSM 305 indicating whether or not the WCAp package was successfully loaded on the secure element 303.
At step 388, the WCAp package loaded at step 384 is instantiated on the secure element 303 to create WCAp 304 on the secure element 303. Typically, instantiation includes creating an applet instance from a loaded package and, if necessary, extraditing the created applet instance to a storage area on a secure element (e.g., a corresponding security domain). At step 390, the package loaded at step 386 is used to create a new WCAp instance (i.e., WCAp 304), and that instance may be extradited to a security domain on the secure element 303. Although not illustrated, the secure element 303 may transmit a notification to the TSM 305 indicating whether or not a new WCAp instance was successfully created (and, if necessary, extradited) on the secure element 303.
Once the WCAp 304 has been created, the TSM 305 transmits, at step 392, a personalization command to the secure element 303 to personalize the WCAp 304. The personalization command may include data to be stored on or by the WCAp 304. Such data may include non-critical parameters stored by the WCAp 304, as outlined in Tables 1 and 2. Non-critical parameters are those solely stored by a WCAp and not backed up by an ISAp. In particular, the personalization command transmitted at step 392 may include, for example, ICCID, IMEI, and wallet ID. At step 394, the secure element 303 uses the data (e.g., non-critical parameters) received in the personalization command to personalize the WCAp 304, for example, by calling a StoreData command. Specifically, the data received in the personalization command is stored in, by, or in association with the WCAp 304.
In turn, at step 396, the WCAp 304 in the secure element 303 transmits a get data command or the like to an associated ISAp (e.g., ISAp 302), to retrieve critical parameters stored by the ISAp 302. Examples of critical parameters stored by an ISAp (e.g., ISAp 302) are described above with reference to Table 2. In one exemplary embodiment, the WCAp 304 may establish an SIO with and/or be authenticated by the ISAp 302 prior to the exchange of critical parameters and/or other data. Establishing an SIO and/or authenticating an ISAp (e.g., ISAp 302) is/are described above in more detail with reference to
If the ISAp 302 determines that it has stored thereon some or all of data requested by the WCAp 304 in the get data command, the ISAp 302 retrieves and transmits, at step 398, some or all of the requested data (e.g., critical parameters) to the WCAp 304. Alternatively, and although not illustrated in
In an exemplary embodiment, applets that were associated with the WCAp 301 prior to it being replaced with WCAp 304, may be unlocked and placed in a usable or active state, if they were or had been placed in a locked state. In particular, applets, if any, that were locked to prevent their functionality during the replacement of WCAp 301 may be unlocked to allow for their operability to be resumed. It should be understood that unlocking applets may be achieved in any manner as desired by an applet owner or provider.
IV. Computer Readable Medium Implementation
The example embodiments described above such as, for example, the systems and procedures depicted in or discussed in connection with
The computer 400 may include without limitation a processor device 410, a main memory 425, and an interconnect bus 405. The processor device 410 may include without limitation a single microprocessor, or may include a plurality of microprocessors for configuring the computer 400 as a multi-processor system. The main memory 425 stores, among other things, instructions and/or data for execution by the processor device 410. The main memory 425 may include banks of dynamic random access memory (DRAM), as well as cache memory.
The computer 400 may further include a mass storage device 430, peripheral device(s) 440, portable storage medium device(s) 450, input control device(s) 480, a graphics subsystem 460, and/or an output display 470. For explanatory purposes, all components in the computer 400 are shown in
The portable storage medium device 450 operates in conjunction with a nonvolatile portable storage medium, such as, for example, a compact disc read only memory (CD-ROM), to input and output data and code to and from the computer 400. In some embodiments, the software for storing an internal identifier in metadata may be stored on a portable storage medium, and may be inputted into the computer 400 via the portable storage medium device 450. The peripheral device(s) 440 may include any type of computer support device, such as, for example, an input/output (I/O) interface configured to add additional functionality to the computer 400. For example, the peripheral device(s) 440 may include a network interface card for interfacing the computer 400 with a network 420.
The input control device(s) 480 provide a portion of the user interface for a user of the computer 400. The input control device(s) 480 may include a keypad and/or a cursor control device. The keypad may be configured for inputting alphanumeric characters and/or other key information. The cursor control device may include, for example, a mouse, a trackball, a stylus, and/or cursor direction keys. In order to display textual and graphical information, the computer 400 may include the graphics subsystem 460 and the output display 470. The output display 470 may include a cathode ray tube (CRT) display and/or a liquid crystal display (LCD). The graphics subsystem 460 receives textual and graphical information, and processes the information for output to the output display 470.
Each component of the computer 400 may represent a broad category of a computer component of a general and/or special purpose computer. Components of the computer 400 are not limited to the specific implementations provided here.
Portions of the example embodiments of the invention may be conveniently implemented by using a conventional general purpose computer, a specialized digital computer and/or a microprocessor programmed according to the teachings of the present disclosure, as is apparent to those skilled in the computer art. Appropriate software coding may readily be prepared by skilled programmers based on the teachings of the present disclosure.
Some embodiments may also be implemented by the preparation of application-specific integrated circuits, field programmable gate arrays, or by interconnecting an appropriate network of conventional component circuits.
Some embodiments include a computer program product. The computer program product may be a storage medium or media having instructions stored thereon or therein which can be used to control, or cause, a computer to perform any of the procedures of the example embodiments of the invention. The storage medium may include without limitation a floppy disk, a mini disk, an optical disc, a Blu-ray Disc, a DVD, a CD-ROM, a micro-drive, a magneto-optical disk, a ROM, a RAM, an EPROM, an EEPROM, a DRAM, a VRAM, a flash memory, a flash card, a magnetic card, an optical card, nanosystems, a molecular memory integrated circuit, a RAID, remote data storage/archive/warehousing, and/or any other type of device suitable for storing instructions and/or data.
Stored on any one of the computer readable medium or media, some implementations include software for controlling both the hardware of the general and/or special computer or microprocessor, and for enabling the computer or microprocessor to interact with a human user or other mechanism utilizing the results of the example embodiments of the invention. Such software may include without limitation device drivers, operating systems, and user applications. Ultimately, such computer readable media further include software for performing example aspects of the invention, as described above.
Included in the programming and/or software of the general and/or special purpose computer or microprocessor are software modules for implementing the procedures described above.
While various example embodiments of the invention have been described above, it should be understood that they have been presented by way of example, and not limitation. It is apparent to persons skilled in the relevant art(s) that various changes in form and detail can be made therein. Thus, the invention should not be limited by any of the above described example embodiments, but should be defined only in accordance with the following claims and their equivalents.
In addition, it should be understood that the figures are presented for example purposes only. The architecture of the example embodiments presented herein is sufficiently flexible and configurable, such that it may be utilized and navigated in ways other than that shown in the accompanying figures. Further, the purpose of the Abstract is to enable the U.S. Patent and Trademark Office and the public generally, and especially the scientists, engineers and practitioners in the art who are not familiar with patent or legal terms or phraseology, to determine quickly from a cursory inspection the nature and essence of the technical disclosure of the application. The Abstract is not intended to be limiting as to the scope of the example embodiments presented herein in any way. It is also to be understood that the procedures recited in the claims need not be performed in the order presented.
This application is a continuation of and claims priority to U.S. patent application Ser. No. 14/488,366, filed Sep. 17, 2014, and entitled “Systems, Methods, and Computer Program Products for Securely Managing Data on a Secure Element,” which claims priority to U.S. Provisional Patent Application No. 61/884,719, filed Sep. 30, 2013, and entitled “Systems, Methods, and Computer Program Products for Managing a Wallet Companion Applet.” The entire disclosure of each of the above-identified priority applications is hereby fully incorporated herein by reference.
Number | Name | Date | Kind |
---|---|---|---|
5590038 | Pitroda | Dec 1996 | A |
5640002 | Ruppert et al. | Jun 1997 | A |
5748740 | Curry et al. | May 1998 | A |
5805702 | Curry et al. | Sep 1998 | A |
5884271 | Pitroda | Mar 1999 | A |
5901303 | Chew | May 1999 | A |
5940510 | Curry et al. | Aug 1999 | A |
5949880 | Curry et al. | Sep 1999 | A |
6073840 | Marion | Jun 2000 | A |
6105013 | Curry et al. | Aug 2000 | A |
6116505 | Withrow | Sep 2000 | A |
6131811 | Gangi | Oct 2000 | A |
6237095 | Curry et al. | May 2001 | B1 |
6422464 | Terranova | Jul 2002 | B1 |
6587835 | Treyz et al. | Jul 2003 | B1 |
6601759 | Fife et al. | Aug 2003 | B2 |
6671358 | Sossaman et al. | Dec 2003 | B1 |
6732081 | Nicholson | May 2004 | B2 |
6769607 | Pitroda et al. | Aug 2004 | B1 |
6813609 | Wilson | Nov 2004 | B2 |
6837436 | Swartz et al. | Jan 2005 | B2 |
6925439 | Pitroda | Aug 2005 | B1 |
7083094 | Cooper | Aug 2006 | B2 |
7110792 | Rosenberg | Sep 2006 | B2 |
7127236 | Khan et al. | Oct 2006 | B2 |
7155405 | Petrovich | Dec 2006 | B2 |
7194422 | Killick | Mar 2007 | B1 |
7216109 | Donner | May 2007 | B1 |
7249112 | Berardi et al. | Jul 2007 | B2 |
7286818 | Rosenberg | Oct 2007 | B2 |
7298271 | Sprogis | Nov 2007 | B2 |
7308426 | Pitroda | Dec 2007 | B1 |
7330714 | Rosenberg | Feb 2008 | B2 |
7349885 | Gangi | Mar 2008 | B2 |
7469151 | Khan et al. | Dec 2008 | B2 |
7469381 | Ording | Dec 2008 | B2 |
7483858 | Foran et al. | Jan 2009 | B2 |
7494055 | Fernandes et al. | Feb 2009 | B2 |
7529563 | Pitroda | May 2009 | B1 |
7571139 | Giordano et al. | Aug 2009 | B1 |
7581678 | Narendra et al. | Sep 2009 | B2 |
7613628 | Ariff et al. | Nov 2009 | B2 |
7631810 | Liu et al. | Dec 2009 | B2 |
7693752 | Jaramillo | Apr 2010 | B2 |
7708198 | Gangi | May 2010 | B2 |
7712658 | Gangi | May 2010 | B2 |
7775430 | Lin | Aug 2010 | B2 |
7805615 | Narendra et al. | Sep 2010 | B2 |
7828214 | Narendra et al. | Nov 2010 | B2 |
7856377 | Cohagan et al. | Dec 2010 | B2 |
7864163 | Ording et al. | Jan 2011 | B2 |
7942337 | Jain | May 2011 | B2 |
7954715 | Narendra et al. | Jun 2011 | B2 |
7954716 | Narendra et al. | Jun 2011 | B2 |
7954717 | Narendra et al. | Jun 2011 | B2 |
7961101 | Narendra et al. | Jun 2011 | B2 |
7967215 | Kumar et al. | Jun 2011 | B2 |
7991158 | Narendra et al. | Aug 2011 | B2 |
8072331 | Narendra et al. | Dec 2011 | B2 |
8083145 | Narendra et al. | Dec 2011 | B2 |
8091786 | Narendra et al. | Jan 2012 | B2 |
8131645 | Lin et al. | Mar 2012 | B2 |
8140418 | Casey et al. | Mar 2012 | B1 |
8396808 | Greenspan | Mar 2013 | B2 |
8429046 | Pitroda | Apr 2013 | B2 |
9311491 | Watson | Apr 2016 | B2 |
20020049631 | Williams | Apr 2002 | A1 |
20020082921 | Rankin | Jun 2002 | A1 |
20020174025 | Hind et al. | Nov 2002 | A1 |
20020179703 | Allen | Dec 2002 | A1 |
20030009382 | D'Arbeloff et al. | Jan 2003 | A1 |
20030083042 | Abuhamdeh | May 2003 | A1 |
20030115126 | Pitroda | Jun 2003 | A1 |
20030132298 | Swartz et al. | Jul 2003 | A1 |
20030200489 | Hars | Oct 2003 | A1 |
20040073519 | Fast | Apr 2004 | A1 |
20040186768 | Wakim et al. | Sep 2004 | A1 |
20050004866 | Bonalle et al. | Jan 2005 | A1 |
20050171898 | Bishop et al. | Aug 2005 | A1 |
20050222961 | Staib et al. | Oct 2005 | A1 |
20050234769 | Jain et al. | Oct 2005 | A1 |
20050247777 | Pitroda | Nov 2005 | A1 |
20060287004 | Fuqua | Dec 2006 | A1 |
20070014407 | Narendra et al. | Jan 2007 | A1 |
20070014408 | Narendra et al. | Jan 2007 | A1 |
20070198432 | Pitroda et al. | Aug 2007 | A1 |
20080306849 | Johnson et al. | Dec 2008 | A1 |
20090006640 | Brouwer et al. | Jan 2009 | A1 |
20090108064 | Fernandes et al. | Apr 2009 | A1 |
20090164322 | Khan et al. | Jun 2009 | A1 |
20100241494 | Kumar et al. | Sep 2010 | A1 |
20100318812 | Auradkar et al. | Dec 2010 | A1 |
20110073663 | Narendra et al. | Mar 2011 | A1 |
20110171996 | Narendra et al. | Jul 2011 | A1 |
20110223972 | Narendra et al. | Sep 2011 | A1 |
20110231238 | Khan et al. | Sep 2011 | A1 |
20110244796 | Khan et al. | Oct 2011 | A1 |
20110269438 | Narendra et al. | Nov 2011 | A1 |
20110271044 | Narendra et al. | Nov 2011 | A1 |
20110272468 | Narendra et al. | Nov 2011 | A1 |
20110272469 | Narendra et al. | Nov 2011 | A1 |
20120064828 | Khan et al. | Mar 2012 | A1 |
20120109764 | Martin et al. | May 2012 | A1 |
20120323664 | Klems | Dec 2012 | A1 |
20130160134 | Marcovecchio et al. | Jun 2013 | A1 |
20140172700 | Teuwen | Jun 2014 | A1 |
Number | Date | Country |
---|---|---|
2381614 | Mar 2001 | CA |
1 222 503 | Jul 2002 | EP |
0 766 852 | Aug 2004 | EP |
1 412 890 | Nov 2004 | EP |
1 477 943 | Nov 2004 | EP |
2 003 842 | Dec 2008 | EP |
10-2013-0094170 | Aug 2013 | KR |
0118629 | Mar 2001 | WO |
03012717 | Feb 2003 | WO |
2006007329 | Jan 2006 | WO |
2015047807 | Apr 2015 | WO |
Entry |
---|
Koo, “Korean Office Action issued in Korean Application No. 10-2016-7011237”, mailed on Sep. 5, 2016, 5 pages of English Translation and 5 pages of Korean Office Action. |
Ahn, “International Search Report and Written Opinion issued in International Application No. PCT/US2014/055983”, mailed on Dec. 15, 2014, 14 pages. |
Moussaid, “International Preliminary Report on Patentability issued in International Application No. PCT/US2014/055983”, mailed on Apr. 14, 2016, 11 pages. |
Chen, “Java Card Technology for Smart Cards”, Jan. 1, 2000, 38 pages. |
Jardak, “Extended European Search Report issued in European Application No. 14849563.3 (GOOG-2373EP)”, mailed on Jan. 30, 2017, 8 pages. |
Number | Date | Country | |
---|---|---|---|
20160212117 A1 | Jul 2016 | US |
Number | Date | Country | |
---|---|---|---|
61884719 | Sep 2013 | US |
Number | Date | Country | |
---|---|---|---|
Parent | 14488366 | Sep 2014 | US |
Child | 15081819 | US |