The present disclosure relates generally to methods and systems for detecting unwanted electronic devices and, more particularly, to methods and systems for detecting automated teller machine (“ATM”) skimmers.
An ATM is an electronic device that allows banking customers to carry out financial transactions without the need for a human teller. For example, customers may use an ATM to access their bank accounts, deposit, withdraw, or transfer funds, check account balances, or dispense items of value. Generally, to use an ATM, the customer may insert a banking card containing magnetic stripe information into the ATM's card reader, and authenticate the card by entering a personal identification number (PIN). After the card has been read and authenticated, the customer can carry out various financial transactions.
While ATMs are convenient, their use can also be risky. Thieves have been known to attach devices known as “skimmers” on or adjacent to the ATMs to capture the card information and PINs entered by the customer. These skimmers can remain on the ATM for an extended period of time prior to detection, and are sometimes constructed to match the visual appearance of the ATM's card reader. Thus, the customer is unable to determine whether the device is a skimmer or part of the ATM itself.
To combat these skimmers, bank employees often conduct periodic visual reviews of the ATM's appearance. However, these visual reviews are error prone (sometimes the skimmer is not found), labor intensive, time consuming, and expensive. Accordingly, a need exists to detect these skimmer devices quickly and inexpensively and thus mitigate the risk of the compromise of a customer's card data.
The disclosed embodiments include methods, systems, and non-transitory computer-readable storage media for detecting ATM skimmers based upon radio frequency (RF) signals emitted from the ATM. In one aspect, the disclosed embodiments include a system for detecting ATM skimmers including a memory storing instructions and one or more processors that execute the instructions to perform one or more operations for detecting ATM skimmers. The operations may include, for example, receiving radio frequency (RF) signal data corresponding to one or more detected RF signals emitted by an ATM and/or other electronic device and detected by an antenna located within communication range of the ATM. The operations may also include determining one or more unidentified RF signals of the detected ATM RF signals that differ from one or more baseline RF signals. The operations may also include determining whether the one or more unidentified RF signals are present for a predetermined period of time, and determining whether a skimmer is present at the ATM based on a determination that the one or more unidentified RF signals are present for the predetermined period of time.
The disclosed embodiments may also include a computer implemented method for detecting ATM skimmers. In one aspect, the method may include receiving radio frequency (RE) signal data corresponding to one or more detected RF signals emitted by an ATM and detected by an antenna located within communication range of the ATM. The method may also include determining one or more unidentified RE signals of the detected ATM RE signals that differ from one or more baseline RE signals. The method may also include determining whether the one or more unidentified RF signals are present for a predetermined period of time, and determining whether a skimmer is present at the ATM based on a determination that the one or more unidentified RE signals are present for the predetermined period of time.
The disclosed embodiments may also include a non-transitory computer-readable storage medium. In one aspect, the non-transitory computer-readable storage medium may be encoded with instructions which, when executed on a processor, perform a method. The method may include receiving radio frequency (RF) signal data corresponding to one or more detected RF signals emitted by an ATM and detected by an antenna located within communication range of the ATM. The method may also include determining one or more unidentified RE signals of the detected ATM RE signals that differ from one or more baseline RE signals. The method may also include determining whether the one or more unidentified RE signals are present for a predetermined period of time, and determining whether a skimmer is present at the ATM based on a determination that the one or more unidentified RF signals are present for the predetermined period of time.
It is to be understood that both the foregoing general description and the following detailed description are exemplary and explanatory only and are not restrictive of the disclosed embodiments, as claimed. Further features and/or variations may be provided in addition to those set forth herein. For example, disclosed embodiments may be directed to various combinations and subcombinations of the disclosed features and/or combinations and subcombinations of several further features disclosed below in the detailed description.
The accompanying drawings, which are incorporated in and constitute part of this specification, illustrate various embodiments and together with the description, serve to explain one or more aspects of the disclosed embodiments. In the drawings:
The following detailed description refers to the accompanying drawings. Wherever possible, the same reference numbers are used in the drawings and the following description to refer to the same or similar parts. While several exemplary embodiments and features of the disclosed embodiments are described herein, modifications, adaptations, and other implementations are possible, without departing from the spirit and scope of the disclosed embodiments. Accordingly, the following detailed description does not limit the disclosed embodiments. Instead, the proper scope of the disclosed embodiments may be defined by the appended claims.
Almost ail electronic devices emit radio frequency (“RF”) signals incidental to their operation. Thus, the disclosed embodiments may use these incidental RF emissions to detect skimmer devices present on ATMs. To this end, an exemplary system may be configured to determine one or more baseline RF signals associated with an ATM, detect RF signals near the ATM, and/or determine any differences between the baseline RF signals and the detected RF signals. The system may also determine whether a skimmer is present based on the detected RF signals. For example, the system may compare the detected RF signals to data contained in a known skimmer emissions database to determine whether the detected RE signals match any known ATM skimmers. As another example, the system may also determine that a skimmer is present based on the number and type of detected RE emissions in various frequency ranges and/or the period of time that the particular RF emissions are detected. As yet another example, the system may also detect increases in ambient RF noise levels that are not clearly confined to specific frequencies. The system may also include multiple receiving antennas to enable a directional read of the source of the RF emissions to reduce false positives.
Antenna 110 may be any type of known antenna capable of detecting RF signals. For example, antenna 110 may be any type of commercially available wideband antenna or tunable antenna.
Receiver 120 may be any type of receiver that can receive one or more frequencies of RF signals, and may be configured in hardware, software and/or some combination of hardware and software. Receiver 120 may also convert the received RF signals into digital data, and send the digital data to one or more devices, such as skimmer detection server 130. Receiver 120 may also be associated with a particular ATM (not pictured) and may store identification information related to the ATM (e.g., ATM location, ATM type, etc.) in a memory. Receiver 120 may also transmit the identification information to server 130 using any known transmission method such as, for example, using one or more data packets. In some configurations, receiver 120 may be a software defined radio (“SDR”) capable of simultaneously listening for a plurality of differently modulated signals at once. Exemplary commercially available SDRs may include RTL-SDR, Zeus ZS-1, and Flex Radio.
Skimmer detection server 130 may be a computing system that performs various functions consistent with the disclosed embodiments. In some embodiments, server 130 may be configured to process information received from receiver 120. For example, server 130 may demodulate the digital data received from receiver 120 and perform analyses on the digital data to determine whether a skimmer is present. As another example, server 130 may capture one or more data packets transmitted by receiver 120 and decode the packets' raw data, such as the identification information related to the ATM. Server 130 may also store the decoded raw data in memory 233. Server 130 may also generate and send one or more alerts to one or more of client terminals 140-a through 140-n. Certain functions that may be performed by server 130 are described in greater detail below with respect to, for example,
Each client terminal 140 may be a computing system operated by a user. In one example, client terminal 140 may be a computing device configured to perform one or more operations consistent with certain disclosed embodiments. For example, terminal 140 may be configured to generate and/or display alerts indicating that a skimmer has been detected on one or more ATMs. Terminal 140 may be a desktop computer, a laptop, a server, a mobile device (e.g., tablet, smart phone, etc.), and any other type of computing device. Client terminal 140 may include one or more processors configured to execute software instructions stored in memory. The disclosed embodiments are not limited to any particular configuration of client terminal 140. For instance, as shown in
Network 150 may be any type of network that facilitates communication between remote components, such as server 130 and terminals 140-a to 140-n. For example, network 150 may be a local area network (LAN), a wide area network (WAN), a virtual private network, a dedicated intranet, the Internet, and/or a wireless network.
The arrangement illustrated in
Processor 231 may include one or more processors, such as known processing devices, microprocessors, etc. configured to execute instructions to perform operations. Memory 233 may include one or more storage devices configured to store information used and/or executed by processor 231 to perform one or more operations related to disclosed embodiments. Storage 235 may include volatile or non-volatile, magnetic, semiconductor, tape, optical, removable, nonremovable, or any other type of storage device or tangible computer-readable medium.
In some embodiments, memory 233 may include software instructions that when executed by processor 231, perform operations consistent with disclosed embodiments. For example, memory 233 may include software instructions that when executed perform one or more skimmer detection processes consistent with disclosed embodiments. In one example, memory 233 may include skimmer detection program 232. In one embodiment, program 232 may be loaded from storage 235 or another source component that, when executed by skimmer detection server 130, perform various procedures, operations, and/or processes consistent with disclosed embodiments. For example, memory 233 may include a skimmer detection program 232 that performs operations that may determine one or more differences between one or more baseline RF signals and one or more detected RE signals and, based on the detected differences, determine whether a skimmer is present on or near an ATM. Memory 233 may also include other programs that perform other functions and processes, such as programs that provide communication support, Internet access, database access, and the like. Memory 233 may also include one or more interconnected information storage databases, such as, for example, known skimmer database 234, unknown skimmer database 236, and detected signals database 238. The information storage databases can by populated by any known methods. For example, server 130 may populate known skimmer database 234 by receiving one or more database entries from another component, a wireless network operator, or a user of server 130 and/or terminal 140, and storing the database entries into memory 233. The database entries can contain a plurality of fields, one or more of which may include information related to known skimmer devices, such as, for example, skimmer device names, the frequency or frequencies of RF signals emitted by the skimmer device, the amplitude(s) of the RF signals emitted by the skimmer device, one or more images of the skimmer device, information related to disabling the particular skimmer device, and the like. While in the embodiment shown in
Methods, systems, and articles of manufacture consistent with disclosed embodiments are not limited to separate programs or computers configured to perform dedicated tasks. For example, memory 233 may be configured with a skimmer detection program 232 that performs several processes when executed by processor 231. For example, memory 233 may include a single program 232 that performs the functions of the skimmer detection system, or program 232 could comprise multiple programs. Moreover, processor 231 may execute one or more programs located remotely from server 130. For example, sever 130 may access one or more remote programs that, when executed, perform functions related to disclosed embodiments.
Memory 233 may also be configured with an operating system (not shown) that performs several functions well known in the art when executed by server 130. By way of example, the operating system may be Microsoft Windows, UNIX, Linux, Apple Computer operating systems, or some other operating system. The choice of operating system, and even the use of an operating system, is not critical to any embodiment.
Skimmer detection server 130 may include one or more I/O devices (not shown) that allow data to be received and/or transmitted by skimmer detection server 130. I/O devices may also include one or more digital and/or analog communication input/output devices that allow skimmer detection server 130 to communicate with other machines and devices, such as terminals 140-a to 140-n. The configuration and number of input and/or output devices incorporated in I/O devices may vary as appropriate for certain embodiments.
Skimmer detection server 130 may receive and store the digital data in one or more memories, such as in detected signals database 238 of memory 233. Skimmer detection server 130 may execute software instructions that perform operations to determine whether or not a skimmer is present on the ATM (S340). In one aspect, skimmer detection server 130 may demodulate the digital data and analyze it in accordance with software instructions to determine whether a skimmer is present. In one embodiment, for example, skimmer detection server 130 may differentiate between RE signals generated by the ATM and/or other non-harmful devices and those generated by a skimmer. This analysis is described in further detail with respect to
In one embodiment, server 130 may be configured to determine the type of detected skimmer. For example, server 130 may perform operations that determine whether the detected skimmer has one or more characteristics that match those of a known type of skimmer through analysis of information stored in known skimmer database 234. In such instances, server 130 may generate an alert such that it includes skimmer related information obtained, for example, from known skimmer database 234. For example, if server 130 has identified the detected skimmer, server 130 may query known skimmer database 234 to match the detected skimmer to database entries of known skimmers in the known skimmer database 234. If server 130 determines a match between the detected skimmer and a database entry, server 130 may populate an alert template with information contained in the matching database entry and/or with information linked to the matching database entry. For example, in some embodiments, server 130 may generate the alert such that it may include one or more images (e.g., digital picture, or the like) of the detected skimmer, information about how to remove, disable, etc. the skimmer, and the like. In certain embodiments, if server 130 has determined the detected skimmer is an unknown skimmer, server 130 may generate information in the alert that provides directions on how a user may populate unknown skimmer database 236 with information related to the unknown skimmer (e.g., how to input information related to detected RF signals emitted by the particular skimmer device, how to create and/or upload one or more images of the particular skimmer device, how the user disabled the particular skimmer device, and the like.
In certain aspects, if skimmer detection server 130 determines that a skimmer is not present (step S340; No), server 130 may not generate an alert (S360).
The disclosed embodiments may implement process 300 such that the disclosed embodiments may monitor a plurality of ATMs to determine whether one or more skimming devices are present on the ATMs. In certain aspects, the disclosed embodiments may be configured to generate and store data related to multiple skimming devices detected at respective ATMs, at a central location, such as server 130. For example, system 100 may be configured to use data gathered from a plurality of ATMs to identify skimmers (e.g., new, known, etc.) and store that data for use by skimmer detection server 130 or by another computing component that may be in communication with skimmer detection server 130.
Server 130 may determine whether there are any differences between the baseline signals and one or more signal(s) detected by antenna 110 and provided by receiver 120, such as the signals collected during operations S310-S330. For example, server 130 may employ a spectrum analyzer that generates signal amplitudes over various frequencies based on the detected signals. In another embodiment, server 130 may execute software instructions that perform spectrum analyzer operations to generate signal amplitudes over various frequencies based on the detected signals. Server 130 may be configured to determine whether a skimmer device is present when one or more signals exceed a threshold amplitude level. In certain aspects, server 130 may be programmed with one or more amplitude threshold levels that may be associated with anomalous operations of an ATM. The threshold level of server 130 may be set, for example, by a device or component manufacturer, by a wireless network operator, by a user of server 130, and/or by a user of terminal 140. For instance, the threshold level may be set at an amplitude level determined to be appropriate to initiate investigation as to whether the ATM may include a skimmer device such as, for example, an amplitude level 5% greater than the amplitude level of the baseline signal(s).
Server 130 may be configured to determine, when analyzing the detected RF signals provided by receiver 120, whether the amplitude of the detected RF signals exceeds the threshold level. If so, server 130 may be configured to set a threshold timer to begin measuring the duration of the detected RF signal(s) which exceed the threshold level. When the detected RF signal(s) no longer exceed the threshold level, server 130 may instruct the threshold timer to stop measuring the duration of the detected RF signals(s) and to store information relation to the measurement of the duration (e.g., length of duration, time period(s) of duration, etc.) in memory 233. Server 130 may also perform a comparison process that determines whether a difference exists between one or more baseline signals previously collected for the ATM and/or stored in memory and the detected signals associated with the ATM. For example, server 130 may compare one or more baseline signals associated with the ATM to one or more detected signals associated with the ATM to determine whether one or more differences exists in one or more frequency ranges of the compared signals. As another example, server 130 may compare the amplitude(s) of the one or more baseline signals associated with the ATM to the amplitude(s) of the detected signals associated with the ATM to determine whether one or more differences exist in the amplitudes of the compared signals. This comparison may utilize one or more types of displays. For example, RE signals may be visualized and analyzed in various frameworks. The signals may exhibit changes in the time and frequency domains. A common “oscilloscope style” display may show near real-time changes in the amplitude at various frequencies, A “waterfall” display may show similar information but with an added time dimension by showing changing amplitudes as varying colors on a graphical format that has the appearance of a waterfall
If there are one or more differences between the amplitudes and/or frequencies baseline signals and the amplitudes and/or frequencies of the detected signals, server 130 may determine whether the differences are present for a predetermined time period (S440). For example, server 130 may compare the duration of the detected RF signals measured by the threshold timer to the predetermined time period. In one embodiment, the predetermined time period may be a length of time greater than an average time for a customer to initiate and complete a typical ATM transaction. In one aspect, server 130 may receive the predetermined time period from another component, or it may be provided via a user using an input device to program and/or store the predetermined time period data in memory, which is accessible by processor 231 (for example) for subsequent analysis in accordance with these embodiments. In one aspect, the software instructions executed by server 130 may include processes that take into account that skimmers are generally present on an ATM until retrieved by a person who implemented the skimmer on the ATM (e.g., a thief). Thus, in one example, server 130 may perform processes that determine whether the unidentified RE signals associated with the ATM are emitted for a period of time that is longer than the typical time for typical ATM transactions. For instance, one of ordinary skill in the art would appreciate that skimmers may emit RF signals for a period of time that would be longer, and in some instances significantly longer, than the time it would take a customer to initiate and complete an ATM transaction. Server 130 may be configured to account for changes in RF signals based on normal activities by or near a monitored ATM. For example, server 130 may be configured to determine whether detected different RF signals are not constant or near constant for the predetermined time period, and if so, may determine that the signals likely have been generated by non-harmful electronic devices passing by the proximity of the ATM, such as a customer's cellular phone. Thus in certain embodiments, if server 130 determines that the differences in detected RF signals are not present for a predetermined time period (e.g., step S440; No), server 130 may determine that a skimmer is not in place at the ATM (e.g., step S430). In one embodiment, process 400 may then restart the analysis for detecting a skimmer using additional and/or new detected signal information.
However, if server 130 determines that the different RF signals associated with the ATM are constant, or near constant, for the predetermined period of time, server 130 may determine that the signals were likely generated by a skimmer (e.g., step S440; Yes). Server 130 may also be configured to determine whether differences between the amplitude levels and/or the frequencies of the baseline signals and the detected signals are present in multiple frequency ranges during the predetermined time period (e.g., step S450). In one aspect, server 130 may be configured to execute software instructions to perform processes that take into account that skimmers generally emit RF signals in multiple frequency ranges and thus determine that that it is likely that a skimmer is present at the ATM if multiple frequencies are detected during the predetermined time period.
If server 130 determines that the differences between the amplitude levels and/or the frequencies of the baseline signals and the detected signals are present in multiple frequency ranges (e.g., step S450; Yes), server 130 may determine whether the frequency emissions match any known skimmer frequencies (step S460). For example, server 130 may be configured to perform one or more processes that request or obtain skimmer frequency data from one or more databases, such as known skimmer database 234, and compare the detected frequency or combination of frequencies associated with the detected RF signals with the frequency or combination of frequencies of known skimmers stored in known skimmer database 234. If the comparison results in a match (e.g., one or more frequencies of the detected RF signals match one or more frequencies of known skimmers), server 130 may determine that the detected RF signals are generated by a known skimmer associated with the known skimmer data (e.g., step S470). However, if server 130's comparison fails to result in a match, server 130 may determine that the detected frequencies are being generated by an unknown skimmer (e.g., step S480). In one embodiment, server 130 may store the detected frequencies of the RF signals and information related to the detection (e.g., location information, time information, etc.) in unknown skimmer database 236 (e.g., step S490). The disclosed embodiments may later use the updated unknown skimmer frequency data to identify and detect an unknown skimmer based on other detected RF signals for the ATM or another ATM. Moreover, the disclosed embodiments may provide the unknown skimmer frequency data to another component for additional analysis to identify the unknown skimmer based on other characteristics of the detected RF signals.
The disclosed embodiments may include methods, systems, and computer-readable storage media that provide skimmer detection processes for detecting skimmer(s) located on or near ATMs using incidental RF signal emissions. For purposes of explanation only, certain aspects and embodiments are described herein with reference to the components illustrated in
Further, the sequences of operations described in connection with
Other aspects of the disclosed embodiments will be apparent to those skilled in the art from consideration of the specification and practice of the disclosed embodiments. It is intended that the specification and examples be considered as exemplary only, with exemplary scopes of the disclosed embodiments being indicated by the following claims.
This application is a continuation of U.S. patent application Ser. No. 14/606,423, filed Jan. 27, 2015, which claims priority to U.S. Provisional Patent Application No. 61/932,311, filed on Jan. 28, 2014. The contents of the above-referenced applications are expressly incorporated herein by reference in their entireties.
Number | Name | Date | Kind |
---|---|---|---|
8418917 | Lewis et al. | Apr 2013 | B1 |
8833669 | Chin | Sep 2014 | B1 |
20050201450 | Volpi | Sep 2005 | A1 |
20060169764 | Ross | Aug 2006 | A1 |
20070057070 | Scarafile | Mar 2007 | A1 |
20070063838 | Yuzik | Mar 2007 | A1 |
20080191860 | Flook et al. | Aug 2008 | A1 |
20110164811 | Ishiyama | Jul 2011 | A1 |
20130106576 | Hinman | May 2013 | A1 |
20130106577 | Hinman | May 2013 | A1 |
20130182904 | Zhang et al. | Jul 2013 | A1 |
20130342317 | Rimai | Dec 2013 | A1 |
20130342323 | Hinman | Dec 2013 | A1 |
20140372305 | Ray et al. | Dec 2014 | A1 |
20150091547 | Vasilev | Apr 2015 | A1 |
20150213427 | Hodges et al. | Jul 2015 | A1 |
Entry |
---|
International Search Report and Written Opinion of the International Searching Authority in International Application No. PCT/US 15/13053, dated Apr. 16, 2015 (13 pages). |
“Detecting Skimmers and other ATM traps,” [online], May 2013 [retrieved Mar. 29, 2015]. Retrieved from the Internet: http://security.stackexchanqe.com/questions/36135/detecting-skimmers-and-other-atm-traps. |
Office Action dated Jul. 10, 2017 in U.S. Appl. No. 14/606,342 to William A. Hodges entitled “Detection of Unauthorized Devices on ATMs” filed Jan. 27, 2015, (37 pages). |
Number | Date | Country | |
---|---|---|---|
20180061188 A1 | Mar 2018 | US |
Number | Date | Country | |
---|---|---|---|
61932311 | Jan 2014 | US |
Number | Date | Country | |
---|---|---|---|
Parent | 14606423 | Jan 2015 | US |
Child | 15804456 | US |