This invention is related to systems and methods for identifying both legitimate (e.g., good mail) and undesired mail, and more particularly for processing electronic messages to extract data to facilitate spam prevention.
The advent of global communications networks such as the Internet has presented commercial opportunities for reaching vast numbers of potential customers. Electronic messaging, and particularly electronic mail (“email”), is becoming increasingly pervasive as a means for disseminating unwanted advertisements and promotions (also denoted as “spam”) to network users.
The Radicati Group, Inc., a consulting and market research firm, estimates that as of August 2002, two billion junk e-mail messages are sent each day—this number is expected to triple every two years. Individuals and entities (e.g., businesses, government agencies) are becoming increasingly inconvenienced and oftentimes offended by junk messages. As such, spam is now or soon will become a major threat to trustworthy computing.
A key technique utilized to thwart spam is employment of filtering systems/methodologies. One proven filtering technique is based upon a machine learning approach—machine learning filters assign to an incoming message a probability that the message is spam. In this approach, features typically are extracted from two classes of example messages (e.g., spam and non-spam messages), and a learning filter is applied to discriminate probabilistically between the two classes. Since many message features are related to content (e.g., words and phrases in the subject and/or body of the message), such types of filters are commonly referred to as “content-based filters”.
With the onslaught of such spam filtering techniques, many spammers have thought of ways to disguise their identities to avoid and/or bypass spam filters. Thus, conventional content-based and adaptive filters may become ineffective in recognizing and blocking disguised spam messages.
The following presents a simplified summary of the invention in order to provide a basic understanding of some aspects of the invention. This summary is not an extensive overview of the invention. It is not intended to identify key/critical elements of the invention or to delineate the scope of the invention. Its sole purpose is to present some concepts of the invention in a simplified form as a prelude to the more detailed description that is presented later.
Spammers can disguise almost all of the information in their messages. For instance, they can embed images, so that there are no words to use as features for a machine learning system. The images can even be distorted in ways that would make it difficult, or at least time-consuming, to use OCR software. Still, no matter how many features they remove, there is still useful information. First, the spammers must send the message from somewhere. We can detect what IP address the message was received from. Second, the spammers are almost always trying to sell something, and must therefore include a way to contact them. This could be a toll free number, but spammers, may be reluctant to use this, because of the high cost of complaints. It could be a non-toll free number, but spammers may be reluctant to do this, because of the lower response rate. Alternatively, it could be a URL (e.g., http://www.spamcorp.com/buyenlarger.htm). This URL could be embedded in an image to make it more difficult for filters and/or software to detect. However, spammers may be reluctant to do this because the user will need to type the URL in to their browser, which could lower response rates.
The most likely ways for spammers to be contacted are embedded links, or through an embedded email address of some sort. For instance, “click here to learn more” wherein the “click here” contains a link to a specific web page that the machine learning system can detect and use in accordance with one aspect of the present invention. Similarly, the address to be replied to (e.g., typically the “from address” but sometimes the “reply-to” address if there is one), or any embedded mailto: links (links that allow a mail message to be sent by clicking on the link), or any other embedded email addresses. Additionally, spammers often include images in messages. Because it is expensive to mail large images over and over, spammers often embed only a special link to the image, which causes the image to be downloaded. The locations that these links point to can also be used as features.
With respect to the information pulled from the mail from address, mail reply-to address, embedded mailto: addresses, external links, and links of external images, at least a portion of such information can be used as a feature of a machine learning system, with which a weight or probability is associated; or the information can be added to a list. For instance, we can keep lists of IP addresses or from addresses that send only spam, or only good mail, or more than 90% good mail, etc. The fact that a particular link or address is on such a list can be used either as a feature of a machine learning system, or as part of any other spam filtering system, or both.
The subject invention provides a system and method that facilitate identifying disguised spam messages by examining particular portions of the messages. More specifically, the present invention involves processing a message such as electronic mail (email) to extract origination and/or destination data to distinguish spam messages from legitimate messages. The processing includes various techniques to identify and parse IP address information, email address information, and/or universal resource locator (URL) information and to associate the extracted data with spam attributes (e.g., good user vs. bad user or good sender vs. bad sender). A bad user or bad sender would be considered a spammer (e.g., one who sends spam), for example.
The extracted data, or at least a portion thereof, can be used to generate feature sets for machine learning systems. Machine learning techniques examine the contents of messages to determine if the messages are spam. Spammers can obfuscate most of the contents of a message such as by putting most of their information in difficult-to-process images. However, the origin of the message cannot be fully disguised since the spammers need to provide some way for a recipient to easily contact them. Examples of such include using a link (e.g., URL) and/or an email address (e.g., IP address). These types of information or variations or portions thereof, can be employed as features of a spam detector. In particular, the information can be used to train a spam detector and/or spam filter by way of the machine learning systems, for example.
The present invention can also be cooperative with parental control systems. Parental controls systems can notify a user that a message is inappropriate and can also indicate a reason for such inappropriateness such as ‘includes pornographic material.’ According to one aspect of the present invention, one or more extracted and normalized features (e.g., a URL) can be passed through a parental control system or filter to obtain the parental control system's classification. This classification can be employed as an additional feature of the machine learning system to facilitate building and/or improving spam filters.
Furthermore, extracted features can be classified by type, can be weighted according to a degree of spaminess, and can be designated as either positive (e.g., more likely not spam) or negative (e.g., more likely to be spam) features. The features can also be utilized to create lists such as non-spammer lists and spammer lists, for example.
To the accomplishment of the foregoing and related ends, certain illustrative aspects of the invention are described herein in connection with the following description and the annexed drawings. These aspects are indicative, however, of but a few of the various ways in which the principles of the invention may be employed and the present invention is intended to include all such aspects and their equivalents. Other advantages and novel features of the invention may become apparent from the following detailed description of the invention when considered in conjunction with the drawings.
The present invention is now described with reference to the drawings, wherein like reference numerals are used to refer to like elements throughout. In the following description, for purposes of explanation, numerous specific details are set forth in order to provide a thorough understanding of the present invention. It may be evident, however, that the present invention may be practiced without these specific details. In other instances, well-known structures and devices are shown in block diagram form in order to facilitate describing the present invention.
As used in this application, the terms “component” and “system” are intended to refer to a computer-related entity, either hardware, a combination of hardware and software, software, or software in execution. For example, a component may be, but is not limited to being, a process running on a processor, a processor, an object, an executable, a thread of execution, a program, and/or a computer. By way of illustration, both an application running on a server and the server can be a component. One or more components may reside within a process and/or thread of execution and a component may be localized on one computer and/or distributed between two or more computers.
The subject invention can incorporate various inference schemes and/or techniques in connection with generating training data for machine learned spam filtering. As used herein, the term “inference” refers generally to the process of reasoning about or inferring states of the system, environment, and/or user from a set of observations as captured via events and/or data. Inference can be employed to identify a specific context or action, or can generate a probability distribution over states, for example. The inference can be probabilistic—that is, the computation of a probability distribution over states of interest based on a consideration of data and events. Inference can also refer to techniques employed for composing higher-level events from a set of events and/or data. Such inference results in the construction of new events or actions from a set of observed events and/or stored event data, whether or not the events are correlated in close temporal proximity, and whether the events and data come from one or several event and data sources.
It is to be appreciated that although the term message is employed extensively throughout the specification, such term is not limited to electronic mail per se, but can be suitably adapted to include electronic messaging of any form that can be distributed over any suitable communication architecture. For example, conferencing applications that facilitate a conference between two or more people (e.g., interactive chat programs, and instant messaging programs) can also utilize the filtering benefits disclosed herein, since unwanted text can be electronically interspersed into normal chat messages as users exchange messages and/or inserted as a lead-off message, a closing message, or all of the above. In this particular application, a filter can be trained to automatically filter particular message content (text and images) in order to capture and tag as spam the undesirable content (e.g., commercials, promotions, or advertisements).
In the subject invention, the term “recipient” refers to an addressee of an incoming message or mail item. The term “user” can refer to a recipient or a sender, depending on the context. For example, a user can refer to an email user who sends spam and/or a user can refer to an email recipient who receives the spam, depending on the context and application of the term.
An Internet Protocol (IP) address is a 32 bit number typically representing a machine on the internet. These numbers are used when two machines communicate. They are typically represented in the form “xxx.xxx.xxx.xxx”, where each xxx is between 0 and 255. Unfortunately, IP addresses are difficult to remember. Because of this, the “domain name” and “host name” conventions have been created. A “domain name” is the name of a group of machines on the internet (perhaps a single machine), and is typically of the form “x.com”, or “y.edu”, or “courts.wa.gov”.
A Fully Qualified Domain Name (FQDN) is a particular machine on the internet, e.g., “b.x.com” or “c.y.edu” or “www.courts.wa.gov”; the domain name portion is “x.com” or “y.edu” or “courts.wa.gov” respectively. The “b”, “c”, and “www” portions, respectively, are called the host name portion of the FQDN. In general, an IP address can be used in any situation in which a domain name can be used (e.g., “DN/IP” indicates that both possibilities exist). Also in general, an IP address can be used in any situation in which an FQDN can be used (e.g., “FQDN/IP” indicates that both possibilities exist). An email address consists of a user name and a domain name or IP address (DN/IP), e.g., “a@x.com” or “a@1.2.3.4”. In both examples, the user name is “a.”
Uniform Resource Locators (URLs) are typically of the form “service-name:FQDN/IP/url-path.” For instance, “http://www.microsoft.com/windows/help.htm” is a URL. The portion “http” is the service name. The portion “www.microsoft.com” is the FQDN and “windows/help.htm” is the URL-path. This is somewhat of a simplification of URLs, but sufficient for the present discussion.
Referring now to
The message receiving component 120 can pass the incoming messages, or a subset thereof, to a feature extraction component 130. The feature extraction component 130 can extract data from the respective messages 110 in order to generate feature sets to facilitate filter training and ultimately spam detection. The data or features extracted from the messages relate to origination and/or destination information found and/or embedded therein. Examples of data or features include a received-from IP address, a reply-to email address, a cc: (e.g., carbon copy) email address, URLs of various sorts (including text-based links, image-based links, and URLs or portions thereof in text form), a non-toll free telephone number (e.g., particularly an area code), toll-free telephone number, a mailto: email address link, a text form email address, a FQDN in a SMTP HELO command, a SMTP MAIL FROM address/return-path address, and/or at least a portion of any of the above.
The feature extraction component 130 can perform any suitable number of processes to extract various sets of features from the message 110 for subsequent use in machine learning systems. In addition or alternatively, the sets of features can be used to populate lists for other filter training techniques.
FQDNs such as a.x.com, for instance, can be translated into numbers generally referred to as an IP address. The IP address is typically observed in a dotted decimal format comprising four blocks of numbers. Each block is separated by a dot or decimal point and each block of numbers can range from 0 to 255, wherein each variation of numbers corresponds to a different internet name. For example, a.x.com could translate to 123.124.125.126 whereas 121.124.125.126 could represent qrstuv.com. Because numbers are not as easily recognizable or memorable as words, IP addresses are usually referred to by their respective FQDNs. The same IP address in dotted decimal format can also be expressed in alternative formats which will be discussed below.
According to one aspect of the subject invention, the feature extraction component 130 can focus on the received-from IP address(s) included in the message 110. The received-from IP address is based at least in part upon the received-from IP information. Generally, mail sent over the Internet is transported from server to server involving as few as two servers (e.g., a sender and a receiver) at times. In even rarer occurrences, a client can send directly to a server. In some cases, many more servers can be involved such that mail or messages are sent from one server to another due to the presence of firewalls, for example. In particular, some servers can be located on the inside of a firewall, and thus can only communicate with designated servers on the other side of the firewall. This causes an increase in the number of hops the message takes to get from the sender to the receiver. The received-from lines comprising the IP addresses facilitate tracing the path of the message to ascertain where the message came from.
As the message 110 travels from server to server, each server which is contacted prepends the identity of the IP address that it received the message from to a received-from field (i.e., “Received:” field) of the message, as well as the name of the alleged FQDN of the server it is talking to. This FQDN is told to the receiving server by the sending server, through the HELO command of the SMTP protocol, and thus cannot be trusted if the sending server is outside the organization. For example, the message can have five received from lines with 5 IP addresses and FQDNs prepended, thus indicating that it has passed through six different servers (i.e., been passed 5 times), with the lines in the reverse order in which they were prepended (i.e., latest first). However, each server has the ability to modify any lower (earlier prepended) lines. This can be particularly problematic especially when the message has traveled between multiple servers. Because each intermediate server is capable of altering any earlier written (lower) received-from lines, spammers can prepend fake IP addresses to the received-from lines of the message to disguise the received-from IP information or sender of the spam message. For example, a spam message may initially appear as if it was sent from trusteddomain.com, thus misrepresenting the true source of the message to the recipient.
It is important for spam software to readily identify an IP address outside the organization that sent to a server inside the organization. Since this IP address is written by the receiving server, inside the organization, it can be trusted as the correct IP address. All other IP addresses outside the organization cannot be trusted, since they were written by servers outside the organization, and thus, possibly modified. There may be many IP addresses of the sending servers involved in the path to the recipient organization, but since only one can be trusted, we refer to this one trustworthy one as the “sender's” IP address.
One way for spam filtering software to find this sender's IP address is to know the mail server configurations at an organization. In general, if one knows which machines pass to which other machines in which situations, one can determine the sender's IP address. However, it may not be convenient to describe the server configuration, especially for spam filtering software installed on email clients. An alternate approach involves utilizing MX records to determine the true source of a message. MX records list, for each domain name, the FQDNs of recipients of email for that domain. One can trace back through the received from list until an IP address is found that corresponds to an FQDN corresponding to an entry in the domain's MX record. The IP addresses that this machine received from is the sender's IP address. Imagine that 1.2.3.101 is the only MX record for x.com. Then by finding the line that received from 1.2.3.101, one can know the next line corresponds to x.com's incoming mail server, and thus that the IP address in that line corresponds to the IP address that sent to x.com.
The table below depicts an exemplary analysis as discussed supra of determining the true source of a message:
Currently, there is no accepted standard for listing outgoing mail servers, and this heuristic can fail if, for instance, IP addresses internal to an organization are different than those external to an organization, or if an organization sends mail from one machine listed in an MX record indirectly to another machine listed in an MX record. Further, in the special case where the sender's IP as found above is found to be internal to the organization, as could happen if one machine in the MX record sent to another in the MX record, the process is continued as above. In addition, certain IP addresses can be detected as internal (because they are of the form 10.x.y.z or 172.16.y.z through 172.31.y.z or 192.168.0.z through 192.168.255.z, a form used only for internal IP addresses); any address internal to an organization can be trusted. Finally, if a received from line is of the form “Received from a.x.com [1.2.3.100]” and an IP address lookup of a.x.com yields 1.2.3.100 or a reverse IP address lookup of 1.2.3.100 yields a.x.com and if x.com is the organization, then the next line can also be trusted.
Using these observations, it is often possible to find the sender's IP address. Exemplary pseudocode is as follows:
Many things can be done with the sender's IP address, as with other origination and destination features. First, they can be added to a list of uniformly bad senders, sometimes known as a Black List. The Black Lists can be employed subsequently to filter, block, or redirect untrustworthy messages to an appropriate folder or location where they can be further investigated.
Other types of lists can also be generated and implemented as filters on both client- and server-based architectures. In the client architecture, a user can inform the client email software who he should be receiving mail from (e.g., mailing lists, individuals, etc). A list of records corresponding to trusted email addresses can be generated either manually or automatically by the user. Accordingly, imagine that a sender having an email address ‘b@zyx.com’ sends the user an email message. The sender's email address b@zyx.com comprises a user name, ‘b’, and an FQDN/IP ‘zyx.com’. When the client receives the incoming message 110 from the sender (b@zyx.com), it can search a trusted sender list for the user's email address to determine if the user has indicated that ‘b@zyx.com’ is a valid and trusted address. For server architectures, the lists can be located directly on the server. Therefore, as messages arrive at the message server, their respective features (e.g., sender's IP address, domain name(s) in MAIL FROM or HELO fields, and other origination and/or destination information) can be compared to the lists located on the message server. Messages that are determined to be from valid senders can be delivered to the intended recipients according to either client-based or server-based delivery protocols. However, messages determined to include origination or destination features in lists of questionable or bad features can be moved to a spam or junk mail folder for discard, or otherwise specially treated.
As an alternative to populating lists of trusted or bad origination features, the sender's origination features (e.g., IP address, alleged From address) can be extracted as one or more features and later used in connection with machine learning techniques for filter building and/or training.
The IP address can be derived from an email address (e.g., IP lookup on the FQDN in the sender's address or reply-to address) in any part of a message header or from an IP address lookup of the domain name portion of a URL link embedded in a body of the message, or directly from an IP address if it occurs as the FQDN/IP portion of a URL. Furthermore, as will be described later, the IP address has several attributes, each of which can be utilized as a feature of a machine learning system or as an element on a user-populated list. Thus, in a second approach, the feature extraction component 130 can exploit the many subparts of the IP address(s) to generate additional features.
Any combination of features as described above can be extracted from each incoming message 110. Messages can be randomly, automatically, and/or manually selected to participate in feature extraction, although typically all messages can be used. The extracted sets of features are subsequently applied to a filter training component 140 such as machine learning systems or any other system that builds and/or trains filters 150 such as spam filters.
Referring now to
Feature extraction involves pulling out one or more features 230 (also referred to as feature1232, feature2234, and featurem 236, where M is an integer greater than or equal to one) associated with origination and/or destination information from the message 210. Origination information can relate to elements indicating the sender of the message as well as server domain names and related identification information that specifies from where the message came. Destination information can relate to elements of a message indicating to whom or where the recipient can send his response to the message. Origination and destination information can be found in a header of the message as well as in the body of the message either visible or invisible (e.g., embedded as text or in image) to the message recipient.
Because spammers tend to disguise and/or obfuscate their identity frequently to avoid detection by conventional spam filters, the system 200 comprises a feature normalizer component 240 that facilitates deobfuscating the one or more extracted features 230, or at least portions thereof. The feature normalizer component 240 can process and/or breakdown the extracted features 230 such as by analyzing the extracted features 230 (e.g., the FQDN—consulting a directory of blocks and MX records and/or translating the FQDN according to its current format) and then comparing them to a database(s) of existing spammer lists, non-spammer lists, and/or parental control lists, for example. In some cases as discussed infra in
Once the features are normalized, at least a subset of them 250 can then be employed by a training system 260 such as a machine learning system, to build and/or update a filter(s) 270. The filter(s) can be trained for use as a spam filter and/or a junk-mail filter, for example. Furthermore, the filter(s) can be built and/or trained with positive features such as those which indicate a non-spam source (e.g., sender's From email address, sender's IP address, embedded telephone numbers, and/or URL) and/or a non-spam sender as well as with negative features such as those that identify and are associated with a spammer.
Alternatively or in addition, the set of features can be utilized to populate a new or add to an existing spam feature list 280. Other lists can also be generated to correspond to the particular extracted features such as a list of good addresses, a list of bad addresses, a list of good URLs, a list of bad URLs, a list of good telephone numbers, and a list of bad telephone numbers. Good feature lists can identify non-spammers, historically legitimate senders, and/or senders having a higher likelihood of non-spamminess (e.g., ˜90% chance not spam source). Conversely, bad feature lists can correspond to spammers, potential spammers, and/or senders having a relatively higher likelihood of spamminess (e.g., ˜90% spam source).
Referring now to
In some circumstances, however, the block ID 302 cannot be readily determined even by referencing arin.net because groups of IP addresses within a block can be sold up divided and re-sold any number of times. In such instances, a user or extraction system can make one or more guesses at the block IDs 302 for the respective IP addresses. For example, the user can extract at least a first 1 bit 304, at least a first 2 bits 306, at least a first 3 bits 308, at least a first M bits 310 (i.e., M is an integer greater or equal to one) and/or up to at least a first 31 bits 312 as separate features for subsequent use by a machine learning system and/or as elements on a feature list(s) (e.g., good feature lists, spam feature lists, etc.).
In practice, for instance, the first 1 bit of an IP address can be extracted and employed as a feature to determine whether the IP address points to a spammer or non-spammer. The first 1 bit from other IP addresses extracted from other messages can be compared to facilitate determining at least one block ID. Identifying at least one block ID can then assist discerning whether the message is from a spammer. Moreover, IP addresses which share the first M bits can be compared with respect to their other extracted features to ascertain whether the IP addresses are from legitimate senders and/or whether the respective messages are spam.
IP addresses can also be arranged hierarchically (314). That is, a set of high order bits may be allocated to a particular country. That country can allocate a subset to an ISP (Internet Service Provider), and that ISP may then allocate a subset to a particular company. Accordingly, various levels can be meaningful for the same IP address. For example, the fact that an IP address comes from a block allocated for Korea could be useful in determining whether the IP address is associated with a spammer. If the IP address is part of a block allocated to an ISP with a strict policy against spammers, this also could be useful in determining that the IP address is not associated with a spammer. Hence, by employing each of the first 1-31 bits of an IP address in combination with the hierarchal arrangement 314 of at least a subset of IP addresses, a user can automatically learn information at different levels without actually knowing the manner in which an IP address was allocated (e.g., without knowing the block IDs).
In addition to the features discussed above, a feature's rarity 316 (e.g., occurrence of feature is not common enough) can be determined by performing suitable calculations and/or employing statistical data comparing the frequency or count in which the feature appears in a sampling of incoming messages, for instance. In practice, an uncommon IP address 300 may be an example of a dial-up line being used to deliver email, which is a tactic often used by spammers. Spammers tend to modify their identity and/or location frequently. Thus, the fact that a feature is common or uncommon may be useful information. Hence, a feature's rarity 316 can be used as a feature of the machine learning system and/or as a part of at least one list (e.g., rare feature list).
Some features, such as received-from information, exist primarily as IP addresses. Thus, it may be useful to convert the FQDN 400 to an IP address 300 that can be broken down into additional features (as shown in
Unfortunately, owners of a domain can make apparently different machines all map to the same place. For instance, the owner of a machine named “a.x.com” could be the same as the owner of “b.x.com” which could be the same owner of “x.com”. Thus, the spammer could easily mislead a conventional filter to believe that the message is from the FQDN 400 “b.x.com” instead of from the domain 404 “x.com”, thereby allowing the message to pass by the spam filter when in actuality, the domain 404 “x.com” would have indicated that the message was spam or was more likely to be spam. Hence, it can be useful to strip the address down to simply the domain name 404 when extracting the origination and/or destination information of the message. Alternatively or in addition, the full FQDN 400 can be extracted as a feature.
In some cases, additional resources are available, such as parental control systems. These resources can often assign a “type” or qualitative assessment, such as pornographic or violent, to host names and/or to URLs. The extracted features can be further classified by type, using such a resource. The feature type 414 of the feature can then be used as an additional feature in connection with building and/or training improved spam related filters. Alternatively, lists can be generated corresponding to different feature types which have previously been identified. The features types 414 can include, but are not limited to, sex or pornographic related features, racial and/or hate-speech related features, physical enhancement features, income or financial solutions features, home-buying features, etc. which identify general subject matter of messages.
Finally, the rarity of a feature 316 or of a feature type (see
The email address 500 ‘a@b.x.com’ can be broken down to various elements or subparts and those elements can be extracted and employed as features as well. In particular, the email address comprises a user name 502 and an FQDN 504 (e.g., see FQDN 400 in
In the current example, ‘a@b.x.com’ comprises the user name 502 “a”. Thus, “a” can be extracted as one feature. Likewise, the FQDN 504 “b.x.com” can be extracted from the email address as at least one other feature. The FQDN 504 portion of the email address 500 can be passed through a parental control filter in order to facilitate determining the feature type 414, which is described in greater detail, supra, in
In addition to email addresses, spammers are often contacted through URLs.
URLs can be deobfuscated in a similar manner with respect to IP addresses. Initially, any prefix (e.g., service name) such as http://, https://, ftp://, telnet://, for example, can be removed before deobfuscating the URL 600. In addition, if an “@” symbol (e.g., % 40 in hex notation) appears amid the URL, anything between the prefix (e.g., http://) and the “@” symbol can be removed before normalizing the URL 400. Incorporating text between the prefix and the “@” symbol can be another tactic or form of trickery by spammers to confuse the message recipient as to the true page location the recipient is being directed to.
For example, http://www.amazon.com@121.122.123.124/info.htm appears to the message recipient as if this page is located at www.amazon.com. Thus, the recipient may be more inclined to trust the link and more importantly, the message sender. On the contrary, the true page location is at “121.122.123.124” which may in fact correspond to a spam-related webpage. In some cases, however, legitimate senders may incorporate authentication information such as a login name and password in this portion of the URL 400 to facilitate an automatic login.
Once normalized and deobfuscated, the URL 600 can essentially be expressed as x.y.com/a/b/c, where x.y.com 630 is the name of the machine (FQDN) and a/b/c (e.g., suffix(s)) is the location of a file on that machine. If x.y.com/a/b/c 600 identifies a spammer(s), then x.y.com/a/b 610 and x.y.com/a 620 most likely identify the same or a related spammer(s) as well. Thus, the end portion or pathway of the URL 600 can be stripped off one part at a time, for example, to obtain additional features for a machine learning system or list. This makes it more difficult for spammers to create many different locations that all actually lead to them in such a way that a pattern is not noticed.
When the suffixes have been stripped off, the FQDN 630 can be further parsed to obtain additional features as previously discussed, supra, in
Some URLs are written with an IP address instead of an FQDN, (e.g., dotted decimal format) such as nnn.nnn.nnn.nnn/a/b/c. The suffixes can be removed in successive order beginning with the “c” and at each stage, the resulting (partial) URL can be used as a feature (e.g., nnn.nnn.nnn.nnn/a/b; nnn.nnn.nnn.nnn/a; and nnn.nnn.nnn.nnn are all possible features to extract from the URL in dotted decimal format). Following, the IP address (e.g., free of suffixes and prefixes) can be used as a feature. It can then be mapped to its netblock. If the netblock is not ascertainable, then multiple guesses can be made using each of the first 1, 2, . . . and up to a first 31 bits of the IP address as separate features (see
In addition to the dotted decimal format, the IP address can be expressed in dword (double word) format (e.g., two binary words of 16 bits each in base 10), in octal format (e.g., base 8), and hexadecimal format (e.g., base 16). In practice, spammers can obfuscate an IP address, a URL, a MAILTO link, and/or a FQDN by, for example, encoding the domain name portion using % nn notation (where nn is a pair of hex digits).
Some URLs can include redirectors which may be employed to confuse or trick the user. A redirector is a parameter or set of parameters following a “?” in the IP address of the URL that instruct a browser to redirect itself to another web page. For example, the URL may appear as “www.intendedpage.com?www.actualpage.com,” wherein the browser actually points to “www.actualpage.com” and loads that page instead of the anticipated “www.intendedpage.com” page. Hence, parameters contained within a URL can also be considered for extraction as features.
Various methodologies in accordance with the subject invention will now be described via a series of acts. It is to be understood and appreciated that the present invention is not limited by the order of acts, as some acts may, in accordance with the present invention, occur in different orders and/or concurrently with other acts from that shown and described herein. For example, those skilled in the art will understand and appreciate that a methodology could alternatively be represented as a series of interrelated states or events, such as in a state diagram. Moreover, not all illustrated acts may be required to implement a methodology in accordance with the present invention.
Referring to
The extracted (and/or normalized) features as well as the classification of the message (e.g., spam or not spam) can be added to a training set of data at 730. At 740, the above (e.g., 710, 720, and 730) can be repeated for substantially all other incoming messages until they are processed accordingly. At 750, features that appear to be useful or the most useful features can be selected from the training set(s). Such selected features can be employed to train a filter, such as a machine learning filter, for example, by way of a machine learning algorithm at 760.
Once trained, a machine learning filter can be utilized to facilitate spam detection as described by an exemplary methodology 800 in
Alternatively, list-based activities can be performed with features extracted from messages. Referring to
It should be appreciated that these lists can be dynamic. That is, they can be updated as additional groups of new messages are processed. Hence, it is possible for a sender's IP address to initially be found on a good list; and then at some time later, be found on a bad list, as it is common for some spammers to initially send good mail (e.g., to gain the “trust” of filters as well as recipients) and then begin to send substantially only spam.
These lists can be utilized in various ways. For instance, they can be used to generate training sets for use by a machine learning system to train filters. Such is depicted by an exemplary process 1000 described next in
Following at 1040, a special feature corresponding to a particular list the sender IP address is on is included in the training set. For example, if the sender IP address was on the “90% good” list, then the feature added to the training set would be “90% good list”. At 1050, the preceding steps (e.g., 1010, 1020, 1030, and 1040) can be repeated to process substantially all incoming messages. Since some features can be more useful for filter training purposes than others, the most useful feature or features are selected based in part on user preferences at 1060 and employed to train a filter(s), such as a spam filter, using a machine learning algorithm.
Moreover, dynamic lists of IP addresses, for example, can be constructed for comparison with test messages, new messages, and/or suspicious messages. However, the IP addresses themselves are not features in this instance. Instead, the quality of the IP address is the feature. Alternatively or in addition, the lists can be utilized in other ways. In practice, for instance, a list of suspicious IP addresses can be used to flag a sender as bad, and accordingly, treat their messages with suspicion.
Turning now to
Optionally, at 1120, contents of the “From:” line can be extracted and/or normalized and subsequently employed as features. At 1130, contents of the “MAIL FROM SMTP” command can similarly be extracted and/or normalized for use as features.
The method 1100 can then proceed to look for other possible features that may be included in the message. For example, it may optionally extract and normalize (if necessary) contents in a reply-to field at 1140. At 1150, contents of the cc field can optionally be extracted and/or normalized for use as at least one feature. At 1160, non-toll free telephone numbers can optionally be extracted from the body of the message and assigned as features as well. Non-telephone numbers can be useful to identify spammers because the area code and/or first three digits of the phone number can be used to map the location of the spammer. If more than one non-toll free telephone number exists in the message, each number can be extracted and used as separate features at 1160.
Likewise, one or more URLs and/or MAILTO links, or portions thereof, can optionally be extracted and/or normalized, respectively at 1170 and 1180. In particular, the URL can undergo pathway stripping (e.g., file name portion of URL), wherein one or more suffixes attached to the end of the FQDN portion of the URL can be stripped away. This can result in one or more partial URLs, depending on the number of suffixes in the pathway. Each partial URL can be employed as a separate feature in accordance with the subject invention.
The method 1100 can continue to scan the body of the message to look for other email addresses as well as key words and/or phrases (e.g., previously selected or determined) which may be more likely to be found in a spam message than in a legitimate message and vice versa. Each word or phrase can be extracted and used as a feature for either the machine learning systems or as an element of a list, or both.
As previously discussed, messages sent over the Internet can be sent from server to server with as few as two servers involved. The number of servers that have contact with the message increases as a result of the presence of firewalls and related network architectures. As the message is passed from server to server, each server prepends its IP address to the received-from field. Each server also has the ability to modify the any earlier prepended received-from addresses. Spammers, unfortunately, can take advantage of this ability and can enter fake addresses in the received-from fields to disguise their location and/or identity and to mislead the recipient as to the source of the message.
At 1230, the sender's alleged FQDN can also be extracted to facilitate determining whether the sender is either legitimate or a spammer. More specifically, the alleged FQDN can be broken down by domain stripping to yield more than one partial FQDNs. For instance, imagine that the alleged FQDN is a.b.c.x.com. This alleged FQDN would be stripped in the following manner to yield: b.c.x.com→c.x.com→x.com→com. Thus, each partial FQDN segment as well as the full FQDN can be employed as a separate feature to assist in determining fake and legitimate senders.
The present invention can also make use of parental control systems. Parental control systems can classify a message as unsuitable for viewing based at least in part upon some content of the message and provide a reason for the unsuitable classification. For example, a URL may be embedded within a message as a clickable link (either text or image-based), or as text within the body of the message. The parental control system can compare the embedded URL(s) to one or more of its stored good and/or bad URL lists to determine the proper classification of the message, or using other techniques for parental control classification. The classification can then be used as an additional feature either in the machine learning system or on a feature list, or both.
In
At 1350, the parental control system can classify the mailto link, URL, or portion thereof by consulting one or more databases of URLs, mailto links, URL service names, URL paths, and FQDNs (e.g., such as the FQDN portions of URLs, email addresses, etc.). For example, the message may be classified as containing at least one of pornographic, get-out-of-debt, gambling, and other similar material. Such classification can be extracted as an additional feature at 1360. Since the subject matter of a majority of spam messages includes such material, incorporating the parental control system can be useful in obtaining additional features with which the machine learning system can use to train and build improved filters. Other classifications exist as well including, but not limited to, hate speech, sex material, gun-violence, and drug-related material, wherein such classifications can be used as features as well. Spam messages may or may not involve subject matter related to these types of materials, but a user may still want to block these types of messages.
In practice, the different classifications can indicate different degrees of spaminess. For instance, messages classified as hate speech may signify substantially no degree of spaminess (e.g., because it is most likely not spam). Conversely, messages classified as sexual content/material may reflect a relatively higher degree of spaminess (e.g., 90% certainty that message is spam). Machine learning systems can build filters that account for the degree of spaminess. Thus, a filter can be customized and personalized to satisfy user preferences.
As already discussed, a myriad of features can be extracted from a message and used as training data by a machine learning system or as elements on a list(s) identifying good and bad features. The qualities of features, in addition to the features themselves, can be useful in detecting and preventing spam. For instance, imagine that one feature is the sender's email address. The email address could be used as one feature and the frequency or count of that email address appearing in new incoming messages could be used as another feature.
The process 1400 can begin with an extraction of one or more features from an incoming message and/or normalization of the feature(s) at 1410. The feature can then be compared to one or more lists of features which have been previously extracted or observed in a plurality of previous messages at 1420. The process 1400 can then determine if the present feature is common. The commonality of a feature can be determined by a calculated frequency of the feature appearing in recent and/or previous incoming messages. If the message is not common or not common enough (e.g., fails to satisfy a commonality threshold) at 1430, then its rarity can be used as an additional feature at 1440. Otherwise, the feature's commonality can also be used as a feature as well at 1450.
In accordance with the present invention as described hereinabove, the following pseudo-code can be employed to carry out at least one aspect of the invention. Variable names are indicated in all uppercase. As an additional note, two functions, add-machine-features and add-ip-features are defined at the end of the pseudo-code. Notation like “PREFIX-machine-MACHINE” is used to indicate the string composed of whatever is in the PREFIX variable concatenated with the word “machine” concatenated with whatever is in the MACHINE variable. Finally, the function add-to-feature-list writes the feature to the list of features associated with the current message.
The exemplary pseudo-code is as follows:
In order to provide additional context for various aspects of the present invention,
Generally, however, program modules include routines, programs, objects, components, data structures, etc. that perform particular tasks or implement particular data types. The operating environment 1510 is only one example of a suitable operating environment and is not intended to suggest any limitation as to the scope of use or functionality of the invention. Other well known computer systems, environments, and/or configurations that may be suitable for use with the invention include but are not limited to, personal computers, hand-held or laptop devices, multiprocessor systems, microprocessor-based systems, programmable consumer electronics, network PCs, minicomputers, mainframe computers, distributed computing environments that include the above systems or devices, and the like.
With reference to
The system bus 1518 can be any of several types of bus structure(s) including the memory bus or memory controller, a peripheral bus or external bus, and/or a local bus using any variety of available bus architectures including, but not limited to, 11-bit bus, Industrial Standard Architecture (ISA), Micro-Channel Architecture (MSA), Extended ISA (EISA), Intelligent Drive Electronics (IDE), VESA Local Bus (VLB), Peripheral Component Interconnect (PCI), Universal Serial Bus (USB), Advanced Graphics Port (AGP), Personal Computer Memory Card International Association bus (PCMCIA), and Small Computer Systems Interface (SCSI).
The system memory 1516 includes volatile memory 1520 and nonvolatile memory 1522. The basic input/output system (BIOS), containing the basic routines to transfer information between elements within the computer 1512, such as during start-up, is stored in nonvolatile memory 1522. By way of illustration, and not limitation, nonvolatile memory 1522 can include read only memory (ROM), programmable ROM (PROM), electrically programmable ROM (EPROM), electrically erasable ROM (EEPROM), or flash memory. Volatile memory 1520 includes random access memory (RAM), which acts as external cache memory. By way of illustration and not limitation, RAM is available in many forms such as synchronous RAM (SRAM), dynamic RAM (DRAM), synchronous DRAM (SDRAM), double data rate SDRAM (DDR SDRAM), enhanced SDRAM (ESDRAM), Synchlink DRAM (SLDRAM), and direct Rambus RAM (DRRAM).
Computer 1512 also includes removable/nonremovable, volatile/nonvolatile computer storage media.
It is to be appreciated that
A user enters commands or information into the computer 1512 through input device(s) 1536. Input devices 1536 include, but are not limited to, a pointing device such as a mouse, trackball, stylus, touch pad, keyboard, microphone, joystick, game pad, satellite dish, scanner, TV tuner card, digital camera, digital video camera, web camera, and the like. These and other input devices connect to the processing unit 1514 through the system bus 1518 via interface port(s) 1538. Interface port(s) 1538 include, for example, a serial port, a parallel port, a game port, and a universal serial bus (USB). Output device(s) 1540 use some of the same type of ports as input device(s) 1536. Thus, for example, a USB port may be used to provide input to computer 1512, and to output information from computer 1512 to an output device 1540. Output adapter 1542 is provided to illustrate that there are some output devices 1540 like monitors, speakers, and printers among other output devices 1540 that require special adapters. The output adapters 1542 include, by way of illustration and not limitation, video and sound cards that provide a means of connection between the output device 1540 and the system bus 1518. It should be noted that other devices and/or systems of devices provide both input and output capabilities such as remote computer(s) 1544.
Computer 1512 can operate in a networked environment using logical connections to one or more remote computers, such as remote computer(s) 1544. The remote computer(s) 1544 can be a personal computer, a server, a router, a network PC, a workstation, a microprocessor based appliance, a peer device or other common network node and the like, and typically includes many or all of the elements described relative to computer 1512. For purposes of brevity, only a memory storage device 1546 is illustrated with remote computer(s) 1544. Remote computer(s) 1544 is logically connected to computer 1512 through a network interface 1548 and then physically connected via communication connection 1550. Network interface 1548 encompasses communication networks such as local-area networks (LAN) and wide-area networks (WAN). LAN technologies include Fiber Distributed Data Interface (FDDI), Copper Distributed Data Interface (CDDI), Ethernet/IEEE 1102.3, Token Ring/IEEE 1102.5 and the like. WAN technologies include, but are not limited to, point-to-point links, circuit switching networks like Integrated Services Digital Networks (ISDN) and variations thereon, packet switching networks, and Digital Subscriber Lines (DSL).
Communication connection(s) 1550 refers to the hardware/software employed to connect the network interface 1548 to the bus 1518. While communication connection 1550 is shown for illustrative clarity inside computer 1512, it can also be external to computer 1512. The hardware/software necessary for connection to the network interface 1548 includes, for exemplary purposes only, internal and external technologies such as, modems including regular telephone grade modems, cable modems and DSL modems, ISDN adapters, and Ethernet cards.
What has been described above includes examples of the present invention. It is, of course, not possible to describe every conceivable combination of components or methodologies for purposes of describing the present invention, but one of ordinary skill in the art may recognize that many further combinations and permutations of the present invention are possible. Accordingly, the present invention is intended to embrace all such alterations, modifications and variations that fall within the spirit and scope of the appended claims. Furthermore, to the extent that the term “includes” is used in either the detailed description or the claims, such term is intended to be inclusive in a manner similar to the term “comprising” as “comprising” is interpreted when employed as a transitional word in a claim.
This application is a continuation of U.S. patent application Ser. No. 10/454,168, filed on Jun. 4, 2003, entitled “ORIGINATION/DESTINATION FEATURES AND LISTS FOR SPAM PREVENTION”, the entirety of which is incorporated herein by reference.
Number | Name | Date | Kind |
---|---|---|---|
5377354 | Scannell et al. | Dec 1994 | A |
5619648 | Canale et al. | Apr 1997 | A |
5638487 | Chigier | Jun 1997 | A |
5704017 | Heckerman et al. | Dec 1997 | A |
5805801 | Holloway et al. | Sep 1998 | A |
5835087 | Herz et al. | Nov 1998 | A |
5884033 | Duvall et al. | Mar 1999 | A |
5905859 | Holloway et al. | May 1999 | A |
6003027 | Prager | Dec 1999 | A |
6023723 | McCormick et al. | Feb 2000 | A |
6041324 | Earl et al. | Mar 2000 | A |
6047242 | Benson | Apr 2000 | A |
6052709 | Paul | Apr 2000 | A |
6072942 | Stockwell et al. | Jun 2000 | A |
6101531 | Eggleston et al. | Aug 2000 | A |
6112227 | Heiner | Aug 2000 | A |
6122657 | Hoffman, Jr. et al. | Sep 2000 | A |
6161130 | Horvitz et al. | Dec 2000 | A |
6167434 | Pang | Dec 2000 | A |
6192360 | Dumais et al. | Feb 2001 | B1 |
6199102 | Cobb | Mar 2001 | B1 |
6266692 | Greenstein | Jul 2001 | B1 |
6308273 | Goertzel et al. | Oct 2001 | B1 |
6314421 | Sharnoff et al. | Nov 2001 | B1 |
6321267 | Donaldson | Nov 2001 | B1 |
6327617 | Fawcett | Dec 2001 | B1 |
6330590 | Cotten | Dec 2001 | B1 |
6351740 | Rabinowitz | Feb 2002 | B1 |
6370526 | Agrawal et al. | Apr 2002 | B1 |
6393465 | Leeds | May 2002 | B2 |
6421709 | McCormick et al. | Jul 2002 | B1 |
6424997 | Buskirk, Jr. et al. | Jul 2002 | B1 |
6434600 | Waite et al. | Aug 2002 | B2 |
6453327 | Nielsen | Sep 2002 | B1 |
6477551 | Johnson et al. | Nov 2002 | B1 |
6484197 | Donohue | Nov 2002 | B1 |
6484261 | Wiegel | Nov 2002 | B1 |
6505250 | Freund et al. | Jan 2003 | B2 |
6546416 | Kirsch | Apr 2003 | B1 |
6592627 | Agrawal et al. | Jul 2003 | B1 |
6615242 | Riemers | Sep 2003 | B1 |
6633855 | Auvenshine | Oct 2003 | B1 |
6643686 | Hall | Nov 2003 | B1 |
6684201 | Brill | Jan 2004 | B1 |
6691156 | Drummond et al. | Feb 2004 | B1 |
6701350 | Mitchell | Mar 2004 | B1 |
6701440 | Kim et al. | Mar 2004 | B1 |
6728690 | Meek et al. | Apr 2004 | B1 |
6732149 | Kephart | May 2004 | B1 |
6732157 | Gordon et al. | May 2004 | B1 |
6732273 | Byers | May 2004 | B1 |
6742047 | Tso | May 2004 | B1 |
6748422 | Morin et al. | Jun 2004 | B2 |
6751348 | Buzuloiu et al. | Jun 2004 | B2 |
6757830 | Tarbotton et al. | Jun 2004 | B1 |
6768991 | Hearnden | Jul 2004 | B2 |
6775704 | Watson et al. | Aug 2004 | B1 |
6779021 | Bates et al. | Aug 2004 | B1 |
6785820 | Muttik | Aug 2004 | B1 |
6842773 | Ralston et al. | Jan 2005 | B1 |
6853749 | Watanabe et al. | Feb 2005 | B2 |
6915334 | Hall | Jul 2005 | B1 |
6920477 | Mitzenmacher | Jul 2005 | B2 |
6928465 | Earnest | Aug 2005 | B2 |
6971023 | Makinson et al. | Nov 2005 | B1 |
7003555 | Jungck | Feb 2006 | B1 |
7032030 | Codignotto | Apr 2006 | B1 |
7051077 | Lin | May 2006 | B2 |
7117358 | Bandini et al. | Oct 2006 | B2 |
7146402 | Kucherawy | Dec 2006 | B2 |
7155243 | Baldwin et al. | Dec 2006 | B2 |
7155484 | Malik | Dec 2006 | B2 |
7188369 | Ho et al. | Mar 2007 | B2 |
7219148 | Rounthwaite et al. | May 2007 | B2 |
7249162 | Rounthwaite et al. | Jul 2007 | B2 |
7263607 | Ingerman et al. | Aug 2007 | B2 |
7293063 | Sobel | Nov 2007 | B1 |
7320020 | Chadwick et al. | Jan 2008 | B2 |
7359941 | Doan et al. | Apr 2008 | B2 |
7366761 | Murray et al. | Apr 2008 | B2 |
20010034849 | Powers | Oct 2001 | A1 |
20010046307 | Wong | Nov 2001 | A1 |
20020016956 | Fawcett | Feb 2002 | A1 |
20020059425 | Belfiore et al. | May 2002 | A1 |
20020073157 | Newman et al. | Jun 2002 | A1 |
20020091738 | Rohrabaugh et al. | Jul 2002 | A1 |
20020124025 | Janakiraman et al. | Sep 2002 | A1 |
20020129111 | Cooper | Sep 2002 | A1 |
20020147782 | Dimitrova et al. | Oct 2002 | A1 |
20020174185 | Rawat et al. | Nov 2002 | A1 |
20020184315 | Earnest | Dec 2002 | A1 |
20020199095 | Bandini et al. | Dec 2002 | A1 |
20030009495 | Adjaoute | Jan 2003 | A1 |
20030009698 | Lindeman et al. | Jan 2003 | A1 |
20030016872 | Sun | Jan 2003 | A1 |
20030037074 | Dwork et al. | Feb 2003 | A1 |
20030041126 | Buford et al. | Feb 2003 | A1 |
20030088627 | Rothwell et al. | May 2003 | A1 |
20030149733 | Capiel | Aug 2003 | A1 |
20030167311 | Kirsch | Sep 2003 | A1 |
20030191969 | Katsikas | Oct 2003 | A1 |
20030204569 | Andrews et al. | Oct 2003 | A1 |
20030320054 | Cheng et al. | Oct 2003 | |
20030229672 | Kohn | Dec 2003 | A1 |
20040003283 | Goodman et al. | Jan 2004 | A1 |
20040015554 | Wilson | Jan 2004 | A1 |
20040019650 | Auvenshine | Jan 2004 | A1 |
20040054887 | Paulsen et al. | Mar 2004 | A1 |
20040073617 | Milliken et al. | Apr 2004 | A1 |
20040083270 | Heckerman et al. | Apr 2004 | A1 |
20040093371 | Burrows et al. | May 2004 | A1 |
20040139160 | Wallace et al. | Jul 2004 | A1 |
20040139165 | McMillan et al. | Jul 2004 | A1 |
20040148330 | Alspector et al. | Jul 2004 | A1 |
20040177120 | Kirsch | Sep 2004 | A1 |
20040199594 | Radatti et al. | Oct 2004 | A1 |
20040210640 | Chadwick et al. | Oct 2004 | A1 |
20040215977 | Goodman et al. | Oct 2004 | A1 |
20040255122 | Ingerman et al. | Dec 2004 | A1 |
20040260776 | Starbuck et al. | Dec 2004 | A1 |
20050015455 | Liu | Jan 2005 | A1 |
20050050150 | Dinkin | Mar 2005 | A1 |
20050060643 | Glass et al. | Mar 2005 | A1 |
20050076084 | Loughmiller et al. | Apr 2005 | A1 |
20050080855 | Murray | Apr 2005 | A1 |
20050080889 | Malik et al. | Apr 2005 | A1 |
20050081059 | Bandini et al. | Apr 2005 | A1 |
20050091321 | Daniell et al. | Apr 2005 | A1 |
20050097174 | Daniell | May 2005 | A1 |
20050102366 | Kirsch | May 2005 | A1 |
20050114452 | Prakash | May 2005 | A1 |
20050120019 | Rigoutsos et al. | Jun 2005 | A1 |
20050159136 | Rouse et al. | Jul 2005 | A1 |
20050160148 | Yu | Jul 2005 | A1 |
20050165895 | Rajan et al. | Jul 2005 | A1 |
20050182735 | Zager et al. | Aug 2005 | A1 |
20050188023 | Doan et al. | Aug 2005 | A1 |
20050204159 | Davis et al. | Sep 2005 | A1 |
20050228899 | Wendkos et al. | Oct 2005 | A1 |
20060031303 | Pang | Feb 2006 | A1 |
20060031306 | Haverkos | Feb 2006 | A1 |
20060036701 | Bulfer et al. | Feb 2006 | A1 |
20060123083 | Goutte et al. | Jun 2006 | A1 |
20060265498 | Turgeman et al. | Nov 2006 | A1 |
20070101423 | Oliver et al. | May 2007 | A1 |
20070130350 | Alperovitch et al. | Jun 2007 | A1 |
20070130351 | Alperovitch et al. | Jun 2007 | A1 |
20070133034 | Jindal et al. | Jun 2007 | A1 |
20080104186 | Wieneke et al. | May 2008 | A1 |
Number | Date | Country |
---|---|---|
413537 | Feb 1991 | EP |
720333 | Jul 1996 | EP |
1376427 | Mar 2003 | EP |
1376427 | Jan 2004 | EP |
1376427 | Jan 2004 | EP |
20020030704 | Apr 2002 | KR |
2127959 | Mar 1999 | RU |
9635994 | Nov 1996 | WO |
9967731 | Dec 1999 | WO |
WO9967731 | Dec 1999 | WO |
02071286 | Sep 2002 | WO |
03054764 | Jul 2003 | WO |
2004059506 | Jul 2004 | WO |
Number | Date | Country | |
---|---|---|---|
20070118904 A1 | May 2007 | US |
Number | Date | Country | |
---|---|---|---|
Parent | 10454168 | Jun 2003 | US |
Child | 11621363 | US |