WO2002017109A1 - Data tracking using ip address filtering over a wide area network - Google Patents

Data tracking using ip address filtering over a wide area network Download PDF

Info

Publication number
WO2002017109A1
WO2002017109A1 PCT/US2001/026292 US0126292W WO0217109A1 WO 2002017109 A1 WO2002017109 A1 WO 2002017109A1 US 0126292 W US0126292 W US 0126292W WO 0217109 A1 WO0217109 A1 WO 0217109A1
Authority
WO
WIPO (PCT)
Prior art keywords
visitor
node
filter
data
address
Prior art date
Application number
PCT/US2001/026292
Other languages
French (fr)
Inventor
Elijahu Shapira
Original Assignee
Netiq Corporation
Priority date (The priority date is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the date listed.)
Filing date
Publication date
Application filed by Netiq Corporation filed Critical Netiq Corporation
Priority to EP01966108A priority Critical patent/EP1323058A4/en
Priority to CA2432344A priority patent/CA2432344C/en
Priority to AU8664801A priority patent/AU8664801A/en
Publication of WO2002017109A1 publication Critical patent/WO2002017109A1/en

Links

Classifications

    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L43/00Arrangements for monitoring or testing data switching networks
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L43/00Arrangements for monitoring or testing data switching networks
    • H04L43/02Capturing of monitoring data
    • H04L43/028Capturing of monitoring data by filtering
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L67/00Network arrangements or protocols for supporting network services or applications
    • H04L67/50Network services
    • H04L67/535Tracking the activity of the user

Definitions

  • the present application relates to compiling and reporting data associated with activity on a network server and more particularly to compiling and reporting server data that is associated with commercial activity on a server using IP address filtering prior to data reporting.
  • Analyzing activity on a worldwide web server from a different location on a global computer network is also known in the art.
  • a provider of remote web-site activity analysis (“service provider”) generates JavaScript code that is distributed to each subscriber to the service. The subscriber copies the code into each web-site page that is to be monitored.
  • the JavaScript code collects information, including time of day, visitor domain, page visited, etc.
  • the code calls a server operated by the service provider — also located on the Internet — and transmits the collected information thereto. Information is also transmitted in a known manner via a cookie.
  • Each subscriber has a password to access a page on the service provider's server. This page includes a set of tables that summarize, in real time, activity on the customer's web site.
  • the present invention realizes this goal by filtering the raw activity data using information obtained from the computer requesting the information from the web server.
  • the preferred method for implementing the invention includes presetting IP filters and storing a web page on a first server coupled to a wide area network, whereby the web page including data mining code.
  • the web page would then be uploaded to a visitor computer responsive to a request over the wide area network from the visitor computer, whereby the visitor computer would have a designated IP address.
  • the data mining code would then be operated on the visitor computer to obtain technical data.
  • a subsequent step would be receiving at a second server the technical data and the IP address of the visitor computer and generating a log file incorporating the technical data and IP address.
  • the IP filters would be applied to the IP address stored in the log file and a database file would then be generated from the log file responsive to the IP filters.
  • the network for implementing the invention includes a visitor node having a browser program coupled to the network, whereby the visitor node provides requests for information on the network.
  • the network further includes a web site node having a respective web site responsive to requests for information from the visitor node to provide media content and data mining code to the visitor node.
  • the apparatus also includes a tracking node including a log file and a database. The tracking node is responsive to a communication from the visitor node based upon the data mining code to store visitor data obtained from the visitor node into the log file.
  • the apparatus network includes a filter node responsive to the visitor data based on a filter to select the visitor data for storage in a data base, whereby said data base is accessible by an owner of the web site node to view relevant traffic data to the web site node.
  • FIG. 1 is a schematic view of a network implementation for carrying out a preferred embodiment of the invention.
  • FIG. 2 is a sample order page included on a commercial web site implementing the present invention.
  • FIGs. 3 A and 3B illustrate screen shots showing examples of an administrative console user interface in which the EXCLUDE filters are set by the web site owner.
  • FIG. 4 is a flow diagram illustrating the software method operable on the data analysis server in FIG. 1 to filter the hits according to the IP addresses of the visiting computer according to a preferred embodiment of the invention.
  • FIGs. 5A and 5B show report pages illustrating site visitor information concerning the web page being tracked by a web site tracking service using the invention.
  • FIG. 1 depicts a system implementing the present invention. Included thereon is a worldwide web server 12.
  • Server 12 in the present example, is operated by a business that sells products via server 12, although the same implementation can be made for sales of services via the server.
  • the server includes a plurality of pages that describe the business and the products that are offered for sale. It also includes an order page, like the one shown in FIG. 2, that a site visitor can download to his or her computer, like computer 14, using a conventional browser program running on the computer.
  • the order form typically contains — for products — the national currency that the seller accepts, an identification of the product, the number of products sold, and the unit price for each product.
  • the visitor actuates a screen-image button 15 that places the order by transmitting the information from computer 14 to server 12 over the network.
  • server 12 typically confirms the order via email to computer 14. The seller then collects payment, using a credit-card number provided in the FIG. 2 form, and ships the product.
  • server 12 it would be advantageous to the seller to have an understanding about how customers and potential customers use server 12. As also mentioned above, it is known to obtain this understanding by analyzing web-server log files at the server that supports the selling web site. It is also known in the art to collect data over the Internet and generate activity reports at a remote server. When the owner of server 12 first decides to utilize a remote service provider to generate such reports, he or she uses a computer 16, which is equipped with a web browser, to visit a web server 18 operated by the service provider. On server 18, the subscriber opens an account and creates a format for real-time reporting of activity on server 12.
  • server 18 provides computer 16 with a small piece of code, typically JavaScript code. The subscriber simply copies and pastes this code onto each web page maintained on server 12 for which monitoring is desired.
  • the code passes predetermined information from computer 14 to a server 20 — also operated by the service provider — via the Internet. This information includes, e.g., the page viewed, the time of the view, the length of stay on the page, the visitor's identification, etc.
  • Server 20 in turn transmits this information to an analysis server 22, which is also maintained by the service provider. This server analyzes the raw data collected on server 20 and passes it to a database server 24 that the service provider also operates.
  • the subscriber uses computer 16 to access server 18, which in turn is connected to database server 24 at the service provider's location.
  • the owner can then see and print reports, sample pages of which are shown in FIGs. 5A and 5B, that provide real-time information about the activity at server 12.
  • Applicant has developed a method in which data relating to revenues, products sold, categories of products, etc., is collected, analyzed and displayed in various report formats.
  • An example of code that can be used to implement this method is shown in Appendices I and II.
  • the code in Appendices I and II is transferred from service 18 to computer 16 in a known manner.
  • the subscriber determines which pages on the server 12 web site he or she would like to track.
  • the subscriber then opens each page to be tracked a text editor, and the code from Appendix I is pasted into the bottom of the page.
  • the code in Appendix I does not provide an image on the page, it should be appreciated that code that includes an image such as a logo or the like, could be included in the Appendix I code. This would consequently both track the page and display an image thereon.
  • Appendix I code is pasted onto each page to be tracked, including an order confirmation page
  • Appendix II which defines a variable called ORDER
  • This variable appears on line 7 of the Appendix I code.
  • the variable ORDER defines the currency that is used to purchase the product.
  • the currency need only be entered once, and in the example is USD for U.S. dollars.
  • each item, of information in the ORDER variable is included for each product purchased.
  • a site visitor using computer 14 first fills in all the information in the FIG. 2 form. The visitor then clicks button 15 in FIG.
  • Appendices I and II collects this information, along with the usual data relating to traffic, visitors, visitors' systems, etc., and transmits it to service 20. This data is analyzed on server 22 as described above and stored on database 24.
  • reports that are maintained in real time, as described above, are accessed, viewed, and — if desired — printed by the subscriber. Examples of various reports are available through the webtrendslive.com reporting service, operated by the assignee of this application, that reports the following commercial activity: Revenue over Time, Revenue by Category, Revenue by Product, Units over Time, Units by Category, Units by Product, Category Sales Trends, and Product Sales Trends.
  • the account owner can define time periods during which the information can be displayed in the format shown in the enclosed reports. There is also a feature that the account owner can select to cause reports to be periodically mailed to computer 16.
  • IP addresses A conventional method for identifying computers on a network, such as the Internet, is by "Internet Protocol" or IP addresses. These addresses are currently expressed as a series of four numbers separated by periods (A.B.C.D) where each number is between 0 and 255.
  • the visitor computer 14 is identified by an IP address that is attached as a tag to all communications over the Internet (or any network using IP Addressing schema) originating from that computer.
  • all communications to visitor computer 14, as from server 12 include a destination tag referencing that computer's four-digit IP address.
  • server 12 receives the request for information from visitor computer 14, it sends the requested information back through the Internet with a destination address of the visitor computer 14.
  • the requested information from server 12 is passed through routers (not shown) that ultimately direct the information to the visitor computer having the particular destination address.
  • routers (not shown) that ultimately direct the information to the visitor computer having the particular destination address.
  • This is a common method for passing information back and forth between particular computers over a network.
  • data obtained via web site analysis tools such as those known in the prior art track all visitors to a particular web site. While this information is oftentimes useful, the data can be misleading since the number and type of visitors can be skewed when the web site owner's own employees visit the site for testing, verification or other work-related reason. Therefore, the need remains for a method and system for reporting only those visitors that may be relevant to the site owner's business.
  • the present invention operates to conduct web traffic analysis based on web site hits coming only from computers having IP addresses within specified ranges.
  • a "hit” is defined as a request by a visitor computer of a web page from a server hosting the web site that includes the requested web page. Multiple requests result in multiple hits.
  • the two types of filters are INCLUDE and EXCLUDE.
  • the INCLUDE filter will allow a hit to be counted if the IP address of the visitor computer 14 is a match against the filter.
  • the EXCLUDE filter will allow a hit to be counted if the IP address of the visitor computer 14 is not a match against the filter.
  • the EXCLUDE filter is most useful in the situation noted above where hits from a company's own employees are excluded from the web traffic analysis report. This can be accomplished because the web site owner has knowledge of the IP addresses of its employees' own computers.
  • FIGs. 3 A and 3B illustrate screen shots showing examples of an administrative console user interface in which the EXCLUDE filters are set by the web site owner.
  • the filter is specified as "E.F.G.H" where E, F, G and H can be set to: 1. Match everything (the '*' character)
  • a range specification (a number followed by a '-' character followed by another number)
  • the EXCLUDE filters are set to default so that no IP addresses are then filtered out of the compiled visitor data.
  • the IP address EXCLUDE filters are set to filter out hits originating from computers having the following IP addresses:
  • IP address filtering is only intended to represent an example of one method in which visitor's to a web site can be filtered according to their identity or originating computer address. Three other examples are expressed below:
  • a first alternate method is to use an IP address (A.B.C.D) with a subnet mask (E.F.G.H) where the incoming visitor IP address (W.X.Y.Z) is filtered according to evaluations using the binary AND (&) operator:
  • a second alternative method is to use classless inter-domain routing (CIDR), in which subnet ranges are specified.
  • CIDR classless inter-domain routing
  • the CIDR specification is documented in RFC1517, RFC1518, RFC1519, and RFC1520 using the designation A.B.C.D/M (Example: 192.168.0.0/16).
  • the IP address A.B.C.D. represents the "IP Prefix” and the M specifies the mask length. For an incoming visitor IP address to match the filter, the M number of leftmost contiguous significant bits in the "IP Prefix" and the "test" IP Address must be equal.
  • a third alternative is to use a standard pattern matching specification like Regular Expressions to match the visitor IP address.
  • the code shown in Appendix I is pasted onto each page to be tracked. As the code is downloaded with the web page by the visitor computer, the Appendix I code executes within the visitor's computer to gather available data such as the type of browser being used, URL of page being viewed, length of time viewed, etc.
  • Appendix El shows another example of the type of code that can fulfill this data mining function.
  • first two lines denote the location of the network server designated by the web site tracking service provider to store the log file information and the final two lines denote the specific data folder within the server.
  • the numbers included in the final two lines of the above code are specific to the customer/owner of the web page being tracked and are generated when the customer signs up for the service.
  • the data is transmitted to service 20 along with the IP address of the sending (visitor's) computer 14 by operation of the JavaScript code in Appendix III upon the browser program (Internet Explorer or Netscape Navigator).
  • the INCLUDE and/or EXCLUDE filters are set in step 30 using the administrative console user interface shown in FIG. 3.
  • the visitor downloads a web page containing the added JavaScript code shown in Appendix I or III.
  • the code operates within the visitor computer's browser to obtain and then transmit specified information to server 20 operated by the web tracking service to which is appended the IP address of the sending (visitor's) computer 14.
  • the IP address is retrieved by the visitor's computer web browser in step 34 and transmitted to the service provider server 20 in step 36.
  • the retrieved information, including the IP address are stripped out and stored within a log file generated on server 20 in step 40.
  • the IP filtering step is then conducted on the log files using software operable on analysis server 22.
  • An example of software operable on the data analysis server 22 to filter the hits according to the IP addresses of the visiting computer 14 is shown in Appendix IV and is represented by box 42 of FIG. 4.
  • Step 44 queries whether the data within the log file originated from a visitor computer having an IP address specified within the INCLUDE filter list. If the IP address is on the list (or if no filter is specified thus defaulting to a "YES" condition), then the filtering process proceeds to step 46.
  • Step 46 queries whether the data within the log file originated from a visitor computer having an IP address specified within the EXCLUDE filter list.
  • step 48 the filtering process proceeds to step 48 in which the database files stored within database 24 are updated to reflect the new information. If the IP address is either not on the INCLUDE list or is on the EXCLUDE, then the log file is ignored and the database is not updated.
  • the database files may be queried by a customer (step 50) in real time by logging onto the web traffic reporting server 18 as described above.
  • FIGs. 5A and 5B show report pages illustrating site visitor information to the web page being tracked.
  • FIG. 5A illustrates site visitors in which no IP EXCLUDE filters were designated, as shown in FIG. 3A.
  • FIG. 5B illustrates the number of site visitors by hour in which hits originating from computers having IP addresses as designated in FIG. 3B have been excluded from the report. Assuming that the IP addresses set in FIG. 3B represent computers used by the web site owner's own employees, it is understood that the filtered data shown in FIG. 5B represents a more accurate view of the effective traffic at the web site as a measure of popularity.
  • ORDER ORDER + product (i) & ",” & category (i) >> & ",” & number_sold(i) & “,” & unit_price (i) >>
  • This class object stores (as part of it) the data for the configured filters.
  • This function reads from the database the configured filters and parse it out for use later.
  • rc pGlobalDB->ExecDirect( hstmt, "SELECT DBLocation, SiteVer, timezone, sitecategory, sitesubcategory, homepage, firstaccess, includefilter, excludefilter "
  • node.end[n] node.start[n];
  • node.end[n] node.start[n];
  • This function is run on every hit and the filter logic is executed to determine if this hit should be counted.

Landscapes

  • Engineering & Computer Science (AREA)
  • Computer Networks & Wireless Communication (AREA)
  • Signal Processing (AREA)
  • Computer Hardware Design (AREA)
  • General Engineering & Computer Science (AREA)
  • Information Transfer Between Computers (AREA)
  • Data Exchanges In Wide-Area Networks (AREA)
  • Computer And Data Communications (AREA)

Abstract

The preferred method for implementing the invention includes presetting IP filters and storing a web page on a first server (12) coupled to a wide area network, whereby the web page including data mining code. The web page would then be uploaded to a visitor computer (14) responsive to a request over the wide area network from the visitor computer, whereby the visitor computer would have a designated IP address. The data mining code would then be operated on the visitor computer to obtain technical data. A subsequent step would be receiving at a second server the technical data and the IP address of the visitor computer and generating a log file incorporating the technical data and IP address. The IP filters would be applied to the IP address stored in the log file and a database file would then be generated from the log file responsive to the IP filters.

Description

DATA TRACKING USING IP ADDRESS FILTERING ONER A WIDE AREA NETWORK
BACKGROUND OF THE INVENTION
1. Field of the Invention.
The present application relates to compiling and reporting data associated with activity on a network server and more particularly to compiling and reporting server data that is associated with commercial activity on a server using IP address filtering prior to data reporting.
2. Description of the Prior Art.
Programs for analyzing traffic on a network server, such as a worldwide web server, are known in the art. One such prior art program is described in U.S. Patent Application No. 09/240,208, filed January 29, 1999, for a Method and Apparatus for Evaluating Nisitors to a Web Server, which is incorporated herein by reference for all purposes and is assigned in common with the present application. In these prior art systems, the program typically runs on the web server that is being monitored. Data is compiled, and reports are generated on deman — or are delivered from time to time via email — to display information about web server activity, such as the most popular page by number of visits, peak hours of website activity, most popular entry page, etc.
Analyzing activity on a worldwide web server from a different location on a global computer network ("Internet") is also known in the art. To do so, a provider of remote web-site activity analysis ("service provider") generates JavaScript code that is distributed to each subscriber to the service. The subscriber copies the code into each web-site page that is to be monitored. When a visitor to the subscriber's web site loads one of the web-site pages into his or her computer, the JavaScript code collects information, including time of day, visitor domain, page visited, etc. The code then calls a server operated by the service provider — also located on the Internet — and transmits the collected information thereto. Information is also transmitted in a known manner via a cookie. Each subscriber has a password to access a page on the service provider's server. This page includes a set of tables that summarize, in real time, activity on the customer's web site.
It is understood that not all activity on a web site is commercial or potentially commercial in nature. Instead, some visitors to the web site might be the web site owner's own employees that are only testing the operation of the web site. Such traffic is not important to the commercial success of the web page since such visitors have no intention of buying anything on the web site. Accordingly, the need arises for somehow obtaining a more accurate representation of commercial activity on a web server by only reporting activity on the web site from actual or potential customers.
SUMMARY OF THE INVENTION The present invention realizes this goal by filtering the raw activity data using information obtained from the computer requesting the information from the web server.
The preferred method for implementing the invention includes presetting IP filters and storing a web page on a first server coupled to a wide area network, whereby the web page including data mining code. The web page would then be uploaded to a visitor computer responsive to a request over the wide area network from the visitor computer, whereby the visitor computer would have a designated IP address. The data mining code would then be operated on the visitor computer to obtain technical data. A subsequent step would be receiving at a second server the technical data and the IP address of the visitor computer and generating a log file incorporating the technical data and IP address. The IP filters would be applied to the IP address stored in the log file and a database file would then be generated from the log file responsive to the IP filters.
The network for implementing the invention includes a visitor node having a browser program coupled to the network, whereby the visitor node provides requests for information on the network. The network further includes a web site node having a respective web site responsive to requests for information from the visitor node to provide media content and data mining code to the visitor node. The apparatus also includes a tracking node including a log file and a database. The tracking node is responsive to a communication from the visitor node based upon the data mining code to store visitor data obtained from the visitor node into the log file. Finally, the apparatus network includes a filter node responsive to the visitor data based on a filter to select the visitor data for storage in a data base, whereby said data base is accessible by an owner of the web site node to view relevant traffic data to the web site node.
The foregoing and other objects, features and advantages of the invention will become more readily apparent from the following detailed description of a preferred embodiment of the invention that proceeds with reference to the accompanying drawings.
BRIEF DESCRIPTION OF THE DRAWINGS FIG. 1 is a schematic view of a network implementation for carrying out a preferred embodiment of the invention.
FIG. 2 is a sample order page included on a commercial web site implementing the present invention.
FIGs. 3 A and 3B illustrate screen shots showing examples of an administrative console user interface in which the EXCLUDE filters are set by the web site owner.
FIG. 4 is a flow diagram illustrating the software method operable on the data analysis server in FIG. 1 to filter the hits according to the IP addresses of the visiting computer according to a preferred embodiment of the invention. FIGs. 5A and 5B show report pages illustrating site visitor information concerning the web page being tracked by a web site tracking service using the invention.
APPENDICES I through IV illustrate a preferred source code method for implementing the invention. DETAILED DESCRIPTION OF THE PREFERRED EMBODIMENT Turning now to FIG. 1, indicated generally at 10 is a highly schematic view of a portion of the Internet. FIG. 1 depicts a system implementing the present invention. Included thereon is a worldwide web server 12. Server 12, in the present example, is operated by a business that sells products via server 12, although the same implementation can be made for sales of services via the server. The server includes a plurality of pages that describe the business and the products that are offered for sale. It also includes an order page, like the one shown in FIG. 2, that a site visitor can download to his or her computer, like computer 14, using a conventional browser program running on the computer. The order form typically contains — for products — the national currency that the seller accepts, an identification of the product, the number of products sold, and the unit price for each product. After a site visitor at computer 14 fills in the information in FIG. 2, the visitor actuates a screen-image button 15 that places the order by transmitting the information from computer 14 to server 12 over the network. Upon receipt of this information, server 12 typically confirms the order via email to computer 14. The seller then collects payment, using a credit-card number provided in the FIG. 2 form, and ships the product.
As mentioned above, it would be advantageous to the seller to have an understanding about how customers and potential customers use server 12. As also mentioned above, it is known to obtain this understanding by analyzing web-server log files at the server that supports the selling web site. It is also known in the art to collect data over the Internet and generate activity reports at a remote server. When the owner of server 12 first decides to utilize a remote service provider to generate such reports, he or she uses a computer 16, which is equipped with a web browser, to visit a web server 18 operated by the service provider. On server 18, the subscriber opens an account and creates a format for real-time reporting of activity on server 12.
To generate such reporting, server 18 provides computer 16 with a small piece of code, typically JavaScript code. The subscriber simply copies and pastes this code onto each web page maintained on server 12 for which monitoring is desired. When a visitor from computer 14 loads one of the web pages having the embedded code therein, the code passes predetermined information from computer 14 to a server 20 — also operated by the service provider — via the Internet. This information includes, e.g., the page viewed, the time of the view, the length of stay on the page, the visitor's identification, etc. Server 20 in turn transmits this information to an analysis server 22, which is also maintained by the service provider. This server analyzes the raw data collected on server 20 and passes it to a database server 24 that the service provider also operates.
When the subscriber would like to see and print real-time statistics, the subscriber uses computer 16 to access server 18, which in turn is connected to database server 24 at the service provider's location. The owner can then see and print reports, sample pages of which are shown in FIGs. 5A and 5B, that provide real-time information about the activity at server 12.
The above-described arrangement for monitoring web server activity by a service provider over the Internet is generally known in the art. Information analyzed in prior art systems, however, consists of what might be thought of as technical data, such as most popular pages, referring URLs, total number of visitors, returning visitors, etc. As will now be explained, applicant has developed the ability to analyze commercial data as well, e.g., number of orders, total revenues, etc., generated by server 18, as explained in detail below.
Applicant has developed a method in which data relating to revenues, products sold, categories of products, etc., is collected, analyzed and displayed in various report formats. An example of code that can be used to implement this method is shown in Appendices I and II. When the subscriber opens an account with the service provider by connecting computer 16 to server 18, as described above, the code in Appendices I and II is transferred from service 18 to computer 16 in a known manner. The subscriber then determines which pages on the server 12 web site he or she would like to track. The subscriber then opens each page to be tracked a text editor, and the code from Appendix I is pasted into the bottom of the page. Although the code in Appendix I does not provide an image on the page, it should be appreciated that code that includes an image such as a logo or the like, could be included in the Appendix I code. This would consequently both track the page and display an image thereon.
After the Appendix I code is pasted onto each page to be tracked, including an order confirmation page, the code in Appendix II, which defines a variable called ORDER, is also pasted onto the order confirmation page. This variable appears on line 7 of the Appendix I code.
The variable ORDER, among other things, defines the currency that is used to purchase the product. The currency need only be entered once, and in the example is USD for U.S. dollars. There are four other items that are included in the variable for each product ordered. In the order appearing in the variable they are first, the product name; second, the category that the product is in; third, the number of products purchased; and fourth, the unit price for the product. As can be seen in the Appendix II code, each item, of information in the ORDER variable is included for each product purchased. In operation, a site visitor using computer 14 first fills in all the information in the FIG. 2 form. The visitor then clicks button 15 in FIG. 2, and an order confirmation page (not shown) appears that includes the product, category, number, and unit price information, for each product ordered. The code in Appendices I and II collects this information, along with the usual data relating to traffic, visitors, visitors' systems, etc., and transmits it to service 20. This data is analyzed on server 22 as described above and stored on database 24.
When the business owner operating the website on server 12 wants to determine activity on that site, he or she logs onto his or her account on web server 18 via computer 16. After entering the appropriate user name and password, reports that are maintained in real time, as described above, are accessed, viewed, and — if desired — printed by the subscriber. Examples of various reports are available through the webtrendslive.com reporting service, operated by the assignee of this application, that reports the following commercial activity: Revenue over Time, Revenue by Category, Revenue by Product, Units over Time, Units by Category, Units by Product, Category Sales Trends, and Product Sales Trends. In addition to viewing the reports that are maintained in real time, the account owner can define time periods during which the information can be displayed in the format shown in the enclosed reports. There is also a feature that the account owner can select to cause reports to be periodically mailed to computer 16.
IP ADDRESS FILTERING
It is understood that not all activity on a web site is commercial or potentially commercial in nature. Instead, some visitors to the web site might be the web site owner's own employees that are only testing the operation of the web site. Such traffic is not important to the commercial success of the web page since such visitors have no intention of buying anything on the web site. Accordingly, one aspect of obtaining a more accurate representation of commercial activity on a web server is only reporting activity on the web site from actual or potential customers. The present invention realizes this goal by filtering the raw activity data using information obtained from the computer requesting the information from the web server.
A conventional method for identifying computers on a network, such as the Internet, is by "Internet Protocol" or IP addresses. These addresses are currently expressed as a series of four numbers separated by periods (A.B.C.D) where each number is between 0 and 255. In FIG. 1, for instance, the visitor computer 14 is identified by an IP address that is attached as a tag to all communications over the Internet (or any network using IP Addressing schema) originating from that computer. Similarly, all communications to visitor computer 14, as from server 12, include a destination tag referencing that computer's four-digit IP address. When server 12 receives the request for information from visitor computer 14, it sends the requested information back through the Internet with a destination address of the visitor computer 14. The requested information from server 12 is passed through routers (not shown) that ultimately direct the information to the visitor computer having the particular destination address. This is a common method for passing information back and forth between particular computers over a network. Currently, data obtained via web site analysis tools such as those known in the prior art track all visitors to a particular web site. While this information is oftentimes useful, the data can be misleading since the number and type of visitors can be skewed when the web site owner's own employees visit the site for testing, verification or other work-related reason. Therefore, the need remains for a method and system for reporting only those visitors that may be relevant to the site owner's business.
The present invention operates to conduct web traffic analysis based on web site hits coming only from computers having IP addresses within specified ranges. A "hit" is defined as a request by a visitor computer of a web page from a server hosting the web site that includes the requested web page. Multiple requests result in multiple hits.
The two types of filters are INCLUDE and EXCLUDE. The INCLUDE filter will allow a hit to be counted if the IP address of the visitor computer 14 is a match against the filter. The EXCLUDE filter will allow a hit to be counted if the IP address of the visitor computer 14 is not a match against the filter. The EXCLUDE filter is most useful in the situation noted above where hits from a company's own employees are excluded from the web traffic analysis report. This can be accomplished because the web site owner has knowledge of the IP addresses of its employees' own computers.
FIGs. 3 A and 3B illustrate screen shots showing examples of an administrative console user interface in which the EXCLUDE filters are set by the web site owner. The filter is specified as "E.F.G.H" where E, F, G and H can be set to: 1. Match everything (the '*' character)
2. Match only a particular number (e.g., a designated number between 0 and 255)
3. A range specification (a number followed by a '-' character followed by another number) In FIG. 3 A, the EXCLUDE filters are set to default so that no IP addresses are then filtered out of the compiled visitor data. In FIG. 3B, however, the IP address EXCLUDE filters are set to filter out hits originating from computers having the following IP addresses:
1. The computer having the IP address 206.58.83.2
2. Any computer having an IP address where the first three numbers are, in order, 192.168.83;
3. Any computer having an IP address where the first two numbers are, in order, 206.58; and
4. Any computer having the first three numbers of their IP addresses as "100.100.83" and the final number within the range of 1 and 100. Note that the first filter is a subset of the third filter since the third filter would necessarily operate to exclude the computer having the IP address "206.58.83.2". The IP address filtering above is only intended to represent an example of one method in which visitor's to a web site can be filtered according to their identity or originating computer address. Three other examples are expressed below:
A first alternate method is to use an IP address (A.B.C.D) with a subnet mask (E.F.G.H) where the incoming visitor IP address (W.X.Y.Z) is filtered according to evaluations using the binary AND (&) operator:
W & E = A X & F = B
Y & G = C Z & H = D A match occurs if all four equations are true.
A second alternative method is to use classless inter-domain routing (CIDR), in which subnet ranges are specified. The CIDR specification is documented in RFC1517, RFC1518, RFC1519, and RFC1520 using the designation A.B.C.D/M (Example: 192.168.0.0/16). The IP address A.B.C.D. represents the "IP Prefix" and the M specifies the mask length. For an incoming visitor IP address to match the filter, the M number of leftmost contiguous significant bits in the "IP Prefix" and the "test" IP Address must be equal. A third alternative is to use a standard pattern matching specification like Regular Expressions to match the visitor IP address.
As explained above with reference to commercial transaction reporting, the code shown in Appendix I is pasted onto each page to be tracked. As the code is downloaded with the web page by the visitor computer, the Appendix I code executes within the visitor's computer to gather available data such as the type of browser being used, URL of page being viewed, length of time viewed, etc.
Appendix El shows another example of the type of code that can fulfill this data mining function. Once the data is collected by operation of the JavaScript code within the visitor computer's web browser, the data is transmitted over the Internet to service 20. An example of the location of the service to which the data is transmitted, and the data folder into which the log file is written, is identified within the code of Appendix HI:
v+= ' http: //stats.webtrendslive.com/S005-00-5- 18-2994-11462/scripts/wttagv2.cgi? sid=005-00-5-18-2994-11462&siteID=11462& tagver=2&tz=-800&ed=ecommerce&button=& ' ;
where the first two lines denote the location of the network server designated by the web site tracking service provider to store the log file information and the final two lines denote the specific data folder within the server. The numbers included in the final two lines of the above code are specific to the customer/owner of the web page being tracked and are generated when the customer signs up for the service. The data is transmitted to service 20 along with the IP address of the sending (visitor's) computer 14 by operation of the JavaScript code in Appendix III upon the browser program (Internet Explorer or Netscape Navigator).
Attention is now directed to the flow diagram shown in FIG. 4 illustrating the operation of the invention. The INCLUDE and/or EXCLUDE filters are set in step 30 using the administrative console user interface shown in FIG. 3. In step 32, the visitor downloads a web page containing the added JavaScript code shown in Appendix I or III. The code operates within the visitor computer's browser to obtain and then transmit specified information to server 20 operated by the web tracking service to which is appended the IP address of the sending (visitor's) computer 14. The IP address is retrieved by the visitor's computer web browser in step 34 and transmitted to the service provider server 20 in step 36. The retrieved information, including the IP address, are stripped out and stored within a log file generated on server 20 in step 40.
The IP filtering step is then conducted on the log files using software operable on analysis server 22. An example of software operable on the data analysis server 22 to filter the hits according to the IP addresses of the visiting computer 14 is shown in Appendix IV and is represented by box 42 of FIG. 4. Step 44 then queries whether the data within the log file originated from a visitor computer having an IP address specified within the INCLUDE filter list. If the IP address is on the list (or if no filter is specified thus defaulting to a "YES" condition), then the filtering process proceeds to step 46. Step 46 then queries whether the data within the log file originated from a visitor computer having an IP address specified within the EXCLUDE filter list. If the IP address is not on the list (or if no filter is specified thus defaulting to a "NO" condition), then the filtering process proceeds to step 48 in which the database files stored within database 24 are updated to reflect the new information. If the IP address is either not on the INCLUDE list or is on the EXCLUDE, then the log file is ignored and the database is not updated. The database files may be queried by a customer (step 50) in real time by logging onto the web traffic reporting server 18 as described above.
FIGs. 5A and 5B show report pages illustrating site visitor information to the web page being tracked. FIG. 5A illustrates site visitors in which no IP EXCLUDE filters were designated, as shown in FIG. 3A. FIG. 5B, on the other hand, illustrates the number of site visitors by hour in which hits originating from computers having IP addresses as designated in FIG. 3B have been excluded from the report. Assuming that the IP addresses set in FIG. 3B represent computers used by the web site owner's own employees, it is understood that the filtered data shown in FIG. 5B represents a more accurate view of the effective traffic at the web site as a measure of popularity. Having described and illustrated the principles of the invention in a preferred embodiment thereof, it should be apparent that the invention can be modified in arrangement and detail without departing from such principles. I claim all modifications and variation coming within the spirit and scope of the following claims.
APPENDIX I
<! — Copyright 1999 WebTrends Corporation — >
<! — http://www.webtrends.com — >
<! — Modification of this code is not allowed and will permanently disable your account — >
4 <script language- ' JavaScriρtl.2"> 5: <!— 6 var code = "";
7 var ORDER = "<% ORDER %>" var SERVER = "";
8: var title = escape(document.title);
9: var url = window.document.URL;
10 var orderstr = escape(order);
11 var get = "http://stats.webtrendslive.com/scripts/enterprise.cgi";
12 get += "?sid=000-99-9-7-27-7349&siteID=232";
13 get += "&tifle=" + title + "&url=" + url;
16 document.write("<" + "script src- " + get + '"></script>");
17 IX>
18 </scriρt>
19 <script language- ' JavaScriptl.2">
20 document.write(code);
21 document.write("<" + "! — "); </script>
22 <img src- 'http ://stats.webtrendslive.com/scripts/enterprise3.cgi?sid=000- 99-9-7-27-
23: 7349&siteID=232&url=">
24: <script language- ' JavaScriptl.2">
25: document.write(" — " + ">");
26: </script> 27: <noscript>
28: <img src="http://stats.webtrendslive.com/scripts/enterprise3.cgi?sid=000-
99-9-7-27-29: 7349&siteID=232&url=*'>
30: </noscriρt>
31: <! — End of WebTrends Counter insertion — >
APPENDIXII
<%
ORDER = "Dl; " FOR i = 0 to UBOUND (orders)
ORDER = ORDER + product (i) & "," & category (i) >> & "," & number_sold(i) & "," & unit_price (i) >>
& " ; "
NEXT %>
('>>' indicates line continues)
APPENDIX III
<!-- START OF WEBTRENDS LIVE TAG INSERTION --> <!-- Copyright 1999-2000 WebTrends Corporation ->
<!-- Visit our corporate website at http://www.webtrends.com --> <!-- Visit our Webtrends Live website at http://www.webtrendslive.com --> <!-- eCommerce Revenue Tracking (patent pending) --> <SCRIPT LANGUAGE="JavaScriptl.l"> var ORDER= ""; var SERVER= ""; var CONTENTGROUP= "";
// You may customize the values of the above three variables to suit your website. // Simply insert your own values between the double-quotes.
// The lines below show some examples:
// var ORDER= "D2,Business to Consumer,Pocket FM Radio,Audio
Products,10,499.99;";
// var SERVER= "Name of this web server"; // var CONTENTGROUP = "Content group name for this page";
</SCRIPT>
<!— Modification of this code is not allowed and will permanently disable your account!
>
<SCRIPT LANGUAGE="JavaScriptl.l"> v = '<' + 'SCRIPT SRC-'"; v+= 'http://stats.webtrendslive.com/S005-00-5-l 8-2994-
11462/scripts/wttagv2.cgi?sid=005-00-5-l 8-2994-11462&siteID=l 1462&tagver=2&tz=- 800&ed=ecommerce&button=&'; v+= 'order=' + escape(ORDER) + '&'; v+= 'server=' + escape(SERVER) + '&'; v+= 'url- + escape(window.document.URL) + '&'; v+= 'ref=' + escape(window.document.referrer) + '&'; v+= 'title=' + escape(document.title) + '&'; v+= »» + ->- + -<- + y + 'SCRIPT' + '>'; document.write( v); </SCRIPT> <NOSCRIPT>
<MG SRC="http://stats.webtrendslive.com S005-00-5-18-2994- 11462/scripts/wttagv2_ns.cgi?uid=005-00-5-l 8-2994-
11462&siteID=11462&tagveι-=2&tz=-800&ed=ecommerce&button=&javaOk=No"> </NOSCRJJPT>
<!- END OF WEBTRENDS LIVE TAG INSERTION --> APPENDIX IV
This class object stores (as part of it) the data for the configured filters.
class CLogStats
{ public:
CLogStatsO;
~CLogStats(); public: enum ENUM_STATE
{
ENUM_UNUSED= 0,
ENUM_ANALYZE= 1, ENUM_ANALYZE_BUSY= 2,
ENUM_DATABASE= 3, ENUM_DATABASE_BUSY= 4,
}; public:
ENUM_STATE fuiuse;
DWORD dwStartTick; DWORD dwCountTick;
char szLogfile[MAX_PATH]; unsigned int nLogfile_size; unsigned int nLogfile_read; FILETIME ftCreateOn; char szComment[MAX_PATH]; DWORD dwSiteCountTick; int nHits; int nDNSBlanks; int nDNSResolved; int nDNSUnresolved; FILETIME ftFirstHit; public: char szDsn[MAX_PATH]; public: int nUid; int nSiteld;
int nTimeZone; char szCategory[100]; char szSubCategory[100]; char szLast Access [20]; char szHomePage[100]; public: char szIncludeFilter[400]; char szExcludeFilter[400]; struct IPFILTER
{ public: unsigned int start[4]; unsigned int end[4]; public:
IPFILTERO
{ memset( start, 0, sizeof(start)); memset( end, 0, sizeof(end));
}
}; std: :list< IPFILTER> listExcludeFilter; std::list< IPFILTER> listlncludeFilter; public: char szDBLocation[100]; char szSiteVer[100]; public:
Table* pdb;
Table* pGlobalDB; public:
SiteTables* pSiteTables;
GlobalTables* pGlobalTables; public:
DWORD dwGlobalStartTick; public:
CLogStats* pNode_Global;
};
This function reads from the database the configured filters and parse it out for use later.
int CheckSiteId( Table* pGlobalDB, CLogStats* pSite) { if( pGlobalDB->hdbc)
{
TableStmt hstmt( pGlobalDB->hdbc); int re;
//rc= db.ExecDirect( hstmt, "SELECT timezone, sitecategory, sitesubcategory, homepage, firstaccess FROM SiteSettings WHERE siteid=%u", pSite-
>nSiteId); rc= pGlobalDB->ExecDirect( hstmt, "SELECT DBLocation, SiteVer, timezone, sitecategory, sitesubcategory, homepage, firstaccess, includefilter, excludefilter "
"FROM PageCounterSites "
"WHERE siteid=%u", pSite->nSiteId); if( rc== SQL_SUCCESS)
{ char szFirstAccess[100]= ""; pSite->nTimeZone= 0; pSite->szCategory[0]= 0; pSite->szSubCategory[0]= 0; pSite->sz_EJomePage[0]= 0; pSite->szIncludeFilter[0]= 0; pSite->szExcludeFilter[0]= 0;
SDWORD nLen[30]; int nCol= 0;
nLen[nCol]= 0; rc= SQLBindCol( hstmt, nCol+1 , SQL_C_CHAR, &pSite-
>szDBLocation, sizeof(pSite->szDBLocation), &nLen[nCol]); nCol++; nLen[nCol]= 0; rc= SQLBindCol( hstmt, nCol+1, SQL_C_CHAR, &pSite- >szSiteVer, sizeof(pSite->szSiteVer), &nLen[nCol]); nCol++;
nLen[nCol]= 0; rc= SQLBindCol( hstmt, nCol+1, SQL_C_LONG, &pSite- >nTimeZone, sizeof(pSite->nTimeZone), &nLen[nCol]); nCol++;
nLen[nCol]= SQL_NTS; rc= SQLBindCol( hstmt, nCol+1, SQL_C_CHAR, (void*) &pSite- >szCategory, sizeof(pSite->szCategory), &nLen[nCol]); nCol++;
nLen[nCol]= SQL_NTS; rc= SQLBindCol( hstmt, nCol+1, SQL_C_CHAR, (void*) &pSite- >szSubCategory, sizeof(pSite->szSubCategory), &nLen[nCol]); nCol++;
nLen[nCol]= SQL_NTS; rc= SQLBindCol( hstmt, nCol+1, SQL_C_CHAR, (void*) &ρSite- >szHomePage, sizeof(pSite->szHomePage), &nLen[nCol]); nCol++;
nLen[nCol]= SQL_NTS; rc= SQLBindCol( hstmt, nCol+1, SQL_C_CHAR, szFirstAccess, sizeof(szFirstAccess), &nLen[nCol]); nCol++;
nLen[nCol]= SQL_NTS; rc= SQLBindCol( hstmt, nCol+1, SQL_C_CHAR, pSite- >szrncludeFilter, sizeof(pSite->szlhcludeFilter), &nLen[nCol]); nCol++;
nLen[nCol]= SQL_NTS; rc= SQLBindCol( hstmt, nCol+1, SQL_C_CHAR, pSite- >szExcludeFilter, sizeof(pSite->szExcludeFilter), &nLen[nCol]); nCol++;
rc= SQLFetch( hstmt); if( rc== SQL_SUCCESS || rc== SQL_SUCCESS_WITH_INFO)
{ //—=== ===
// Parse out the Include Filter if( ρSite->szhιcludeFilter[0])
{ pSite->listIncludeFilter.clear(); 5
CLogStats: :IPFILTER node; int n= 0; char* p= pSite->szIncludeFilter; 10 while( p && p[0])
{ if(p[0]= '*')
{ node.start[n]= 0;
15 node.end[n]= 255; n++; p++;
} 20 else
{ node.start[n]= atoi( p); p+= strspn( p, "0123456789");
25 if( p[0]= "-')
{
P++; node.end[n]= atoi( p); 30 ρ+= strspn( p, "0123456789");
} else
{ node.end[n]= node.start[n];
35 } n++;
} if(p[0]= '.')
40 { p++;
} else
{
45 if( n== 4)
{ pSite- >listIncludeFilter.push_back( node);
}
} if( n>= = 4) { p+= strcspn( p, "; "); p+= strspn( p, "; "); n= 0;
}
}
}
II—
// Parse out the Exclude Filter if( pSite->szExcludeFilter[0])
{ pSite->listExcludeFilter.clear();
CLogStats: :ff FILTER node; int n= 0; char* p= pSite->szExcludeFilter; while( p && p[0])
{ if( p[0]= '*')
{ node.start[n]= 0; node.end[n]= 255; n++;
P++;
} else
{ node.start[n]= atoi( p); p+= strspn( p, "0123456789"); if( p[0]= '-')
{ p++; node.end[n]= atoi( p); p+= strspn( p, "0123456789");
} else
{ node.end[n]= node.start[n];
} n++;
} if( p[0]= '.")
{
P++; } else { if( n= 4)
{ pSite-
>listExcludeFilter.push_back( node); }
} if( n>= 4)
{ p+= strcspn( p, "; "); p+= strsρn( p, "; "); n= 0;
} }
}
if( !szFirstAccess[0])
{
TableStmt hstmt( pGlobalDB->hdbc); rc= pGlobalDB->ExecDirect( hstmt,
"UPDATE [PageCounterSites] SET [firstaccess]=GETDATE() WHERE siteid=%u", ρSite->nSiteId, 0); }
//= strlwr( pSite->szDBLocation); if( l)
{ std::map< std::string, std::string>: iterator i; i= gGlobalSettings.zSiteDsn.find( pSite-
>szDBLocation); if( i!= gGlobalSettings.zSiteDsn.endO)
{ strcpy( pSite->szDsn, (*i).second.c_str()); return 0;
} //= dρrintf( "DSN '%s' not foundVvn", pSite->szDBLocation);
} else { dprintf( "CheckSiteld fetch failed with rc=%u\r\n", re);
}
} else { dprintf( "CheckSiteld failed with rc=%u, msg=%s\r\n", re, pGlobalDB->szErrorMsg);
} } pSite->nSiteId= -l; return -1;
}
This function is run on every hit and the filter logic is executed to determine if this hit should be counted.
int SiteCount( Table* pdb, Table* pGlobalDB, CLogStats* pStats, CLogEntry* pLogEntry) {
DWORD dwStartTick= GetTickCountQ; // Make sure we look at tags for the right version! if( atoi( pLogEntry->pTagNersion)!= 1)
{
DWORD dwElapsed= GetTickCount() - dwStartTick; pStats->dwSiteCountTick+= dwElapsed; return 0;
int id;
//=
// Check Include Filters if( 1)
{ if( pStats->listlhcludeFilter.size())
{ unsigned long 1; unsigned char* p= (unsigned char*) &1;
1= inet_addr( pLogEntry->pHost); std::list< CLogStats: :IPFILTER>: iterator i; for( i= pStats->listhιcludeFilter.begin(); i!= pStats-
>listlhcludeFilter.end(); i++)
{
CLogStats: :IPFILTER& n= (*i); if( p[0]>= n.start[0] && p[0]<= n.end[0] && p[l]>= n.start[l] && p[l]<= n.end[l] && p[2]>= n.start[2] && p[2]<= n.end[2] && p[3]>= n.start[3] && p[3]<= n.end[3]
) break;
} if( i= pStats->listIhcludeFilter.end())
{
. DWORD dwElapsed= GetTickCount() - dwStartTick; pStats->dwSiteCountTick+= dwElapsed; return 0;
}
//= // Check Exclude Filters if( l)
{ if( pStats->listExcludeFilter.size())
{ unsigned long 1; unsigned char* p= (unsigned char*) &1; 1= inet_addr( pLogEntry->pHost); std::list< CLogStats: :IPFILTER>::iterator i; for( i= pStats->listExcludeFilter.begin(); i!= pStats- >listExcludeFilter.end(); i++) {
CLogStats: :IPFILTER& n= (*i); if(p[0]>= n.start[0] && p[0]<= n.end[0] && p[l]>= n.start[l] && p[l]<= n.end[l] && p[2]>= n.start[2] && p[2]<= n.end[2] && p[3]>= n.start[3] && p[3]<= n.end[3]
) break;
} if( i!= pStats->listExcludeFilter.end())
{
DWORD dwElapsed= GetTickCount() - dwStartTick; pStats->dwSiteCountTick+= dwElapsed; retuni 0;
}
//=
DWORD dwTick= GetTickCount();
//—===—==== ρStats->nHits++;

Claims

I claim:
1. A method for generating web traffic reports comprising the steps of: presetting IP filters; storing a web page on a first server coupled to a wide area network, said web page including data mining code; uploading the web page to a visitor computer responsive to a request over the wide area network from the visitor computer, said visitor computer having a designated IP address; operating the data mining code on the visitor computer to obtain technical data; receiving at a second server the technical data and the IP address of the visitor computer and generating a log file incorporating the technical data and IP address; applying the IP filters to the IP address stored in the log file; and generating a database file from the log file responsive to the IP filters.
2. The method of claim 1, wherein the step of presetting IP filters includes setting an INCLUDE IP filter.
3. The method of claim 1, wherein the step of presetting IP filters includes setting an EXCLUDE filter.
4. The method of claim 1, wherein the step of applying the IP filters to the IP addresses includes the step of using classless inter-domain routing.
5. The method of claim 1 , wherein the step of applying the IP filters to the IP addresses includes the step of using standard pattern matching specifications like Regular Expressions.
6. The method of claim 1 further including the steps of: defining a subnet mask; and filtering the IP addresses using the subnet mask with a binary AND operator.
7. A network comprising: a visitor node having a browser program coupled to said network, said visitor node providing requests for information on said network; a web site node having a respective web site responsive to requests for information from said visitor node to provide media content and data mining code to said visitor node; a tracking node including a log file and a database, said tracking node responsive to a communication from said visitor node based upon said data mining code to store visitor data obtained from said visitor node into said log file; and a filter node responsive to said visitor data based on a filter to select said visitor data for storage in a database, whereby said database is accessible by an owner of said web site node to view relevant traffic data to the web site node.
8. A network in accordance with claim 7, wherein said filter node selects said visitor data based on whether the visitor data is included within the filter.
9. A network in accordance with claim 7, wherein said filter node selects said visitor data based on whether the visitor data is excluded from the filter.
10. A network in accordance with claim 7, wherein said filter is an IP address filter.
11. A network in accordance with claim 7, wherein said filter is a subnet mask applied to an IP address of the visitor node using an AND operator.
12. A network in accordance with claim 7, wherein said filter uses classless inter-domain routing.
13. A network in accordance with claim 7, wherein said filter uses standard pattern matching specifications like Regular Expressions.
PCT/US2001/026292 2000-08-21 2001-08-21 Data tracking using ip address filtering over a wide area network WO2002017109A1 (en)

Priority Applications (3)

Application Number Priority Date Filing Date Title
EP01966108A EP1323058A4 (en) 2000-08-21 2001-08-21 Data tracking using ip address filtering over a wide area network
CA2432344A CA2432344C (en) 2000-08-21 2001-08-21 Data tracking using ip address filtering over a wide area network
AU8664801A AU8664801A (en) 2000-08-21 2001-08-21 Data tracking using ip address filtering over a wide area network

Applications Claiming Priority (2)

Application Number Priority Date Filing Date Title
US22678800P 2000-08-21 2000-08-21
US60/226,788 2000-08-21

Publications (1)

Publication Number Publication Date
WO2002017109A1 true WO2002017109A1 (en) 2002-02-28

Family

ID=22850406

Family Applications (1)

Application Number Title Priority Date Filing Date
PCT/US2001/026292 WO2002017109A1 (en) 2000-08-21 2001-08-21 Data tracking using ip address filtering over a wide area network

Country Status (5)

Country Link
US (1) US7225246B2 (en)
EP (1) EP1323058A4 (en)
AU (1) AU8664801A (en)
CA (1) CA2432344C (en)
WO (1) WO2002017109A1 (en)

Families Citing this family (53)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US6108637A (en) * 1996-09-03 2000-08-22 Nielsen Media Research, Inc. Content display monitor
US5796952A (en) * 1997-03-21 1998-08-18 Dot Com Development, Inc. Method and apparatus for tracking client interaction with a network resource and creating client profiles and resource database
AUPQ206399A0 (en) * 1999-08-06 1999-08-26 Imr Worldwide Pty Ltd. Network user measurement system and method
CA2396565A1 (en) 2000-01-12 2001-07-19 Jupiter Media Metrix, Inc. System and method for estimating prevalence of digital content on the world-wide-web
US7660869B1 (en) * 2000-08-21 2010-02-09 Vignette Software, LLC Network real estate analysis
AUPR505601A0 (en) * 2001-05-17 2001-06-07 Traffion Technologies Pty Ltd Method of optimising content presented to a user within a communications network
US6741990B2 (en) * 2001-05-23 2004-05-25 Intel Corporation System and method for efficient and adaptive web accesses filtering
US20030131093A1 (en) * 2002-01-09 2003-07-10 International Business Machines Corporation System for generating usage data in a distributed information processing environment and method therefor
US8271778B1 (en) 2002-07-24 2012-09-18 The Nielsen Company (Us), Llc System and method for monitoring secure data on a network
US8140569B2 (en) * 2003-05-29 2012-03-20 Microsoft Corporation Dependency network based model (or pattern)
US7149977B2 (en) * 2002-08-28 2006-12-12 Microsoft Corporation Virtual calling card system and method
AU2003900398A0 (en) * 2003-01-31 2003-02-13 Red Sheriff Limited Method and system of measuring and recording user data in a communications network
US7441195B2 (en) * 2003-03-04 2008-10-21 Omniture, Inc. Associating website clicks with links on a web page
US7873695B2 (en) * 2004-05-29 2011-01-18 Ironport Systems, Inc. Managing connections and messages at a server by associating different actions for both different senders and different recipients
US7849142B2 (en) * 2004-05-29 2010-12-07 Ironport Systems, Inc. Managing connections, messages, and directory harvest attacks at a server
US20070233566A1 (en) * 2006-03-01 2007-10-04 Dema Zlotin System and method for managing network-based advertising conducted by channel partners of an enterprise
US7877392B2 (en) 2006-03-01 2011-01-25 Covario, Inc. Centralized web-based software solutions for search engine optimization
US8869066B2 (en) 2006-07-06 2014-10-21 Addthis, Llc Generic content collection systems
US20080052278A1 (en) * 2006-08-25 2008-02-28 Semdirector, Inc. System and method for modeling value of an on-line advertisement campaign
US8972379B1 (en) 2006-08-25 2015-03-03 Riosoft Holdings, Inc. Centralized web-based software solution for search engine optimization
US8838560B2 (en) * 2006-08-25 2014-09-16 Covario, Inc. System and method for measuring the effectiveness of an on-line advertisement campaign
US8943039B1 (en) 2006-08-25 2015-01-27 Riosoft Holdings, Inc. Centralized web-based software solution for search engine optimization
US8056092B2 (en) 2006-09-29 2011-11-08 Clearspring Technologies, Inc. Method and apparatus for widget-container hosting and generation
US20080222232A1 (en) * 2007-03-06 2008-09-11 Allen Stewart O Method and Apparatus for Widget and Widget-Container Platform Adaptation and Distribution
US9009728B2 (en) 2007-03-06 2015-04-14 Addthis, Inc. Method and apparatus for widget and widget-container distribution control based on content rules
US8266274B2 (en) * 2007-03-06 2012-09-11 Clearspring Technologies, Inc. Method and apparatus for data processing
US10169781B1 (en) 2007-03-07 2019-01-01 The Nielsen Company (Us), Llc Method and system for generating information about portable device advertising
CA2631040A1 (en) * 2007-05-10 2008-11-10 Publicinsite, Ltd. Website affiliation analysis method and system
US20080281696A1 (en) 2007-05-11 2008-11-13 Verizon Services Organization Inc. Systems and methods for using dns records to provide targeted marketing services
US9137093B1 (en) * 2007-07-02 2015-09-15 Comscore, Inc. Analyzing requests for data made by users that subscribe to a provider of network connectivity
US8209378B2 (en) * 2007-10-04 2012-06-26 Clearspring Technologies, Inc. Methods and apparatus for widget sharing between content aggregation points
US20090112976A1 (en) * 2007-10-29 2009-04-30 Hutchinson Kevin P Method for measuring web traffic
US7752308B2 (en) * 2007-10-30 2010-07-06 Hutchinson Kevin P System for measuring web traffic
US20100281389A1 (en) * 2007-10-29 2010-11-04 Hutchinson Kevin P System for measuring web traffic
US20090210352A1 (en) * 2008-02-20 2009-08-20 Purplecomm, Inc., A Delaware Corporation Website presence marketplace
US9336527B2 (en) * 2008-02-20 2016-05-10 Purplecomm, Inc. Collaborative website presence
US8539057B2 (en) * 2008-02-20 2013-09-17 Purplecomm, Inc. Website presence
US8190594B2 (en) 2008-06-09 2012-05-29 Brightedge Technologies, Inc. Collecting and scoring online references
US20100100626A1 (en) * 2008-09-15 2010-04-22 Allen Stewart O Methods and apparatus related to inter-widget interactions managed by a client-side master
US8396742B1 (en) 2008-12-05 2013-03-12 Covario, Inc. System and method for optimizing paid search advertising campaigns based on natural search traffic
US20100198742A1 (en) * 2009-02-03 2010-08-05 Purplecomm, Inc. Online Social Encountering
US8671089B2 (en) 2009-10-06 2014-03-11 Brightedge Technologies, Inc. Correlating web page visits and conversions with external references
US8412847B2 (en) * 2009-11-02 2013-04-02 Demandbase, Inc. Mapping network addresses to organizations
US9514466B2 (en) * 2009-11-16 2016-12-06 Yahoo! Inc. Collecting and presenting data including links from communications sent to or from a user
US8281397B2 (en) * 2010-04-29 2012-10-02 Telcordia Technologies, Inc. Method and apparatus for detecting spoofed network traffic
US9250759B1 (en) * 2010-07-23 2016-02-02 Amazon Technologies, Inc. Visual representation of user-node interactions
US9608930B1 (en) * 2011-08-30 2017-03-28 Amazon Technologies, Inc. Allocating identifiers with minimal fragmentation
US10062091B1 (en) * 2013-03-14 2018-08-28 Google Llc Publisher paywall and supplemental content server integration
US9247273B2 (en) 2013-06-25 2016-01-26 The Nielsen Company (Us), Llc Methods and apparatus to characterize households with media meter data
WO2015123201A1 (en) 2014-02-11 2015-08-20 The Nielsen Company (Us), Llc Methods and apparatus to calculate video-on-demand and dynamically inserted advertisement viewing probability
US10219039B2 (en) 2015-03-09 2019-02-26 The Nielsen Company (Us), Llc Methods and apparatus to assign viewers to media meter data
US9848224B2 (en) 2015-08-27 2017-12-19 The Nielsen Company(Us), Llc Methods and apparatus to estimate demographics of a household
US10791355B2 (en) 2016-12-20 2020-09-29 The Nielsen Company (Us), Llc Methods and apparatus to determine probabilistic media viewing metrics

Citations (4)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US6178505B1 (en) * 1997-03-10 2001-01-23 Internet Dynamics, Inc. Secure delivery of information in a network
US6237006B1 (en) * 1996-10-15 2001-05-22 Mercury Interactive Corporation Methods for graphically representing web sites and hierarchical node structures
US6249820B1 (en) * 1995-07-12 2001-06-19 Cabletron Systems, Inc. Internet protocol (IP) work group routing
US6282548B1 (en) * 1997-06-21 2001-08-28 Alexa Internet Automatically generate and displaying metadata as supplemental information concurrently with the web page, there being no link between web page and metadata

Family Cites Families (18)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US5740549A (en) * 1995-06-12 1998-04-14 Pointcast, Inc. Information and advertising distribution system and method
US5892917A (en) * 1995-09-27 1999-04-06 Microsoft Corporation System for log record and log expansion with inserted log records representing object request for specified object corresponding to cached object copies
US6018619A (en) * 1996-05-24 2000-01-25 Microsoft Corporation Method, system and apparatus for client-side usage tracking of information server systems
US5787253A (en) * 1996-05-28 1998-07-28 The Ag Group Apparatus and method of analyzing internet activity
US6112238A (en) * 1997-02-14 2000-08-29 Webtrends Corporation System and method for analyzing remote traffic data in a distributed computing environment
US5796952A (en) * 1997-03-21 1998-08-18 Dot Com Development, Inc. Method and apparatus for tracking client interaction with a network resource and creating client profiles and resource database
US5991740A (en) 1997-06-10 1999-11-23 Messer; Stephen Dale Data processing system for integrated tracking and management of commerce related activities on a public access network
US6766327B2 (en) * 1997-07-29 2004-07-20 Acxiom Corporation Data linking system and method using encoded links
US6393407B1 (en) * 1997-09-11 2002-05-21 Enliven, Inc. Tracking user micro-interactions with web page advertising
US6055510A (en) * 1997-10-24 2000-04-25 At&T Corp. Method for performing targeted marketing over a large computer network
US6151601A (en) * 1997-11-12 2000-11-21 Ncr Corporation Computer architecture and method for collecting, analyzing and/or transforming internet and/or electronic commerce data for storage into a data storage area
US6278966B1 (en) * 1998-06-18 2001-08-21 International Business Machines Corporation Method and system for emulating web site traffic to identify web site usage patterns
US6317787B1 (en) * 1998-08-11 2001-11-13 Webtrends Corporation System and method for analyzing web-server log files
US6330592B1 (en) * 1998-12-05 2001-12-11 Vignette Corporation Method, memory, product, and code for displaying pre-customized content associated with visitor data
US7685311B2 (en) * 1999-05-03 2010-03-23 Digital Envoy, Inc. Geo-intelligent traffic reporter
US6393479B1 (en) * 1999-06-04 2002-05-21 Webside Story, Inc. Internet website traffic flow analysis
US6792458B1 (en) * 1999-10-04 2004-09-14 Urchin Software Corporation System and method for monitoring and analyzing internet traffic
US6741990B2 (en) * 2001-05-23 2004-05-25 Intel Corporation System and method for efficient and adaptive web accesses filtering

Patent Citations (4)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US6249820B1 (en) * 1995-07-12 2001-06-19 Cabletron Systems, Inc. Internet protocol (IP) work group routing
US6237006B1 (en) * 1996-10-15 2001-05-22 Mercury Interactive Corporation Methods for graphically representing web sites and hierarchical node structures
US6178505B1 (en) * 1997-03-10 2001-01-23 Internet Dynamics, Inc. Secure delivery of information in a network
US6282548B1 (en) * 1997-06-21 2001-08-28 Alexa Internet Automatically generate and displaying metadata as supplemental information concurrently with the web page, there being no link between web page and metadata

Non-Patent Citations (1)

* Cited by examiner, † Cited by third party
Title
See also references of EP1323058A4 *

Also Published As

Publication number Publication date
EP1323058A1 (en) 2003-07-02
CA2432344A1 (en) 2002-02-28
EP1323058A4 (en) 2006-04-05
CA2432344C (en) 2010-10-26
US7225246B2 (en) 2007-05-29
AU8664801A (en) 2002-03-04
US20020040394A1 (en) 2002-04-04

Similar Documents

Publication Publication Date Title
CA2432344C (en) Data tracking using ip address filtering over a wide area network
US7181412B1 (en) Systems and methods for collecting consumer data
US7562030B1 (en) Method and apparatus for real-time reporting of electronic commerce activity
US5960409A (en) Third-party on-line accounting system and method therefor
US7886051B2 (en) On-line web traffic sampling
US6487538B1 (en) Method and apparatus for local advertising
US8452865B1 (en) System and method for reporting website activity based on inferred attribution methodology
JP2004504649A (en) System and method for estimating the spread of digital content on the world wide web
CA2449809A1 (en) Method and system for displaying analytics about a website and its contents
US7373376B1 (en) Method and system for evaluating quality of service over the internet
JP2007523416A (en) Information system
US20040088210A1 (en) Methods and systems for integrating human and electronic channels
AU2001286648B2 (en) Data tracking using IP address filtering over a wide area network
AU2001286648A1 (en) Data tracking using IP address filtering over a wide area network
McClure Web Traffic Analysis: Analyzing What Is Happening on Your Site
Kohout et al. The internet visit rate, its monitoring and analysis
JP2003015996A (en) Method for acquiring site browsing state information, file used for the method, and system for collecting site browsing state information
Lu Traffic Tracking and Analysis for E-commerce
KR20190083111A (en) Method, Apparatus and System for On-line Advertisement
WO2001090966A1 (en) Monitoring system
Anand et al. Gaining insights into web customers using web intelligence
Henderson et al. Web-Intelligence: A Primer

Legal Events

Date Code Title Description
AK Designated states

Kind code of ref document: A1

Designated state(s): AE AG AL AM AT AU AZ BA BB BG BR BY BZ CA CH CN CO CR CU CZ DE DK DM DZ EC EE ES FI GB GD GE GH GM HR HU ID IL IN IS JP KE KG KP KR KZ LC LK LR LS LT LU LV MA MD MG MK MN MW MX MZ NO NZ PH PL PT RO RU SD SE SG SI SK SL TJ TM TR TT TZ UA UG UZ VN YU ZA ZW

AL Designated countries for regional patents

Kind code of ref document: A1

Designated state(s): GH GM KE LS MW MZ SD SL SZ TZ UG ZW AM AZ BY KG KZ MD RU TJ TM AT BE CH CY DE DK ES FI FR GB GR IE IT LU MC NL PT SE TR BF BJ CF CG CI CM GA GN GQ GW ML MR NE SN TD TG

121 Ep: the epo has been informed by wipo that ep was designated in this application
DFPE Request for preliminary examination filed prior to expiration of 19th month from priority date (pct application filed before 20040101)
WWE Wipo information: entry into national phase

Ref document number: 2001966108

Country of ref document: EP

Ref document number: 2001286648

Country of ref document: AU

WWE Wipo information: entry into national phase

Ref document number: 2432344

Country of ref document: CA

WWP Wipo information: published in national office

Ref document number: 2001966108

Country of ref document: EP

REG Reference to national code

Ref country code: DE

Ref legal event code: 8642

NENP Non-entry into the national phase

Ref country code: JP

WWG Wipo information: grant in national office

Ref document number: 2001286648

Country of ref document: AU