US20110078029A1 - Systems and methods for hosting, updating, and sending a webpage - Google Patents
Systems and methods for hosting, updating, and sending a webpage Download PDFInfo
- Publication number
- US20110078029A1 US20110078029A1 US12/851,457 US85145710A US2011078029A1 US 20110078029 A1 US20110078029 A1 US 20110078029A1 US 85145710 A US85145710 A US 85145710A US 2011078029 A1 US2011078029 A1 US 2011078029A1
- Authority
- US
- United States
- Prior art keywords
- webpage
- client
- webserver
- request
- information
- Prior art date
- Legal status (The legal status 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 status listed.)
- Abandoned
Links
Images
Classifications
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06Q—INFORMATION AND COMMUNICATION TECHNOLOGY [ICT] SPECIALLY ADAPTED FOR ADMINISTRATIVE, COMMERCIAL, FINANCIAL, MANAGERIAL OR SUPERVISORY PURPOSES; SYSTEMS OR METHODS SPECIALLY ADAPTED FOR ADMINISTRATIVE, COMMERCIAL, FINANCIAL, MANAGERIAL OR SUPERVISORY PURPOSES, NOT OTHERWISE PROVIDED FOR
- G06Q30/00—Commerce
- G06Q30/02—Marketing; Price estimation or determination; Fundraising
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06Q—INFORMATION AND COMMUNICATION TECHNOLOGY [ICT] SPECIALLY ADAPTED FOR ADMINISTRATIVE, COMMERCIAL, FINANCIAL, MANAGERIAL OR SUPERVISORY PURPOSES; SYSTEMS OR METHODS SPECIALLY ADAPTED FOR ADMINISTRATIVE, COMMERCIAL, FINANCIAL, MANAGERIAL OR SUPERVISORY PURPOSES, NOT OTHERWISE PROVIDED FOR
- G06Q30/00—Commerce
- G06Q30/02—Marketing; Price estimation or determination; Fundraising
- G06Q30/0241—Advertisements
- G06Q30/0242—Determining effectiveness of advertisements
- G06Q30/0243—Comparative campaigns
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06Q—INFORMATION AND COMMUNICATION TECHNOLOGY [ICT] SPECIALLY ADAPTED FOR ADMINISTRATIVE, COMMERCIAL, FINANCIAL, MANAGERIAL OR SUPERVISORY PURPOSES; SYSTEMS OR METHODS SPECIALLY ADAPTED FOR ADMINISTRATIVE, COMMERCIAL, FINANCIAL, MANAGERIAL OR SUPERVISORY PURPOSES, NOT OTHERWISE PROVIDED FOR
- G06Q30/00—Commerce
- G06Q30/02—Marketing; Price estimation or determination; Fundraising
- G06Q30/0241—Advertisements
- G06Q30/0242—Determining effectiveness of advertisements
- G06Q30/0246—Traffic
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06Q—INFORMATION AND COMMUNICATION TECHNOLOGY [ICT] SPECIALLY ADAPTED FOR ADMINISTRATIVE, COMMERCIAL, FINANCIAL, MANAGERIAL OR SUPERVISORY PURPOSES; SYSTEMS OR METHODS SPECIALLY ADAPTED FOR ADMINISTRATIVE, COMMERCIAL, FINANCIAL, MANAGERIAL OR SUPERVISORY PURPOSES, NOT OTHERWISE PROVIDED FOR
- G06Q30/00—Commerce
- G06Q30/02—Marketing; Price estimation or determination; Fundraising
- G06Q30/0241—Advertisements
- G06Q30/0251—Targeted advertisements
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06Q—INFORMATION AND COMMUNICATION TECHNOLOGY [ICT] SPECIALLY ADAPTED FOR ADMINISTRATIVE, COMMERCIAL, FINANCIAL, MANAGERIAL OR SUPERVISORY PURPOSES; SYSTEMS OR METHODS SPECIALLY ADAPTED FOR ADMINISTRATIVE, COMMERCIAL, FINANCIAL, MANAGERIAL OR SUPERVISORY PURPOSES, NOT OTHERWISE PROVIDED FOR
- G06Q30/00—Commerce
- G06Q30/02—Marketing; Price estimation or determination; Fundraising
- G06Q30/0241—Advertisements
- G06Q30/0277—Online advertisement
Definitions
- Online merchants associate products with service plans or warranties so that a customer can buy an extended warranty or service plan when he or she purchases a product. Sometimes, however, a product should be listed as having a service plan, but an error in the listing causes the webpage on which the product is listed to not offer a service plan. Consequentially, the online merchant would not, in this case, offer the service plan to the customer. In other cases, the website of the online merchant may associate the product with an incorrect service plan. Because the sale of warranties or service plans may be a significant source of revenue for the merchant, merchants often expend considerable resources in checking their websites for mismatched warranties and products not having an associated warranty.
- One aspect of the present invention may relate to providing a web crawler which can identify missing or misassociated service plans or warranties.
- a second aspect of the present invention may relate to providing a dynamic mapper for determining what service plan should be associated with a particular product.
- the web crawler may be constructed so that it follows links on a merchant's website to find at least one product on a merchant's webpage, identifies which service plan is associated with that product, and determines whether the correct service plan has been associated with the product.
- Additional features of the web crawler embodiment may include a placement analyzer for determining where on the webpage the warranty is located, and whether the placement is easily visible to the customer.
- the web crawler may provide is a class generator for populating a relational database with information downloaded by the web crawler. Moreover, the web crawler may contain a smart crawling routine for preventing the web crawler from crawling blacklisted webpages. Other features of the web crawler may include a throttle controller for managing the web crawler's impact and strain on the merchant's website, and an error checking routine for tracking errors returned by the website.
- a dynamic mapper which allows a merchant to automatically map service plans to product webpages. This technique allows the merchant to avoid having to manually map the service plans with the product webpage, which may increase costs in personnel and also increase the number of incorrectly paired service plans to product pages.
- the merchant may send the dynamic mapper a request to add a product webpage to the merchant's website.
- the dynamic mapper may analyze the product to be added, and return content to the merchant. In some embodiments, the content may simply be information regarding the service plan (such as a warranty SKU).
- the dynamic mapper may return an advertisement for the service plan itself. In the latter case, the merchant may incorporate the advertisement directly into the product webpage.
- the dynamic mapper may determine that no service plan should be included.
- the dynamic mapper may be able to determine whether the product should have a warranty by comparing product information, category, bread crumbs, and price info (etc.) against a set of previously collected data. This previously collected data may be used to allow the dynamic mapper to implement a Bayesian filter. An implementation of this filter may allow the dynamic mapper to determine whether the product webpage it is currently analyzing should have a service plan based on whether or not similar product webpages have a service plan. Alternatively or in addition, the dynamic mapper could use a rule-based engine to determine whether a particular product webpage should have a service plan. Once the service plan or service plans are identified, the dynamic mapper may return the service plan information back to the merchant. In some embodiments, the service plan may be identified simply by an identifier unique to each service plan (e.g. a warranty SKU).
- a webserver may be provided which contains instructions or software stored on computer readable media (hard drive/optical drive) and a processor (e.g. Intel or AMD microprocessor) for causing the webserver to perform a series of steps.
- the webserver may receive a request for a webpage containing details on a particular product from a client executing a web browser; determine the web browser version and type; and determine from the version and type whether the web browser supports asynchronous page loading.
- the instructions in the computer readable media may cause the webserver to send a copy of the requested webpage to the client; send an update request to a file server; receive updated information to the file server; format the information from the file server so that it may be displayed by the web browser of the client; and send the formatted information to the web browser of the client. If the webserver determines that asynchronous page loading is not supported by the web browser, the instructions in the computer readable media may cause the webserver to send a request to the client to determine whether a media player such as Adobe Flash Media Player is installed.
- a media player such as Adobe Flash Media Player
- the instructions in the storage media of the webserver may cause the webserver to: send a webpage to the client containing details about a product, a control, and a media file; receive a transmission from a program executing the media file at the client; said transmission containing a request for updated information; send the request for updated information to the file server; receive a response from the file server which contains data; format the data so that it may be viewed by the web browser; and return the formatted data to the client.
- the client, webserver, and server could be configured so that the service plan server sends updated information directly to the client (bypassing the webserver).
- One way to accomplish this configuration would be to instruct the webserver to send a script to the client. Upon execution of the script, the client may send a request to the service plan server for service plan information.
- configurations of the invention may be constructed which are not limited to service plans or products.
- the above topology may be used to update news articles, sports scores, directories, or other webpages which may need to be updated depending on the particular client requesting the information, or need to be updated on a frequent basis.
- FIG. 1 is a schematic view of an embodiment of the present invention.
- FIG. 2 is a screenshot of a merchant's homepage.
- FIG. 3 is a screenshot of a category webpage of a merchant.
- FIG. 4 is a screenshot of a subcategory webpage of a merchant.
- FIG. 5 is a screenshot of a product webpage of a merchant.
- FIG. 6 is a screenshot of a quasi category webpage of a merchant.
- FIG. 7 is a schematic view of a database designed to be used with an embodiment of the present invention.
- FIG. 8 is a screenshot of an example of the output of the interface output.
- FIG. 9 is a screenshot of an example of the output of the interface output.
- FIG. 10 is a screenshot of an example of the output of the interface output.
- FIG. 11 is a screenshot of an example of the output of the interface output.
- FIG. 12 is a screenshot of an example of the output of the interface output.
- FIG. 13 is a schematic view of the dynamic mapper.
- FIG. 14A is a flow diagram illustrating how information may be sent between a client, webserver, and file server.
- FIG. 14B is a flow diagram illustrating a second embodiment of how information may be sent between a client, webserver, and file server if the client's web browser can be configured to natively accept asynchronous page loading.
- FIG. 14C is a flow diagram illustrating a third embodiment of how information may be sent between a client, webserver, and file server if the client's web browser can be configured to natively accept asynchronous page loading.
- FIG. 14D is a flow diagram illustrating an embodiment of how information may be sent between a client, webserver, and file server if the client's web browser does not natively accept asynchronous page loading.
- FIG. 1 illustrates a schematic view of the web crawler 10 .
- the web crawler has many utilities including, for example, allowing a user to learn which products on a merchant's website are correctly paired with a service plan, and whether the service plan is sufficiently visible to the customers browsing the webpages of the merchant's website.
- a service plan is generally an agreement between the customer and a service plan provider to repair or replace a product if a prespecified condition occurs (e.g. the product breaks, wears down, etc.)
- a warranty is a type of service plan.
- the web crawler 10 may be stored on computer readable media (such as memory or an optical or magnetic disc) and take the form of computer executable instructions or software that a computer can execute to generate an instance of the webcrawler object.
- the computer may contain a processor, hard drive, motherboard, I/O connections, memory, or other typical hardware.
- the web crawler 10 may contain an interface input 20 which can accept inputs from a user or another computer.
- the interface 20 may allow a user to enter a URL of a homepage 210 of a desired webpage the user would like the web crawler 10 to analyzer.
- the interface 20 may contain a control or button for instructing the web crawler 10 to execute one or more the routines shown in FIG. 1 .
- the interface may contain a webpage collector control and/or an analyzer control. In some embodiments, multiple routines may be combined into one control.
- the interface output 130 may contain inputs for receiving information from other routines (e.g.
- Interface output 130 may be a monitor or other display device, a printer, or a sound emission device.
- Interface 20 may send a request to the webpage collector 50 to tell the retriever to collect webpages from the merchant's website 200 .
- vertical links 221 connect the homepage 210 to the webpages 250 and 250 ′ (which may be category webpages), while a horizontal link 222 links webpage 250 to webpage 250 ′.
- vertical link 221 links the homepage 210 to category webpage 250 , FIG. 3 (the link to mp3 players is indicated).
- the web crawler 10 may also contain a smart crawler 30 for minimizing the number of webpages the downloader needs to download.
- the smart crawling routine 30 may contain a blacklist and/or a whitelist of items.
- a matcher 31 may contain a blacklist routine 32 or a whitelist routine 33 , or both. The matcher 31 will attempt to match breadcrumbs 76 , the name of the product 71 , etc. (see FIG. 5 ) against the terms in the blacklist or whitelist.
- the matcher 31 determines there is a match, the matcher 31 will allow the webpage collector 50 to save the webpage information in the database, but it will instruct a halter 35 which, if any item in the blacklist matches a breadcrumb, causes the smart crawler to download the current webpage and instructs the web crawler to avoid following any further links from the current webpage. In other embodiments, if the matcher 31 determines that some product information matches the blacklist, the matcher 31 will instruct the halter 35 to prevent the webpage collector from saving the webpage in the database 60 . In whitelist routine 33 , the matcher 31 will determine whether any of the product information matches any term in the whitelist.
- matcher 31 determines there is a match, the matcher 31 will allow the webpage collector 50 to save the webpage information, but if there is no match, the matcher 31 will instruct the halter 35 to prevent the current webpage from being saved.
- the smart crawler may also interact with a cacher 99 which saves copies of the webpages into the database 60 .
- the amount of caching performed may be set by the user via interface input 20 .
- the web crawler 10 may contain a linking system 40 which may contain a link follower 41 and a linker 45 .
- the link follower 41 may retrieve and follow links 221 - 222 from the homepage 210 or from the webpage 250 or 250 ′ to other additional webpages 260 and 260 ′ (which may be subcategory webpages).
- FIG. 4 illustrates a subcategory webpage.
- a linker 45 may determine whether a particular link should be followed by matching a part of the link's URL against a regular expression. For example, the words “category” 81 , “subcategory” 82 , “product” 83 , or “catprop” may be used as terms to match against the URL to determine the type of page.
- the linker 45 may monitor the sequence of links to determine the type of page (often webpages progress from homepage 210 ->category page 250 ->subcategory page 260 ->product page 270 ), or the linker 45 may rely on information determined from analyzer 70 such as breadcrumbs 76 (See FIG. 5 ) to determine the type of page currently being analyzed.
- the web crawler 10 may also contain a webpage collector 50 for collecting a current webpage associated with at least one of the links retrieved from the linking system.
- the collector may contain a categorizer 55 for categorizing the webpage as a category webpage 250 , a quasi category webpage 280 ( FIG. 6 ), or a SKU or product webpage 270 .
- Quasi category 200 webpages may provide products within a certain price range 84 , brand 85 , or size 86 for example (See FIGS. 4 and 6 ).
- categorizer may rely on information from analyzer 70 to help determine the type of webpage being collected.
- the web crawler 10 may also contain a database 60 for storing webpages 250 retrieved from webpage collector 50 .
- An enlarged view of the database 60 is shown in FIG. 7 .
- a garbage 205 collector 92 may remove unnecessary or empty classes in the database.
- a relational database may be used, and the database may comprise a number of classes such as a merchant class 61 , category class 62 , subcategory class 63 A, quasi category class 63 B, SKU class 64 , SKU warranty class 65 , page link class 66 , page content class 67 , category display filter class 68 (used for filtering down categories in the website), category spider filter class 69 (used for blacklisting certain specified websites).
- a class generator 93 may work in conjunction with the analyzer 70 to build classes based upon the information determined by analyzer 70 .
- a tree builder 80 may be used to establish relationships or links between these classes.
- the merchant class 61 is linked to the category class 62 and the page link class 66 .
- the category class 62 is liked to the subcategory class 63 A and the quasi category class 63 B, the subcategory class 63 A and the quasi category class 63 B are linked to the SKU class 64 .
- the SKU class is linked to the SKU warranty class.
- the page link class 66 is linked to the page content class 67 .
- the web crawler 10 may also contain an analyzer 70 for collecting information about a particular product.
- the analyzer can collect a name of the product 71 , a category 72 and subcategory 73 of the class, pricing information on the product 74 , pricing information relating to a service plan of the product 75 , breadcrumbs 76 , and images of the product 77 .
- the analyzer 70 (of FIG. 1 ) has identified all seven types of information. Once identified, the analyzer may store this information in the database 60 .
- Breadcrumbs 76 provide contextual information for location of the product within a product page. As shown in FIG.
- the breadcrumbs are “Home>Categories>MP3 Players & Accessories>MP3/MP4 Players>iRiver America>Item#:N82E16855150095.”
- the breadcrumbs 76 also provide the SKU 79 , the category 72 , and the subcategory 73 information.
- the analyzer may collect information such as the name of the merchant 78 from either the URL or merchant logo, and the SKU 79 .
- the web crawler 10 may also contain a placement analyzer 90 for determining the quality of placement and location of the service plan on the current webpage.
- the placement analyzer 90 may have a simulator 91 for determining the service plan's visibility on the current webpage through simulating human interaction with the webpage to enable the analyzer 90 to locate placement of the service plan on the SKU webpage 270 , in a shopping cart, in a popup window, light box, or in a related items window (i.e. a window which suggests products other customers also bought.)
- the placement analyzer may contain instructions for causing the web crawler 10 to determine whether the service plan is placed before the bend of a webpage (i.e. is the service plan visible on a customer's screen without requiring the customer to scroll the screen?).
- the web crawler 10 may also contain a validator 100 for examining the information relating to the product 83 and its associated service plan 75 .
- the validator 100 may receive webpage information from the database 60 or directly from webpage collector 50 .
- the validator 100 may comprise a range checker 101 and a missing service plan locator 105 for validating the product 83 and service plan 75 .
- the range checker 101 can be used with any product 83 having a service plan with a price range for products covered thereunder. For example, a service plan might generally cover products costing between 100-200 dollars.
- the missing service plan locator 105 may analyze products of a particular subcategory 73 , and determine whether any of the products in the same subcategory 73 have a service plan, and if the locator 105 determines that at least one of the products does have a service plan, the locator 105 may notify the web crawler 10 as to which products do not have an associated service plan.
- the locator 105 will determine that the black Ipod® Nano® is likely missing an associated service plan, and the locator 105 will notify the webcrawler that the black Ipod® Nano® does not have an associated service plan.
- the locator 105 may inform the crawler 10 of this event, and may send the results of its analysis to the interface output 130 .
- the locator 105 may utilize various algorithms for determining whether a particular product should have a service plan. In a first configuration, the locator 105 may utilize a string distance comparator to determine the Levenshtein distance between two product names 71 .
- the locator 105 may compare the string distance to a preestablished threshold value to enable the locator 105 to determine whether the strings are sufficiently close together such that an inference should be made that if one of the products 83 has a service plan 75 , then the second product should have a service plan.
- the locator 105 may use its string distance comparator to determine the strings have a distance of four, and if the preestablished threshold value is 8 (for example), the locator 105 would determine that the string distance is less that the threshold value, thereby causing the locator 105 to inform the validator 100 (which may send the result to the interface output 130 ) that the Black Ipod probably should have a service plan 75 because the Pink Ipod has a service plan 75 .
- the locator 105 may utilize category and/or subcategory matches to prevent nonsensical matches and deductions. For example, if the website offered both Cadillac cars and Cadillac dog food, the locator 105 may use category and subcategory information to avoid concluding that dog food should come with a service plan, because the Cadillac cars come with a service plan.
- the locator 105 may use a Bayesian filter to classify products as having or not having service plan 75 .
- the locator 105 may be trained to determine which products usually have a service plan 75 .
- the locator 105 may be provided with test data to process.
- the test data will contain product attributes such as name 71 , category 72 , price 74 , and breadcrumbs 76 . From these attributes, the locator 105 can develop a centroid that the locator 105 may use to classify the product 83 by its attributes as one which usually has a service plan 75 or one that does not usually have a service plan 75 .
- the web crawler 10 may also contain a throttle controller 110 which may have a connection limiter 111 , a bandwidth limiter 112 , and a request limiter 113 . Presets for the throttle controller 110 may be defaulted or set through the interface 20 .
- Connection limiter 111 may control the maximum number of simultaneous connections the web crawler 10 or webpage collector 50 may use while crawling the website. For example, the connection limiter 111 may allow 5 simultaneous connections.
- Bandwidth limiter 112 may control how much data per unit of time the web crawler may download from the website. For example, the connection limiter may limit the download speed to 2 megabytes per second.
- Request limiter 113 may control the frequency the web crawler sends requests or queries to the website. For example, the request limiter could limit the requester 50 to 20 requests per minute.
- the web crawler 10 may also contain an error checker 120 which may have a stopping routine 121 , a total error threshold monitor 122 , and a frequency error monitor 123 .
- the webserver 205 ( FIG. 13 ), hosting the website 200 , may return errors indicating too many webpages 250 were requested, the webpages 250 were requested too quickly, the webpage 250 associated with a particular link 221 or 222 could not be found, etc.
- the error checker 120 may comprise presets that may be defaulted or set through the interface input 20 . Stopping routine 121 can control the crawler 10 or the retriever 50 by preventing either from downloading webpages for a period of time.
- Total error threshold monitor 122 is designed to monitor the amount of errors received from the website.
- the monitor may contain a preselected amount of errors per second, and may execute the stopping routine 121 to stop the crawler 10 or retriever 50 if the amount of errors exceeds a threshold value, such as 20 errors.
- Frequency error monitor 123 may monitor the frequency of errors per unit of time received from the website. The monitor 123 may execute the stopping routine to stop the crawler if the frequency of errors exceeds a threshold value, such as 5 errors/minute.
- FIG. 1 also illustrates a process flow of information and interaction between the web crawler 10 and the website 200 . While a specific, sequenced process flow is shown in FIG. 1 and described herewith, various steps can be omitted or placed in a differing order than the one shown.
- Interface input 20 may request the user enter the URL of the homepage of the website the user would like to crawl. Additionally interface input 20 may request other settings such as throttle, caching, or error settings.
- Interface input 20 then may send the information to the smart crawler 30 which downloads the webpage.
- Smart crawler 30 may utilize its whitelist and/or blacklist to determine whether to process any links on the homepage.
- the smart crawler 30 then sends the homepage to webpage collector 50 .
- the smart crawler 30 may send any errors received in conjunction with the homepage to the error checker 120 .
- Error checker 120 may monitor and regulate the actions of the smart controller depending on the amount or frequency of received errors.
- the error checker 120 may send the results of its error analysis to the webpage collector 50 .
- Smart crawler 30 also may send bandwidth and network information to the throttle controller 110 which will monitor and regulate the network performance of the smart crawler 30 .
- Webpage collector 50 may use its categorizer 55 to determine the type of webpage it is currently collecting. If the current webpage being collected is a category 250 , subcategory 260 or quasi category 280 webpage, the collector will send a request (and optionally the results of the categorizer's analysis) to the linking system 40 , which will access the website 200 to find and process further links to find the SKU webpage 270 .
- Linking 40 system may use its linker 45 and link follower 41 to determine which links to analyze and process. The results of the linking system's analysis are sent back to the smart crawler 30 , which downloads the next webpage specified by the linking system 40 .
- the webpage collector 50 may send the webpage to placement analyzer 90 , cacher 99 , and/or analyzer 70 .
- Placement analyzer 90 may evaluate the placement and visibility of the service plan, but it may need information from analyzer 70 to inform it of the positioning of the service plan.
- the analyzer 70 may send both the webpage and the results of its analysis to placement analyzer 90 .
- Cacher 99 may determine whether or not to save or cache the webpage in the database 60 .
- Analyzer 70 may determine the content and location of information such as category 72 or breadcrumbs 76 on the webpage, and then send the results of its analysis to the database 60 .
- Database 60 may use its class generator 93 to create classes for database 60 .
- Tree builder 80 may establish relationships between the classes, and garbage collector 92 may remove blank or not needed classes.
- Validator 100 may request information from the database 60 (such as objects of the classes created by the class generator) and process the information to determine whether the product on the webpage should have a service plan, and whether the service plan offered is the correct service plan through using the locator 105 and the range checker 101 .
- Validator 100 may then send the results of its analysis to interface output 130 .
- Interface output 130 may generate an output to display the results gathered from the placement analyzer 90 and/or the validator 100 (or other routine).
- the computer processing the webcrawler software may transfer the output to a display or a monitor or print the results on paper to inform the user of the results of the analysis performed by web crawler 10 .
- the details of these results may be customized by the user.
- FIG. 8 for example shows a flat report of a retailor's (Zaps) website.
- the report display 300 can show a number of different fields and in some embodiments the contents of the fields or their order can be customized by the user or by the software.
- the category filter 305 may allow the interface output 130 to restrict its output to certain categories of items. Category, subcategory, and breadcrumb information may be determined by the analyzer 70 to populate this field.
- the flat report view ( FIG. 8 ) has a number of tabs 310 for causing the interface output to switch the current view. These tabs include report 313 , explorer 311 , filters, statistics 312 , status, and administration.
- This embodiment of the output of the interface output 130 includes a search command 320 for searching for certain terms of keywords in the report display 300 .
- the search command in this embodiment, can filter by the presence or absence of a warranty (using the warranty filter 325 ) or by price (using the price filter 330 ).
- the report generator function 335 may be used to switch the format of the report display.
- FIG. 8 the flat report display is shown, but in FIG. 9 , a hierarchical display is shown. Clicking on the radial button, causes the interface output 130 to switch the display format.
- the hierarchical display ( FIG. 9 ) shows category and subcategory information in the report display. Additionally, in this embodiment, the report display illustrates the number of products available in the present view.
- a description, price, warranty description, warranty price, and warranty name columns are generated by the interface output 130 .
- One advantage of this layout as compared to the flat layout is that it shows products by their category information, but a disadvantage of this layout is that somewhat less detailed information about the warranty is displayed by interface output 130 .
- Clicking on the explorer tab 311 instructs the interface output 130 to display the explorer interface (see FIG. 10 ).
- This interface provides additional information about the product being sold, and through popup windows provides detailed views of warranty information.
- FIG. 10 shows the first warranty window 340 the interface output 130 generates when the product hyper link ( 341 ) is clicked.
- FIG. 11 shows the second warranty window 342 the interface output 130 generates when the warranty icon 343 is clicked.
- Clicking the statistics tab 312 instructs the interface output 130 to display the statistics output ( FIG. 12 .)
- crawling activity on Zaps webpage is shown.
- Various types of information is compiled and illustrated by the interface output 130 in this view. For example, the number of products having warranties can be calculated, the amount data pulled from the merchant's website can be displayed (this data may come from the throttle controller 110 for example), and the total number of webpages downloaded can be displayed.
- the webcrawler 10 may be used to determine which products on a merchant's website have or should have warranties or service plans, and which products are correctly paired with the warranty or service plan. Once a user learns this information, he or she may relay it to the merchant (in some embodiments the merchant may be able to use the software directly). In such a case, the merchant may still need to have personnel update the merchant's website to add the missing warranties or service plans and update the incorrectly paired warranties or service plans.
- a dynamic mapper may be used to select which service plan should be paired with a particular product.
- the dynamic mapper may be stored on computer readable media and comprise instructions for causing a processor of a computer to execute the instructions, thereby creating an instance of the dynamic mapper.
- the computer may contain a processor, hard drive, motherboard, I/O connections, memory, or other typical hardware.
- a dynamic mapper to a merchant's website involves adding a control 400 onto a product webpage 410 , search page, or shopping cart. Then, when a consumer views the product—or adds it to the shopping cart—the control 400 may send a request 5400 including the product name, price, category, SKU breadcrumbs, and/or other information to a service plan server 420 , to instruct a processor 421 in the server 420 to lookup S 402 which service plan should be associated with the particular product by accesing a database 422 . The processor 421 returns 5410 electronic data back to the control 400 .
- the electronic data may simply be html code which allows the control 400 to display warranty information or provide a selector to choose among multiple service plans (2 yr or 3 yr plans for example).
- the electronic information may include a sales pitch, service plan options, or an advertisement.
- the control 400 may display and/or process the electronic data so that the product webpage 410 and control 400 appear to be one integral page.
- the control 400 may store the electronic data locally, and send a request for updated information from the service plan server 420 when certain conditions are met. Such requests may be sent after a predetermined period of time elapses (e.g. once a year), or anytime the product information is modified.
- the electronic data may contain text, images, videos, popup panels, and other types of rich media.
- the control 400 may support chat functions to allow customers to ask questions about a service. If a customer wants to purchase the service plan, he or she may have the option to click a purchase button to add the service to their shopping cart. In a way, the content returned by the dynamic mapper may act like part of the underlying webpage; as opposed to a banner type advertisement.
- One way to allow a user to update his or her order, is to construct the control 400 so that the control 400 sends a request to the webserver 205 hosting the webpage when the user clicks a button or other element in the control.
- the request 5420 sent by the control 400 to the webserver 205 may contain information to allow the webserver 205 to display S 425 updated information such as a new combined price.
- the dynamic mapper may also track customer behavior and sales outcome to determine a success rate of different embodiments of the control 400 .
- the webserver 205 may store S 435 the outcome of what happens in a webserver database 430 when alternative embodiments of the control 400 are used (sales pitch, radial box with options, chat popup, etc).
- the webserver database 430 may store a consumer's decision whether or not to purchase a service plan advertised through the control 400 . For example, when the consumer presses a “Buy” button 401 , the consumer's computer may submit S 430 information to the webserver 205 including the service plan selected, the current embodiment of the control 400 , and perhaps the total price.
- An analysis engine 435 may process this information, and determine which embodiments of the control 400 are more effective in persuading customers to purchase the service plan.
- the analysis engine 435 may take into account information about the purchaser including the location of the purchaser (obtainable from the purchaser's IP address), the merchant from which the customer is purchasing the item, the time of day or year of the purchase (during the workday or at Christmas time for example.)
- the merchant's website or the customer sends information about the customer to the webserver 205 or analysis engine 435 (such as the customer's phone number) this information can be cross-referenced against a database to obtain additional information about the customer including gender, income, age, etc.
- the dynamic mapper may use this information to determine which type of advertisement for the service provider is most effective for the particular customer to maximize sales of the product and/or the service plan.
- the analysis engine may send S 440 an instruction back to the webserver to direct the webserver as to which type of control 400 to use to optimize the likelihood that a particular customer will purchase the service plan.
- the service plan server 420 may use Bayesian algorithms, statistical analysis, rule-based engines, or other techniques to identify which service plans should be associated with a given product. Based on these techniques, the service plan server may determine what type of advertisement it should display to the customer, and return this advertisement to the control 400 .
- the dynamic mapper may also be constructed so that the control 400 downloads dynamic content only after the product webpage 410 has been displayed to the customer. This prevents the advertisement for the service plan from increasing page load time. This may be significant as an increase in page load time may decrease sales of the underlying product. Additionally, the dynamic mapper may be constructed so that the control 400 cannot modify the underlying product webpage. This may be a valuable security benefit to the merchant. Additionally, if the control is restricted to a particular area of the webpage, a failure of the dynamic mapper to return the advertisement may cause displayer to display nothing, thereby making this failure transparent to a customer.
- FIGS. 14A-E show how information may be delivered to a client.
- a client 500 (utilizing a web browser) may send S 500 a request to a webserver 205 for a particular webpage adverting a particular product.
- the webserver 205 may determine the webpage 510 which is being requested, and may send S 502 a request to the service plan server 420 to update the service plan information stored in the webserver 205 for the particular product.
- the service plan server 420 may determine attributes about the service plan and send S 504 a service plan in the form of an executable program to the webserver 205 (although data may be sent instead or in addition).
- the webserver 205 may update S 506 the webpage, and then send S 508 the updated webpage 520 to the client 500 .
- FIGS. 14B and 14C show a process and system which utilizes asynchronous page loading.
- older web browsers are not configured to accept asynchronous page transmissions.
- a client 500 having a web browser 502 may send a request to a webserver 205 to send a webpage 510 having information on one or more products, images, and service plan information (in other configurations the webpage could contain information on news, sports, entertainment etc).
- the webserver 205 may review the query string parameters (information included with the URL to provide server additional information) included within the client's request for the webpage 510 .
- the webserver may be able to determine S 510 the version and type of the browser making the request, and from that information, determine whether the browser supports asynchronous page loading.
- the webserver 205 may transmit a webpage to the client which contains a script (see FIG. 14C ). This script may attempt to send a request S 505 ′ to the service plan server 420 to update the webpage, if this procedure succeeds, an embodiment related to FIG. 14C may be followed.
- FIGS. 14D and E illustrate examples of configurations of process flows if the script fails or the web browser does not support asynchronous page updating.
- the web browser may be able to receive updates to a webpage as the web browser is displaying the webpage.
- the webserver 205 may send S 503 the webpage to the client 500 and an update request S 505 to the service plan server 420 .
- the service plan server 420 may lookup S 507 the requested information, and transmit S 509 the retrieved information back to the webserver 205 .
- the webserver may receive the information from the server, format it S 511 into an update for the client, and transmit S 508 the update to the client.
- the client 500 can view product information on the webpage 510 quickly, while the service plan server sends updates for the webpage.
- Updates (shown schematically as ovals) may be implemented in any portion of the webpage and are not necessarily localized to a particular portion of the webpage. Images and other items having a large file size may also be sent asynchronously via update S 512 .
- the webserver 205 may send a webpage 510 containing a script (e.g. a java script for instructing the web browser 502 to request additional information from a service plan server 420 ) to the client.
- the web browser 502 may transmit S 505 ′ information about a particular product so the service plan server 420 can determine which service plan information to look-up. Once the service plan is determined, the service plan server 420 can send S 508 ′ service plan information back to the client 500 .
- FIG. 14B or 14 C may be used to update a client webpage asynchronously.
- One advantage to FIG. 14B is that the information that the client receives may appear to originate from the webserver 205 .
- FIG. 14B may be effective in distributing information to clients which have their web browser 502 settings set to high levels.
- Advantages of the topology of FIG. 14C include reduced load time for information in the server plan server 420 because the information does not need to be sent through the webserver 205 . Additionally, the topology of FIG. 14B requires the webserver to handle more processing tasks which may require more powerful webservers to implement.
- FIGS. 14D-14E illustrate two embodiments of a webserver process flow for a client that has a web browser which does not support asynchronous page loading (e.g. IE 3 or Firefox 1).
- the webserver 205 may send a request S 513 to determine whether a particular media player (e.g. Adobe Flash Media Player, Microsoft Silverlight, etc.) is installed. If the media player is installed, the webserver 205 can send S 503 a webpage 510 containing a media file (e.g. a Flash movie) to the client 500 .
- the media file may be very small and may be placed in a remote location of the webpage 510 so that it is unlikely an individual looking at the webpage will see it.
- the media file may also be very small in file length ( ⁇ 100 k) and movie length ( ⁇ 1 second).
- the transmitted webpage may contain details about the product, possibly images, the media file, and a control.
- the control may be written using Java script, an applet, or other programming code. The control may be configured so that it awaits information from the webserver 205 to cause the program to execute and display some type of service plan information.
- the program executing the media file may send S 514 a request for additional information to webserver 205 (e.g. updated service plan information).
- the request may be sent directly S 514 ′ to the service plan server 420 .
- the webserver 205 may receive S 515 the request, and send S 516 its own request to the service plan server 420 to lookup S 517 service plan information concerning the product the client is viewing.
- the service plan server 420 fetches the needed service plan information (utilizing the techniques explained above, rule engines/Bayesian filters, etc.), the server 420 may format the results it obtains (e.g.
- the webserver 205 and service plan server 420 may be configured so that the service plan server 420 only sends data (for example XML code and XSLT template) to the webserver 205 (the webserver 205 may be configured only to receive data, i.e. not program code).
- the webserver 205 may contain a program for accepting the data.
- the webserver 205 may also contain a program 530 which will use the received data to generate an executable program, which the webserver 205 can send S 518 to the client 500 .
- the webserver 205 may also send S 518 the information (e.g. XML and XSLT) to the client 500 .
- the browser can cause the program to be executed thereby displaying the service plan information.
- the information may be passed to the control and be executed by the control to display the service plan information.
- the service plan server 420 may send the information or program directly to the client 500 ( FIG. 14E ).
- FIG. 14A-E may be used independently or combined into a single multistep system/method.
- the process/system illustrated and described in conjunction with FIGS. 14A , B, and D could be combined into a multistep system/process.
- the webserver 205 could determine whether the browser of the client 500 natively supports (either as installed or with add-ins or extensions) asynchronous page loading. If so, the webserver 205 could implement the model shown and described in conjunction with FIG. 14B . If asynchronous page loading is not supported, the webserver 205 could send a webpage containing a script for determining whether a particular media player is installed. If so, the webserver 205 could implement the model shown and described in conjunction with FIG. 14D .
- the webserver 205 could implement the model shown and described in conjunction with FIG. 14A .
- the process/system illustrated and described in conjunction with FIGS. 14A , C, and E could be combined into a multistep system/process. Namely, the webserver 205 could send a webpage 510 to the client 500 containing a script. The script could attempt to update the webpage via a third party service plan server 420 ( FIG. 14C ). If the script fails because asynchronous page updating is not supported (or is disabled), the script could attempt to use a media player to update the content of the webpage ( FIG. 14E ). If that attempt fails because the media player is not installed, for example, the process of FIG. 14A could be followed.
- One advantage to using these multi-tiered processes is that these processes identify an efficient way to deliver an updated webpage 520 to the client depending on the software (web browser, media player) installed on the client.
- the preceding technology may be adapted to a number of general technical areas/uses.
- the service plan server 420 may be a generalized file server containing a database of information of interest to the client 500 or webserver 205 .
- the webserver 205 may be able to send a first version of a webpage to the client, while the file server sends updates to the webpage to the client 500 .
- the preceding technology may be adapted to allow webserver 205 to update the webpage as data in the server 420 changes. For example, sports scores or stock prices may be updated on a webpage using this technology without the client refreshing the webpage.
- the server 420 may alert the webserver 205 that it contains updated information and push new data to the webserver 205 .
- the current assignee of the present application was recently awarded an award by the Consumer Electronics Association for the technology described in the provisional applications 61/245,923; and 61/272,707 (incorporated by reference).
- the Consumer Electronics Show (an annual awards presentation produced by the Consumer Electronics Association) reviewed a description of the technology underlying this patent application and awarded National Electronic Warranty Company (the current Assignee of this patent application) the “Design and Engineering Showcase Award for 2010. See New Corp's award in the IDS being filed on the same day as this application. CEA grants this award to the company which produces the most innovative developments in “online retail” technology.
Landscapes
- Business, Economics & Management (AREA)
- Engineering & Computer Science (AREA)
- Accounting & Taxation (AREA)
- Development Economics (AREA)
- Strategic Management (AREA)
- Finance (AREA)
- Game Theory and Decision Science (AREA)
- Entrepreneurship & Innovation (AREA)
- Economics (AREA)
- Marketing (AREA)
- Physics & Mathematics (AREA)
- General Business, Economics & Management (AREA)
- General Physics & Mathematics (AREA)
- Theoretical Computer Science (AREA)
- Information Transfer Between Computers (AREA)
Abstract
Description
- This application claims the benefit of priority to U.S.
Provisional Applications 61/245,923 (filed Sep. 25, 2009) and 61/272,707 (filed Oct. 23, 2009); both of which are incorporated by reference in their entirety. - Current trends in the market place have influenced merchants to include service plans for many of their products. Sometimes the service plans are offered directly by a merchant, such as BestBuy's GeekSquad and Office Depot's Tech Depot Services, and in other cases a third party may fulfill a merchant's service plan obligations. Customers may purchase these services to receive additional support for their product, ideally increasing their use and enjoyment of it.
- Online merchants associate products with service plans or warranties so that a customer can buy an extended warranty or service plan when he or she purchases a product. Sometimes, however, a product should be listed as having a service plan, but an error in the listing causes the webpage on which the product is listed to not offer a service plan. Consequentially, the online merchant would not, in this case, offer the service plan to the customer. In other cases, the website of the online merchant may associate the product with an incorrect service plan. Because the sale of warranties or service plans may be a significant source of revenue for the merchant, merchants often expend considerable resources in checking their websites for mismatched warranties and products not having an associated warranty.
- One aspect of the present invention may relate to providing a web crawler which can identify missing or misassociated service plans or warranties. A second aspect of the present invention may relate to providing a dynamic mapper for determining what service plan should be associated with a particular product. In an embodiment of the web crawler configuration, the web crawler may be constructed so that it follows links on a merchant's website to find at least one product on a merchant's webpage, identifies which service plan is associated with that product, and determines whether the correct service plan has been associated with the product. Additional features of the web crawler embodiment may include a placement analyzer for determining where on the webpage the warranty is located, and whether the placement is easily visible to the customer. Another feature the web crawler may provide is a class generator for populating a relational database with information downloaded by the web crawler. Moreover, the web crawler may contain a smart crawling routine for preventing the web crawler from crawling blacklisted webpages. Other features of the web crawler may include a throttle controller for managing the web crawler's impact and strain on the merchant's website, and an error checking routine for tracking errors returned by the website.
- In an embodiment of a dynamic mapper configuration, a dynamic mapper is disclosed which allows a merchant to automatically map service plans to product webpages. This technique allows the merchant to avoid having to manually map the service plans with the product webpage, which may increase costs in personnel and also increase the number of incorrectly paired service plans to product pages. In an embodiment of the dynamic mapper, the merchant may send the dynamic mapper a request to add a product webpage to the merchant's website. The dynamic mapper may analyze the product to be added, and return content to the merchant. In some embodiments, the content may simply be information regarding the service plan (such as a warranty SKU). In other embodiments, the dynamic mapper may return an advertisement for the service plan itself. In the latter case, the merchant may incorporate the advertisement directly into the product webpage. If there is no service plan associated with the product webpage, the dynamic mapper may determine that no service plan should be included. The dynamic mapper may be able to determine whether the product should have a warranty by comparing product information, category, bread crumbs, and price info (etc.) against a set of previously collected data. This previously collected data may be used to allow the dynamic mapper to implement a Bayesian filter. An implementation of this filter may allow the dynamic mapper to determine whether the product webpage it is currently analyzing should have a service plan based on whether or not similar product webpages have a service plan. Alternatively or in addition, the dynamic mapper could use a rule-based engine to determine whether a particular product webpage should have a service plan. Once the service plan or service plans are identified, the dynamic mapper may return the service plan information back to the merchant. In some embodiments, the service plan may be identified simply by an identifier unique to each service plan (e.g. a warranty SKU).
- In an embodiment of the webserver, a webserver may be provided which contains instructions or software stored on computer readable media (hard drive/optical drive) and a processor (e.g. Intel or AMD microprocessor) for causing the webserver to perform a series of steps. The webserver may receive a request for a webpage containing details on a particular product from a client executing a web browser; determine the web browser version and type; and determine from the version and type whether the web browser supports asynchronous page loading. If the webserver determines that asynchronous page loading is supported by the web browser, the instructions in the computer readable media may cause the webserver to send a copy of the requested webpage to the client; send an update request to a file server; receive updated information to the file server; format the information from the file server so that it may be displayed by the web browser of the client; and send the formatted information to the web browser of the client. If the webserver determines that asynchronous page loading is not supported by the web browser, the instructions in the computer readable media may cause the webserver to send a request to the client to determine whether a media player such as Adobe Flash Media Player is installed. If the media player is installed, the instructions in the storage media of the webserver may cause the webserver to: send a webpage to the client containing details about a product, a control, and a media file; receive a transmission from a program executing the media file at the client; said transmission containing a request for updated information; send the request for updated information to the file server; receive a response from the file server which contains data; format the data so that it may be viewed by the web browser; and return the formatted data to the client.
- In yet another configuration, the client, webserver, and server could be configured so that the service plan server sends updated information directly to the client (bypassing the webserver). One way to accomplish this configuration would be to instruct the webserver to send a script to the client. Upon execution of the script, the client may send a request to the service plan server for service plan information.
- In the two preceding paragraphs discussing webserver, client, and service plan topology, configurations of the invention may be constructed which are not limited to service plans or products. For example, the above topology may be used to update news articles, sports scores, directories, or other webpages which may need to be updated depending on the particular client requesting the information, or need to be updated on a frequent basis.
- These and additional features are described in more detail in the detailed description of the invention.
-
FIG. 1 : is a schematic view of an embodiment of the present invention. -
FIG. 2 : is a screenshot of a merchant's homepage. -
FIG. 3 : is a screenshot of a category webpage of a merchant. -
FIG. 4 : is a screenshot of a subcategory webpage of a merchant. -
FIG. 5 : is a screenshot of a product webpage of a merchant. -
FIG. 6 : is a screenshot of a quasi category webpage of a merchant. -
FIG. 7 : is a schematic view of a database designed to be used with an embodiment of the present invention. -
FIG. 8 : is a screenshot of an example of the output of the interface output. -
FIG. 9 : is a screenshot of an example of the output of the interface output. -
FIG. 10 : is a screenshot of an example of the output of the interface output. -
FIG. 11 : is a screenshot of an example of the output of the interface output. -
FIG. 12 : is a screenshot of an example of the output of the interface output. -
FIG. 13 : is a schematic view of the dynamic mapper. -
FIG. 14A : is a flow diagram illustrating how information may be sent between a client, webserver, and file server. -
FIG. 14B : is a flow diagram illustrating a second embodiment of how information may be sent between a client, webserver, and file server if the client's web browser can be configured to natively accept asynchronous page loading. -
FIG. 14C : is a flow diagram illustrating a third embodiment of how information may be sent between a client, webserver, and file server if the client's web browser can be configured to natively accept asynchronous page loading. -
FIG. 14D : is a flow diagram illustrating an embodiment of how information may be sent between a client, webserver, and file server if the client's web browser does not natively accept asynchronous page loading. -
FIG. 14E : is a flow diagram illustrating a second embodiment of how information may be sent between a client, webserver, and file server if the client's web browser does not natively accept asynchronous page loading. -
FIG. 1 illustrates a schematic view of theweb crawler 10. The web crawler has many utilities including, for example, allowing a user to learn which products on a merchant's website are correctly paired with a service plan, and whether the service plan is sufficiently visible to the customers browsing the webpages of the merchant's website. A service plan is generally an agreement between the customer and a service plan provider to repair or replace a product if a prespecified condition occurs (e.g. the product breaks, wears down, etc.) A warranty is a type of service plan. Theweb crawler 10 may be stored on computer readable media (such as memory or an optical or magnetic disc) and take the form of computer executable instructions or software that a computer can execute to generate an instance of the webcrawler object. The computer may contain a processor, hard drive, motherboard, I/O connections, memory, or other typical hardware. Theweb crawler 10 may contain aninterface input 20 which can accept inputs from a user or another computer. For example, theinterface 20 may allow a user to enter a URL of ahomepage 210 of a desired webpage the user would like theweb crawler 10 to analyzer. Theinterface 20 may contain a control or button for instructing theweb crawler 10 to execute one or more the routines shown inFIG. 1 . For example, the interface may contain a webpage collector control and/or an analyzer control. In some embodiments, multiple routines may be combined into one control. Theinterface output 130 may contain inputs for receiving information from other routines (e.g. theplacement analyzer 90 or validator 100), and may be able to use information from these routines to generate an output for displaying results generated by the web crawler. An exemplary set of screenshots representing an embodiment of the invention is shown inFIGS. 8-12 .Interface output 130 may be a monitor or other display device, a printer, or a sound emission device.Interface 20 may send a request to thewebpage collector 50 to tell the retriever to collect webpages from the merchant'swebsite 200. (Thehomepage 210 of zapps.com—an exemplary retailer—is shown as an example inFIG. 2 ). As shown inFIG. 1 ,vertical links 221 connect thehomepage 210 to thewebpages horizontal link 222links webpage 250 towebpage 250′. Similarly inFIG. 2 ,vertical link 221 links thehomepage 210 tocategory webpage 250,FIG. 3 (the link to mp3 players is indicated). - The
web crawler 10 may also contain asmart crawler 30 for minimizing the number of webpages the downloader needs to download. The smart crawling routine 30 may contain a blacklist and/or a whitelist of items. Amatcher 31 may contain ablacklist routine 32 or awhitelist routine 33, or both. Thematcher 31 will attempt to matchbreadcrumbs 76, the name of theproduct 71, etc. (seeFIG. 5 ) against the terms in the blacklist or whitelist. In theblacklist routine 32, if thematcher 31 determines there is a match, thematcher 31 will allow thewebpage collector 50 to save the webpage information in the database, but it will instruct ahalter 35 which, if any item in the blacklist matches a breadcrumb, causes the smart crawler to download the current webpage and instructs the web crawler to avoid following any further links from the current webpage. In other embodiments, if thematcher 31 determines that some product information matches the blacklist, thematcher 31 will instruct thehalter 35 to prevent the webpage collector from saving the webpage in thedatabase 60. Inwhitelist routine 33, thematcher 31 will determine whether any of the product information matches any term in the whitelist. If thematcher 31 determines there is a match, thematcher 31 will allow thewebpage collector 50 to save the webpage information, but if there is no match, thematcher 31 will instruct thehalter 35 to prevent the current webpage from being saved. The smart crawler may also interact with acacher 99 which saves copies of the webpages into thedatabase 60. The amount of caching performed may be set by the user viainterface input 20. - The
web crawler 10 may contain a linkingsystem 40 which may contain alink follower 41 and alinker 45. Thelink follower 41 may retrieve and follow links 221-222 from thehomepage 210 or from thewebpage additional webpages FIG. 4 illustrates a subcategory webpage. Alinker 45 may determine whether a particular link should be followed by matching a part of the link's URL against a regular expression. For example, the words “category” 81, “subcategory” 82, “product” 83, or “catprop” may be used as terms to match against the URL to determine the type of page. Also, thelinker 45 may monitor the sequence of links to determine the type of page (often webpages progress from homepage 210->category page 250->subcategory page 260->product page 270), or thelinker 45 may rely on information determined fromanalyzer 70 such as breadcrumbs 76 (SeeFIG. 5 ) to determine the type of page currently being analyzed. - The
web crawler 10 may also contain awebpage collector 50 for collecting a current webpage associated with at least one of the links retrieved from the linking system. The collector may contain acategorizer 55 for categorizing the webpage as acategory webpage 250, a quasi category webpage 280 (FIG. 6 ), or a SKU orproduct webpage 270.Quasi category 200 webpages may provide products within acertain price range 84,brand 85, orsize 86 for example (SeeFIGS. 4 and 6 ). In some embodiments categorizer may rely on information fromanalyzer 70 to help determine the type of webpage being collected. - The
web crawler 10 may also contain adatabase 60 for storingwebpages 250 retrieved fromwebpage collector 50. An enlarged view of thedatabase 60 is shown inFIG. 7 . Agarbage 205collector 92 may remove unnecessary or empty classes in the database. In some embodiments a relational database may be used, and the database may comprise a number of classes such as amerchant class 61,category class 62,subcategory class 63A,quasi category class 63B,SKU class 64,SKU warranty class 65,page link class 66,page content class 67, category display filter class 68 (used for filtering down categories in the website), category spider filter class 69 (used for blacklisting certain specified websites). Aclass generator 93 may work in conjunction with theanalyzer 70 to build classes based upon the information determined byanalyzer 70. Atree builder 80 may be used to establish relationships or links between these classes. For example, in the embodiment shown inFIG. 7 , themerchant class 61 is linked to thecategory class 62 and thepage link class 66. Thecategory class 62 is liked to thesubcategory class 63A and thequasi category class 63B, thesubcategory class 63A and thequasi category class 63B are linked to theSKU class 64. The SKU class is linked to the SKU warranty class. Thepage link class 66 is linked to thepage content class 67. - The
web crawler 10 may also contain ananalyzer 70 for collecting information about a particular product. Referring toFIG. 5 , the analyzer can collect a name of theproduct 71, acategory 72 andsubcategory 73 of the class, pricing information on theproduct 74, pricing information relating to a service plan of theproduct 75,breadcrumbs 76, and images of theproduct 77. InFIG. 2 , the analyzer 70 (ofFIG. 1 ) has identified all seven types of information. Once identified, the analyzer may store this information in thedatabase 60.Breadcrumbs 76 provide contextual information for location of the product within a product page. As shown inFIG. 5 , the breadcrumbs are “Home>Categories>MP3 Players & Accessories>MP3/MP4 Players>iRiver America>Item#:N82E16855150095.” On some webpage such as the one shown, thebreadcrumbs 76 also provide theSKU 79, thecategory 72, and thesubcategory 73 information. The analyzer may collect information such as the name of themerchant 78 from either the URL or merchant logo, and theSKU 79. - The
web crawler 10 may also contain aplacement analyzer 90 for determining the quality of placement and location of the service plan on the current webpage. Theplacement analyzer 90 may have asimulator 91 for determining the service plan's visibility on the current webpage through simulating human interaction with the webpage to enable theanalyzer 90 to locate placement of the service plan on theSKU webpage 270, in a shopping cart, in a popup window, light box, or in a related items window (i.e. a window which suggests products other customers also bought.) In some embodiments, the placement analyzer may contain instructions for causing theweb crawler 10 to determine whether the service plan is placed before the bend of a webpage (i.e. is the service plan visible on a customer's screen without requiring the customer to scroll the screen?). - The
web crawler 10 may also contain avalidator 100 for examining the information relating to theproduct 83 and its associatedservice plan 75. Thevalidator 100 may receive webpage information from thedatabase 60 or directly fromwebpage collector 50. Thevalidator 100 may comprise arange checker 101 and a missingservice plan locator 105 for validating theproduct 83 andservice plan 75. Therange checker 101 can be used with anyproduct 83 having a service plan with a price range for products covered thereunder. For example, a service plan might generally cover products costing between 100-200 dollars. If thepricing information 74 for theproduct 83 is $240, therange checker 101 would determine the price of theproduct 83 is outside the range of the plan, optionally notify thecrawler 10 of this event, and optionally send the results of its analysis to theinterface output 130. The missingservice plan locator 105 may analyze products of aparticular subcategory 73, and determine whether any of the products in thesame subcategory 73 have a service plan, and if thelocator 105 determines that at least one of the products does have a service plan, thelocator 105 may notify theweb crawler 10 as to which products do not have an associated service plan. For example, if aproduct 83 such as a pink Ipod® Nano® (an MP3 player) has a service plan, but a black Ipod® Nano® does not, thelocator 105 will determine that the black Ipod® Nano® is likely missing an associated service plan, and thelocator 105 will notify the webcrawler that the black Ipod® Nano® does not have an associated service plan. Thelocator 105 may inform thecrawler 10 of this event, and may send the results of its analysis to theinterface output 130. Thelocator 105 may utilize various algorithms for determining whether a particular product should have a service plan. In a first configuration, thelocator 105 may utilize a string distance comparator to determine the Levenshtein distance between twoproduct names 71. Thelocator 105 may compare the string distance to a preestablished threshold value to enable thelocator 105 to determine whether the strings are sufficiently close together such that an inference should be made that if one of theproducts 83 has aservice plan 75, then the second product should have a service plan. For example, if thevalidator 100 is examining two products (such as an “iPod Nano Pink” and an “iPod Nano Black”) and thevalidator 100 determines that the Pink Ipod has a service and that the Black Ipod does not, thelocator 105 may use its string distance comparator to determine the strings have a distance of four, and if the preestablished threshold value is 8 (for example), thelocator 105 would determine that the string distance is less that the threshold value, thereby causing thelocator 105 to inform the validator 100 (which may send the result to the interface output 130) that the Black Ipod probably should have aservice plan 75 because the Pink Ipod has aservice plan 75. To take the opposite example, if the locator were comparing a “Ipod Nano Pink” to a “Griffin Aerosport Nano Armband,” thelocator 105 would determine the string distance is 21, and since 21>8, thelocator 105 would not conclude that the Griffin Aerosport Nano Armband should have a service plan. As an additional step, thelocator 105 may utilize category and/or subcategory matches to prevent nonsensical matches and deductions. For example, if the website offered both Cadillac cars and Cadillac dog food, thelocator 105 may use category and subcategory information to avoid concluding that dog food should come with a service plan, because the Cadillac cars come with a service plan. In a second configuration, thelocator 105 may use a Bayesian filter to classify products as having or not havingservice plan 75. To perform this classification, thelocator 105 may be trained to determine which products usually have aservice plan 75. To perform this training, thelocator 105 may be provided with test data to process. The test data will contain product attributes such asname 71,category 72,price 74, andbreadcrumbs 76. From these attributes, thelocator 105 can develop a centroid that thelocator 105 may use to classify theproduct 83 by its attributes as one which usually has aservice plan 75 or one that does not usually have aservice plan 75. Theweb crawler 10 may also contain athrottle controller 110 which may have aconnection limiter 111, abandwidth limiter 112, and arequest limiter 113. Presets for thethrottle controller 110 may be defaulted or set through theinterface 20.Connection limiter 111 may control the maximum number of simultaneous connections theweb crawler 10 orwebpage collector 50 may use while crawling the website. For example, theconnection limiter 111 may allow 5 simultaneous connections.Bandwidth limiter 112 may control how much data per unit of time the web crawler may download from the website. For example, the connection limiter may limit the download speed to 2 megabytes per second.Request limiter 113 may control the frequency the web crawler sends requests or queries to the website. For example, the request limiter could limit the requester 50 to 20 requests per minute. - The
web crawler 10 may also contain anerror checker 120 which may have a stopping routine 121, a totalerror threshold monitor 122, and afrequency error monitor 123. The webserver 205 (FIG. 13 ), hosting thewebsite 200, may return errors indicating toomany webpages 250 were requested, thewebpages 250 were requested too quickly, thewebpage 250 associated with aparticular link error checker 120 may comprise presets that may be defaulted or set through theinterface input 20. Stopping routine 121 can control thecrawler 10 or theretriever 50 by preventing either from downloading webpages for a period of time. Totalerror threshold monitor 122 is designed to monitor the amount of errors received from the website. The monitor may contain a preselected amount of errors per second, and may execute the stopping routine 121 to stop thecrawler 10 orretriever 50 if the amount of errors exceeds a threshold value, such as 20 errors. Frequency error monitor 123 may monitor the frequency of errors per unit of time received from the website. Themonitor 123 may execute the stopping routine to stop the crawler if the frequency of errors exceeds a threshold value, such as 5 errors/minute. -
FIG. 1 also illustrates a process flow of information and interaction between theweb crawler 10 and thewebsite 200. While a specific, sequenced process flow is shown inFIG. 1 and described herewith, various steps can be omitted or placed in a differing order than the one shown. Typically, when a user would like to use web crawler to crawl a website, he or she will 315 access theinterface input 20.Interface input 20 may request the user enter the URL of the homepage of the website the user would like to crawl. Additionally interfaceinput 20 may request other settings such as throttle, caching, or error settings. -
Interface input 20 then may send the information to thesmart crawler 30 which downloads the webpage.Smart crawler 30 may utilize its whitelist and/or blacklist to determine whether to process any links on the homepage. Thesmart crawler 30 then sends the homepage towebpage collector 50. In some embodiments, thesmart crawler 30 may send any errors received in conjunction with the homepage to theerror checker 120.Error checker 120 may monitor and regulate the actions of the smart controller depending on the amount or frequency of received errors. In some embodiments, theerror checker 120 may send the results of its error analysis to thewebpage collector 50.Smart crawler 30 also may send bandwidth and network information to thethrottle controller 110 which will monitor and regulate the network performance of thesmart crawler 30. -
Webpage collector 50 may use itscategorizer 55 to determine the type of webpage it is currently collecting. If the current webpage being collected is acategory 250,subcategory 260 orquasi category 280 webpage, the collector will send a request (and optionally the results of the categorizer's analysis) to the linkingsystem 40, which will access thewebsite 200 to find and process further links to find theSKU webpage 270. Linking 40 system may use itslinker 45 andlink follower 41 to determine which links to analyze and process. The results of the linking system's analysis are sent back to thesmart crawler 30, which downloads the next webpage specified by the linkingsystem 40. - If the webpage now being processed is a
webpage webpage collector 50 may send the webpage toplacement analyzer 90,cacher 99, and/oranalyzer 70.Placement analyzer 90 may evaluate the placement and visibility of the service plan, but it may need information fromanalyzer 70 to inform it of the positioning of the service plan. In some embodiments theanalyzer 70 may send both the webpage and the results of its analysis toplacement analyzer 90.Cacher 99 may determine whether or not to save or cache the webpage in thedatabase 60.Analyzer 70 may determine the content and location of information such ascategory 72 orbreadcrumbs 76 on the webpage, and then send the results of its analysis to thedatabase 60. -
Database 60 may use itsclass generator 93 to create classes fordatabase 60.Tree builder 80 may establish relationships between the classes, andgarbage collector 92 may remove blank or not needed classes.Validator 100 may request information from the database 60 (such as objects of the classes created by the class generator) and process the information to determine whether the product on the webpage should have a service plan, and whether the service plan offered is the correct service plan through using thelocator 105 and therange checker 101.Validator 100 may then send the results of its analysis tointerface output 130.Interface output 130 may generate an output to display the results gathered from theplacement analyzer 90 and/or the validator 100 (or other routine). In some case, the computer processing the webcrawler software may transfer the output to a display or a monitor or print the results on paper to inform the user of the results of the analysis performed byweb crawler 10. In some embodiments, the details of these results may be customized by the user.FIG. 8 for example shows a flat report of a retailor's (Zaps) website. Thereport display 300 can show a number of different fields and in some embodiments the contents of the fields or their order can be customized by the user or by the software. In the embodiment shown, there is a description column, a price column, a Yes/No warranty indication column, a first warranty description column, a first price for the warranty column, a first warranty name column, a second warranty description column, a second price for the warranty column, and a second warranty name column. Thecategory filter 305 may allow theinterface output 130 to restrict its output to certain categories of items. Category, subcategory, and breadcrumb information may be determined by theanalyzer 70 to populate this field. In this embodiment, the flat report view (FIG. 8 ) has a number oftabs 310 for causing the interface output to switch the current view. These tabs includereport 313,explorer 311, filters,statistics 312, status, and administration. This embodiment of the output of theinterface output 130 includes asearch command 320 for searching for certain terms of keywords in thereport display 300. The search command, in this embodiment, can filter by the presence or absence of a warranty (using the warranty filter 325) or by price (using the price filter 330). Thereport generator function 335 may be used to switch the format of the report display. InFIG. 8 , the flat report display is shown, but inFIG. 9 , a hierarchical display is shown. Clicking on the radial button, causes theinterface output 130 to switch the display format. The hierarchical display (FIG. 9 ) shows category and subcategory information in the report display. Additionally, in this embodiment, the report display illustrates the number of products available in the present view. In this particular embodiment, a description, price, warranty description, warranty price, and warranty name columns are generated by theinterface output 130. One advantage of this layout as compared to the flat layout is that it shows products by their category information, but a disadvantage of this layout is that somewhat less detailed information about the warranty is displayed byinterface output 130. Clicking on theexplorer tab 311 instructs theinterface output 130 to display the explorer interface (seeFIG. 10 ). This interface provides additional information about the product being sold, and through popup windows provides detailed views of warranty information.FIG. 10 shows thefirst warranty window 340 theinterface output 130 generates when the product hyper link (341) is clicked.FIG. 11 shows thesecond warranty window 342 theinterface output 130 generates when thewarranty icon 343 is clicked. Clicking thestatistics tab 312 instructs theinterface output 130 to display the statistics output (FIG. 12 .) In this example, crawling activity on Zaps webpage is shown. Various types of information is compiled and illustrated by theinterface output 130 in this view. For example, the number of products having warranties can be calculated, the amount data pulled from the merchant's website can be displayed (this data may come from thethrottle controller 110 for example), and the total number of webpages downloaded can be displayed. - The
webcrawler 10 may be used to determine which products on a merchant's website have or should have warranties or service plans, and which products are correctly paired with the warranty or service plan. Once a user learns this information, he or she may relay it to the merchant (in some embodiments the merchant may be able to use the software directly). In such a case, the merchant may still need to have personnel update the merchant's website to add the missing warranties or service plans and update the incorrectly paired warranties or service plans. - One way to avoid having to pay personnel to update mismatched or missing service plans is to build a system which automatically selects a correct service plan when a product webpage is updated or added to a merchant's
website 200. A dynamic mapper may be used to select which service plan should be paired with a particular product. The dynamic mapper may be stored on computer readable media and comprise instructions for causing a processor of a computer to execute the instructions, thereby creating an instance of the dynamic mapper. The computer may contain a processor, hard drive, motherboard, I/O connections, memory, or other typical hardware. - As shown in
FIG. 13 , in one embodiment for adding a dynamic mapper to a merchant's website involves adding acontrol 400 onto aproduct webpage 410, search page, or shopping cart. Then, when a consumer views the product—or adds it to the shopping cart—thecontrol 400 may send a request 5400 including the product name, price, category, SKU breadcrumbs, and/or other information to aservice plan server 420, to instruct aprocessor 421 in theserver 420 to lookup S402 which service plan should be associated with the particular product by accesing a database 422. Theprocessor 421 returns 5410 electronic data back to thecontrol 400. The electronic data may simply be html code which allows thecontrol 400 to display warranty information or provide a selector to choose among multiple service plans (2 yr or 3 yr plans for example). In other configurations, the electronic information may include a sales pitch, service plan options, or an advertisement. Thecontrol 400 may display and/or process the electronic data so that theproduct webpage 410 andcontrol 400 appear to be one integral page. Alternatively, thecontrol 400 may store the electronic data locally, and send a request for updated information from theservice plan server 420 when certain conditions are met. Such requests may be sent after a predetermined period of time elapses (e.g. once a year), or anytime the product information is modified. The electronic data may contain text, images, videos, popup panels, and other types of rich media. Thecontrol 400 may support chat functions to allow customers to ask questions about a service. If a customer wants to purchase the service plan, he or she may have the option to click a purchase button to add the service to their shopping cart. In a way, the content returned by the dynamic mapper may act like part of the underlying webpage; as opposed to a banner type advertisement. One way to allow a user to update his or her order, is to construct thecontrol 400 so that thecontrol 400 sends a request to thewebserver 205 hosting the webpage when the user clicks a button or other element in the control. The request 5420 sent by thecontrol 400 to thewebserver 205 may contain information to allow thewebserver 205 to display S425 updated information such as a new combined price. - The dynamic mapper may also track customer behavior and sales outcome to determine a success rate of different embodiments of the
control 400. To do so, thewebserver 205 may store S435 the outcome of what happens in awebserver database 430 when alternative embodiments of thecontrol 400 are used (sales pitch, radial box with options, chat popup, etc). In other words, thewebserver database 430 may store a consumer's decision whether or not to purchase a service plan advertised through thecontrol 400. For example, when the consumer presses a “Buy” button 401, the consumer's computer may submit S430 information to thewebserver 205 including the service plan selected, the current embodiment of thecontrol 400, and perhaps the total price. Ananalysis engine 435 may process this information, and determine which embodiments of thecontrol 400 are more effective in persuading customers to purchase the service plan. In some configurations, theanalysis engine 435 may take into account information about the purchaser including the location of the purchaser (obtainable from the purchaser's IP address), the merchant from which the customer is purchasing the item, the time of day or year of the purchase (during the workday or at Christmas time for example.) Moreover, if the merchant's website or the customer sends information about the customer to thewebserver 205 or analysis engine 435 (such as the customer's phone number) this information can be cross-referenced against a database to obtain additional information about the customer including gender, income, age, etc. The dynamic mapper may use this information to determine which type of advertisement for the service provider is most effective for the particular customer to maximize sales of the product and/or the service plan. The analysis engine may send S440 an instruction back to the webserver to direct the webserver as to which type ofcontrol 400 to use to optimize the likelihood that a particular customer will purchase the service plan. - The
service plan server 420 may use Bayesian algorithms, statistical analysis, rule-based engines, or other techniques to identify which service plans should be associated with a given product. Based on these techniques, the service plan server may determine what type of advertisement it should display to the customer, and return this advertisement to thecontrol 400. - The dynamic mapper may also be constructed so that the
control 400 downloads dynamic content only after theproduct webpage 410 has been displayed to the customer. This prevents the advertisement for the service plan from increasing page load time. This may be significant as an increase in page load time may decrease sales of the underlying product. Additionally, the dynamic mapper may be constructed so that thecontrol 400 cannot modify the underlying product webpage. This may be a valuable security benefit to the merchant. Additionally, if the control is restricted to a particular area of the webpage, a failure of the dynamic mapper to return the advertisement may cause displayer to display nothing, thereby making this failure transparent to a customer. -
FIGS. 14A-E show how information may be delivered to a client. InFIG. 14A , a client 500 (utilizing a web browser) may send S500 a request to awebserver 205 for a particular webpage adverting a particular product. Thewebserver 205 may determine thewebpage 510 which is being requested, and may send S502 a request to theservice plan server 420 to update the service plan information stored in thewebserver 205 for the particular product. Theservice plan server 420 may determine attributes about the service plan and send S504 a service plan in the form of an executable program to the webserver 205 (although data may be sent instead or in addition). Thewebserver 205 may update S506 the webpage, and then send S508 the updatedwebpage 520 to theclient 500. While this approach works, it has several short-comings. First, this process will increase the amount of time it takes for the client to obtain the information, because it can take several seconds for thewebserver 205 to negotiate the connection with theservice plan server 420. Second, sending a program (or other executable code (javascript, applets, etc.)) from theservice plan server 420 exposes the webserver and the client to potential security risks. For example, a rogue employee working at theservice plan server 420 could send malicious code to thewebserver 205. Or, a third party could hack into theservice plan server 420 to transmit the malicious program. Recognizing the weaknesses in the FIG. 14A's model, the following multistep approaches were devised. -
FIGS. 14B and 14C show a process and system which utilizes asynchronous page loading. In general, older web browsers are not configured to accept asynchronous page transmissions. As shown inFIG. 14B , aclient 500 having aweb browser 502 may send a request to awebserver 205 to send awebpage 510 having information on one or more products, images, and service plan information (in other configurations the webpage could contain information on news, sports, entertainment etc). When the request is sent, thewebserver 205 may review the query string parameters (information included with the URL to provide server additional information) included within the client's request for thewebpage 510. Using HTTP request headers, the webserver may be able to determine S510 the version and type of the browser making the request, and from that information, determine whether the browser supports asynchronous page loading. In alternate configurations, thewebserver 205 may transmit a webpage to the client which contains a script (seeFIG. 14C ). This script may attempt to send a request S505′ to theservice plan server 420 to update the webpage, if this procedure succeeds, an embodiment related toFIG. 14C may be followed. (FIGS. 14D and E illustrate examples of configurations of process flows if the script fails or the web browser does not support asynchronous page updating.) - If the browser supports asynchronous page loading (such as
IE 8 or Firefox 3), the web browser may be able to receive updates to a webpage as the web browser is displaying the webpage. Under this approach, thewebserver 205 may send S503 the webpage to theclient 500 and an update request S505 to theservice plan server 420. Theservice plan server 420 may lookup S507 the requested information, and transmit S509 the retrieved information back to thewebserver 205. The webserver may receive the information from the server, format it S511 into an update for the client, and transmit S508 the update to the client. Under this model (FIG. 14B ), theclient 500 can view product information on thewebpage 510 quickly, while the service plan server sends updates for the webpage. Updates (shown schematically as ovals) may be implemented in any portion of the webpage and are not necessarily localized to a particular portion of the webpage. Images and other items having a large file size may also be sent asynchronously via update S512. - In
FIG. 14C , thewebserver 205 may send awebpage 510 containing a script (e.g. a java script for instructing theweb browser 502 to request additional information from a service plan server 420) to the client. Theweb browser 502 may transmit S505′ information about a particular product so theservice plan server 420 can determine which service plan information to look-up. Once the service plan is determined, theservice plan server 420 can send S508′ service plan information back to theclient 500. EitherFIG. 14B or 14C may be used to update a client webpage asynchronously. One advantage toFIG. 14B is that the information that the client receives may appear to originate from thewebserver 205. This is effective in overcoming ad-blocking technology which may prevent 3rd party webservers from adding content to a webpage. Additionally, the embodiment ofFIG. 14B may be effective in distributing information to clients which have theirweb browser 502 settings set to high levels. Advantages of the topology ofFIG. 14C include reduced load time for information in theserver plan server 420 because the information does not need to be sent through thewebserver 205. Additionally, the topology ofFIG. 14B requires the webserver to handle more processing tasks which may require more powerful webservers to implement. -
FIGS. 14D-14E illustrate two embodiments of a webserver process flow for a client that has a web browser which does not support asynchronous page loading (e.g. IE 3 or Firefox 1). InFIG. 14D , thewebserver 205 may send a request S513 to determine whether a particular media player (e.g. Adobe Flash Media Player, Microsoft Silverlight, etc.) is installed. If the media player is installed, thewebserver 205 can send S503 awebpage 510 containing a media file (e.g. a Flash movie) to theclient 500. The media file may be very small and may be placed in a remote location of thewebpage 510 so that it is unlikely an individual looking at the webpage will see it. The media file may also be very small in file length (<100 k) and movie length (<1 second). In this step, the transmitted webpage may contain details about the product, possibly images, the media file, and a control. In some embodiments, the control may be written using Java script, an applet, or other programming code. The control may be configured so that it awaits information from thewebserver 205 to cause the program to execute and display some type of service plan information. - As shown in step S514 (
FIG. 14D ), the program executing the media file may send S514 a request for additional information to webserver 205 (e.g. updated service plan information). Alternatively, the request may be sent directly S514′ to theservice plan server 420. InFIG. 14D , thewebserver 205 may receive S515 the request, and send S516 its own request to theservice plan server 420 to lookup S517 service plan information concerning the product the client is viewing. Once theservice plan server 420 fetches the needed service plan information (utilizing the techniques explained above, rule engines/Bayesian filters, etc.), theserver 420 may format the results it obtains (e.g. using XSLT template), and return S518′ data or information back to thewebserver 205. To address security concerns that theservice plan server 420 may send the webserver 205 a malicious program, thewebserver 205 andservice plan server 420 may be configured so that theservice plan server 420 only sends data (for example XML code and XSLT template) to the webserver 205 (thewebserver 205 may be configured only to receive data, i.e. not program code). Thewebserver 205 may contain a program for accepting the data. Thewebserver 205 may also contain aprogram 530 which will use the received data to generate an executable program, which thewebserver 205 can send S518 to theclient 500. In some embodiments, thewebserver 205 may also send S518 the information (e.g. XML and XSLT) to theclient 500. In the former option, once theclient 500 has theexecutable program 530, the browser can cause the program to be executed thereby displaying the service plan information. In the latter option, the information may be passed to the control and be executed by the control to display the service plan information. Also, theservice plan server 420 may send the information or program directly to the client 500 (FIG. 14E ). - The configurations illustrated and described in
FIG. 14A-E may used independently or combined into a single multistep system/method. For example, the process/system illustrated and described in conjunction withFIGS. 14A , B, and D could be combined into a multistep system/process. Namely, thewebserver 205 could determine whether the browser of theclient 500 natively supports (either as installed or with add-ins or extensions) asynchronous page loading. If so, thewebserver 205 could implement the model shown and described in conjunction withFIG. 14B . If asynchronous page loading is not supported, thewebserver 205 could send a webpage containing a script for determining whether a particular media player is installed. If so, thewebserver 205 could implement the model shown and described in conjunction withFIG. 14D . If Adobe Flash is not installed (and the browser does not natively support asynchronous page loading), thewebserver 205 could implement the model shown and described in conjunction withFIG. 14A . Similarly, the process/system illustrated and described in conjunction withFIGS. 14A , C, and E could be combined into a multistep system/process. Namely, thewebserver 205 could send awebpage 510 to theclient 500 containing a script. The script could attempt to update the webpage via a third party service plan server 420 (FIG. 14C ). If the script fails because asynchronous page updating is not supported (or is disabled), the script could attempt to use a media player to update the content of the webpage (FIG. 14E ). If that attempt fails because the media player is not installed, for example, the process ofFIG. 14A could be followed. One advantage to using these multi-tiered processes is that these processes identify an efficient way to deliver an updatedwebpage 520 to the client depending on the software (web browser, media player) installed on the client. - Although the preceding description of
FIG. 14A-E referenced in some locations a system and method designed for updating service plan information in relation to a product listing hosted on awebserver 205, the preceding technology may be adapted to a number of general technical areas/uses. For example, in alternative configurations theservice plan server 420 may be a generalized file server containing a database of information of interest to theclient 500 orwebserver 205. Thewebserver 205 may be able to send a first version of a webpage to the client, while the file server sends updates to the webpage to theclient 500. Additionally, the preceding technology may be adapted to allowwebserver 205 to update the webpage as data in theserver 420 changes. For example, sports scores or stock prices may be updated on a webpage using this technology without the client refreshing the webpage. In some embodiments theserver 420 may alert thewebserver 205 that it contains updated information and push new data to thewebserver 205. - The current assignee of the present application was recently awarded an award by the Consumer Electronics Association for the technology described in the
provisional applications 61/245,923; and 61/272,707 (incorporated by reference). The Consumer Electronics Show (an annual awards presentation produced by the Consumer Electronics Association) reviewed a description of the technology underlying this patent application and awarded National Electronic Warranty Company (the current Assignee of this patent application) the “Design and Engineering Showcase Award for 2010. See New Corp's award in the IDS being filed on the same day as this application. CEA grants this award to the company which produces the most innovative developments in “online retail” technology. Also in the IDS are copies of a webpage from CEA announcing the award (currently listed on the web at http://www.cesweb.org/awards/innovations/2010honorees.asp?category=931397), and a copy of a webpage from NEW Corp discussing the award (currently listed on the web at http://www.businesswire.com/portal/site/home/permalink/?ndmViewId=newsview&newsId=20100105006253&newsLang=en). Consumer Electronics Association is widely regarded as one of the preeminent consumer electronics review organizations in the world, and CEA's decision to award NEW Corp with the award is evidence of the novelty and unobviousness of the below claimed invention. These three documents are hereby incorporated by reference in their entirety. - The invention may be embodied in other specific forms without departing from the spirit or essential characteristics thereof. The present embodiments are therefore to be considered in respect as illustrative and not restrictive; the scope of the invention being indicated by the appended claims rather than by the foregoing description, and changes which come within the meaning and range of the equivalency of the claims are therefore intended to be embraced therein.
Claims (32)
Priority Applications (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
US12/851,457 US20110078029A1 (en) | 2009-09-25 | 2010-08-05 | Systems and methods for hosting, updating, and sending a webpage |
Applications Claiming Priority (3)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
US24592309P | 2009-09-25 | 2009-09-25 | |
US27270709P | 2009-10-23 | 2009-10-23 | |
US12/851,457 US20110078029A1 (en) | 2009-09-25 | 2010-08-05 | Systems and methods for hosting, updating, and sending a webpage |
Publications (1)
Publication Number | Publication Date |
---|---|
US20110078029A1 true US20110078029A1 (en) | 2011-03-31 |
Family
ID=43781342
Family Applications (3)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
US12/851,447 Active 2031-10-13 US9082126B2 (en) | 2009-09-25 | 2010-08-05 | Service plan web crawler |
US12/851,457 Abandoned US20110078029A1 (en) | 2009-09-25 | 2010-08-05 | Systems and methods for hosting, updating, and sending a webpage |
US12/851,451 Abandoned US20110078015A1 (en) | 2009-09-25 | 2010-08-05 | Dynamic mapper |
Family Applications Before (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
US12/851,447 Active 2031-10-13 US9082126B2 (en) | 2009-09-25 | 2010-08-05 | Service plan web crawler |
Family Applications After (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
US12/851,451 Abandoned US20110078015A1 (en) | 2009-09-25 | 2010-08-05 | Dynamic mapper |
Country Status (2)
Country | Link |
---|---|
US (3) | US9082126B2 (en) |
WO (1) | WO2011037691A1 (en) |
Cited By (8)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US20120198056A1 (en) * | 2011-01-31 | 2012-08-02 | Yaacov Shama | Techniques for Analyzing Website Content |
US20120290935A1 (en) * | 2011-05-12 | 2012-11-15 | Koji Ihara | Information processing apparatus, server device, information processing method, computer program, and content sharing system |
US20150051969A1 (en) * | 2011-06-17 | 2015-02-19 | Google Inc. | Advertisements in view |
WO2016105676A1 (en) * | 2014-12-22 | 2016-06-30 | International Bridge, Inc. | Parcel shipping screening and validation |
US9535889B2 (en) | 2011-06-17 | 2017-01-03 | Google Inc. | Method to determine whether advertisements in a web page are in view |
US9576303B2 (en) | 2011-06-17 | 2017-02-21 | Google Inc. | Advertisements in view |
US9830392B1 (en) | 2013-12-18 | 2017-11-28 | BloomReach Inc. | Query-dependent and content-class based ranking |
US10417602B2 (en) | 2017-04-18 | 2019-09-17 | International Bridge, Inc. | Item shipping screening and validation |
Families Citing this family (47)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US8332408B1 (en) * | 2010-08-23 | 2012-12-11 | Google Inc. | Date-based web page annotation |
US8775431B2 (en) * | 2011-04-25 | 2014-07-08 | Disney Enterprises, Inc. | Systems and methods for hot topic identification and metadata |
US20130054316A1 (en) * | 2011-08-22 | 2013-02-28 | Microsoft Corporation | Managing presentation of commercial communications including electronic mail and advertisements |
US20130173593A1 (en) * | 2011-12-28 | 2013-07-04 | Target Brands, Inc. | Breadcrumb filtering |
US8579187B2 (en) | 2012-02-28 | 2013-11-12 | Ebay Inc. | System and method to identify machine-readable codes |
IN2015DN00474A (en) * | 2012-07-25 | 2015-06-26 | Indix Corp | |
US10169802B2 (en) | 2012-07-25 | 2019-01-01 | Indix Corporation | Data refining engine for high performance analysis system and method |
US10628503B2 (en) * | 2012-11-27 | 2020-04-21 | Gubagoo, Inc. | Systems and methods for online web site lead generation service |
US9189798B2 (en) * | 2012-11-27 | 2015-11-17 | Gubagoo, Inc. | Systems and methods for online website lead generation service |
US10600114B2 (en) * | 2012-12-21 | 2020-03-24 | W.W. Grainger, Inc. | Manufacture for providing access to product information and related functionalities |
US8954546B2 (en) | 2013-01-25 | 2015-02-10 | Concurix Corporation | Tracing with a workload distributor |
US9256969B2 (en) * | 2013-02-01 | 2016-02-09 | Microsoft Technology Licensing, Llc | Transformation function insertion for dynamically displayed tracer data |
US8997063B2 (en) | 2013-02-12 | 2015-03-31 | Concurix Corporation | Periodicity optimization in an automated tracing system |
US20130283281A1 (en) | 2013-02-12 | 2013-10-24 | Concurix Corporation | Deploying Trace Objectives using Cost Analyses |
US8924941B2 (en) | 2013-02-12 | 2014-12-30 | Concurix Corporation | Optimization analysis using similar frequencies |
US9665474B2 (en) | 2013-03-15 | 2017-05-30 | Microsoft Technology Licensing, Llc | Relationships derived from trace data |
US9575874B2 (en) | 2013-04-20 | 2017-02-21 | Microsoft Technology Licensing, Llc | Error list and bug report analysis for configuring an application tracer |
US9734040B2 (en) | 2013-05-21 | 2017-08-15 | Microsoft Technology Licensing, Llc | Animated highlights in a graph representing an application |
US8990777B2 (en) | 2013-05-21 | 2015-03-24 | Concurix Corporation | Interactive graph for navigating and monitoring execution of application code |
US9280841B2 (en) | 2013-07-24 | 2016-03-08 | Microsoft Technology Licensing, Llc | Event chain visualization of performance data |
US11922475B1 (en) | 2013-07-25 | 2024-03-05 | Avalara, Inc. | Summarization and personalization of big data method and apparatus |
CN105637504A (en) * | 2013-08-15 | 2016-06-01 | 诺基亚技术有限公司 | Apparatus and method for facilitating browser navigation |
US9292415B2 (en) | 2013-09-04 | 2016-03-22 | Microsoft Technology Licensing, Llc | Module specific tracing in a shared module environment |
WO2015071777A1 (en) | 2013-11-13 | 2015-05-21 | Concurix Corporation | Software component recommendation based on multiple trace runs |
CN105765528B (en) | 2013-11-13 | 2019-09-24 | 微软技术许可有限责任公司 | Method, system and medium with the application execution path trace that configurable origin defines |
US9495457B2 (en) * | 2013-12-26 | 2016-11-15 | Iac Search & Media, Inc. | Batch crawl and fast crawl clusters for question and answer search engine |
KR20150120123A (en) * | 2014-04-17 | 2015-10-27 | 삼성전자주식회사 | Method And Apparatus For Offering Information |
CN105656707B (en) * | 2014-11-18 | 2019-03-26 | 阿里巴巴集团控股有限公司 | A kind of method and system of test network crawler |
US10104107B2 (en) * | 2015-05-11 | 2018-10-16 | Qualcomm Incorporated | Methods and systems for behavior-specific actuation for real-time whitelisting |
CN106126715B (en) * | 2016-06-30 | 2019-06-04 | 北京奇虎科技有限公司 | A method and device for recording rendering data in a web page |
US11093557B2 (en) * | 2016-08-29 | 2021-08-17 | Zoominfo Apollo Llc | Keyword and business tag extraction |
US11282091B2 (en) * | 2016-09-30 | 2022-03-22 | Transitiv, Inc. | Systems, methods, and devices for dynamic page feed management |
US20180330385A1 (en) * | 2017-05-15 | 2018-11-15 | Atlas Certified, LLC | Automated and distributed verification for certification and license data |
CN109784960B (en) * | 2017-11-10 | 2024-05-14 | 北京奇虎科技有限公司 | Creative automatic auditing method, device and equipment |
US10353676B2 (en) | 2017-11-13 | 2019-07-16 | Bank Of America Corporation | Intelligent software compiler dependency fulfillment |
CN108170551B (en) * | 2018-01-03 | 2021-06-22 | 深圳壹账通智能科技有限公司 | Crawler system based front-end and back-end error processing method, server and storage medium |
WO2019148155A1 (en) * | 2018-01-29 | 2019-08-01 | Service Trading Company, Inc. | Product and contractor service mapping for computer-mediated reality systems |
US10991037B1 (en) * | 2018-02-13 | 2021-04-27 | Facebook, Inc. | Analyzing tracking requests generated by client devices based on metadata describing web page of a third party website |
US20190266634A1 (en) * | 2018-02-26 | 2019-08-29 | Baruch AXELROD | On-line Shopping Cart Chat |
US11100555B1 (en) * | 2018-05-04 | 2021-08-24 | Coupa Software Incorporated | Anticipatory and responsive federated database search |
US10296552B1 (en) * | 2018-06-30 | 2019-05-21 | FiaLEAF LIMITED | System and method for automated identification of internet advertising and creating rules for blocking of internet advertising |
US10650358B1 (en) | 2018-11-13 | 2020-05-12 | Capital One Services, Llc | Document tracking and correlation |
CN112905867B (en) * | 2019-03-14 | 2022-06-07 | 福建省天奕网络科技有限公司 | Efficient historical data tracing and crawling method and terminal |
CN110083751A (en) * | 2019-03-18 | 2019-08-02 | 平安科技(深圳)有限公司 | The anti-crawler grasping means of web data and device, storage medium, electronic equipment |
CN111428107B (en) * | 2020-03-23 | 2023-09-01 | 新华智云科技有限公司 | Multi-center comprehensive web crawler system |
US11756049B1 (en) * | 2020-09-02 | 2023-09-12 | Amazon Technologies, Inc. | Detection of evasive item listings |
US11347579B1 (en) | 2021-04-29 | 2022-05-31 | Bank Of America Corporation | Instinctive slither application assessment engine |
Citations (13)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US20020156699A1 (en) * | 2001-04-20 | 2002-10-24 | Joseph Gray | System of upselling in a computer network environment |
US20030177175A1 (en) * | 2001-04-26 | 2003-09-18 | Worley Dale R. | Method and system for display of web pages |
US6874120B2 (en) * | 2001-04-05 | 2005-03-29 | International Business Machines Corporation | Method, system, and product for efficient retrieval of information related to data input into a data entry form from the data entry form |
US20050216290A1 (en) * | 2004-03-29 | 2005-09-29 | The Go Daddy Group, Inc. | Web site design and copyright process |
US20070208641A1 (en) * | 2006-03-03 | 2007-09-06 | Bayview Lending Group Llc | Automated loan processing system and method for processing loans |
US20080027878A1 (en) * | 2006-05-12 | 2008-01-31 | Hookumu Incorporated | Systems and methods for establishing a space planning network |
US20080148161A1 (en) * | 2004-12-27 | 2008-06-19 | Sap Aktiengesellschaft | Webpage Autorefresh |
US20080162329A1 (en) * | 2006-12-19 | 2008-07-03 | Knapp Jason J A | Auction For Each Individual Ad Impression |
US20080306816A1 (en) * | 2007-06-06 | 2008-12-11 | Nebuad, Inc. | Network devices for replacing an advertisement with another advertisement |
US20090222317A1 (en) * | 2008-02-29 | 2009-09-03 | Tim Allen | Systems and methods for generating electronic upsell directory |
US20100106565A1 (en) * | 2008-10-27 | 2010-04-29 | Fotomoto, Inc. | Embeddable Distributed E-Commerce And Community Building System |
US20100223107A1 (en) * | 2005-09-06 | 2010-09-02 | Interpolls Network Inc. | Systems and methods for integrating xml syndication feeds into online advertisement |
US7975019B1 (en) * | 2005-07-15 | 2011-07-05 | Amazon Technologies, Inc. | Dynamic supplementation of rendered web pages with content supplied by a separate source |
Family Cites Families (34)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US6625581B1 (en) * | 1994-04-22 | 2003-09-23 | Ipf, Inc. | Method of and system for enabling the access of consumer product related information and the purchase of consumer products at points of consumer presence on the world wide web (www) at which consumer product information request (cpir) enabling servlet tags are embedded within html-encoded documents |
US6029141A (en) * | 1997-06-27 | 2000-02-22 | Amazon.Com, Inc. | Internet-based customer referral system |
US6351467B1 (en) * | 1997-10-27 | 2002-02-26 | Hughes Electronics Corporation | System and method for multicasting multimedia content |
US6226618B1 (en) * | 1998-08-13 | 2001-05-01 | International Business Machines Corporation | Electronic content delivery system |
US6785671B1 (en) * | 1999-12-08 | 2004-08-31 | Amazon.Com, Inc. | System and method for locating web-based product offerings |
US6819343B1 (en) * | 2000-05-05 | 2004-11-16 | Microsoft Corporation | Dynamic controls for use in computing applications |
US7366721B1 (en) * | 2000-08-29 | 2008-04-29 | Intel Corporation | Method and apparatus for displaying a plurality of related products to a user based upon the selection of a main product by the user |
US7464092B2 (en) * | 2001-04-04 | 2008-12-09 | Alorica, Inc | Method, system and program for customer service and support management |
US20020188527A1 (en) * | 2001-05-23 | 2002-12-12 | Aktinet, Inc. | Management and control of online merchandising |
AU2002355530A1 (en) * | 2001-08-03 | 2003-02-24 | John Allen Ananian | Personalized interactive digital catalog profiling |
US20030110158A1 (en) * | 2001-11-13 | 2003-06-12 | Seals Michael P. | Search engine visibility system |
WO2005046195A1 (en) * | 2003-11-05 | 2005-05-19 | Nice Systems Ltd. | Apparatus and method for event-driven content analysis |
US7788160B2 (en) * | 2004-04-16 | 2010-08-31 | Sap Ag | Method and system for configurable options in enhanced network-based auctions |
US20060184613A1 (en) * | 2005-02-15 | 2006-08-17 | Xata Corporation | Data conduit |
US8768766B2 (en) * | 2005-03-07 | 2014-07-01 | Turn Inc. | Enhanced online advertising system |
US7562304B2 (en) * | 2005-05-03 | 2009-07-14 | Mcafee, Inc. | Indicating website reputations during website manipulation of user information |
US9384345B2 (en) * | 2005-05-03 | 2016-07-05 | Mcafee, Inc. | Providing alternative web content based on website reputation assessment |
US7949646B1 (en) * | 2005-12-23 | 2011-05-24 | At&T Intellectual Property Ii, L.P. | Method and apparatus for building sales tools by mining data from websites |
US20070180521A1 (en) * | 2006-01-31 | 2007-08-02 | International Business Machines Corporation | System and method for usage-based misinformation detection and response |
WO2008108750A1 (en) * | 2006-02-06 | 2008-09-12 | Cnet Networks, Inc. | Controllable automated generator of optimized allied product content |
US7861176B2 (en) * | 2006-04-13 | 2010-12-28 | Touchcommerce, Inc. | Methods and systems for providing online chat |
US20070276720A1 (en) * | 2006-05-26 | 2007-11-29 | Campusl, Inc. | Indexing of a focused data set through a comparison technique method and apparatus |
US8209320B2 (en) * | 2006-06-09 | 2012-06-26 | Ebay Inc. | System and method for keyword extraction |
US20080072139A1 (en) * | 2006-08-20 | 2008-03-20 | Robert Salinas | Mobilizing Webpages by Selecting, Arranging, Adapting, Substituting and/or Supplementing Content for Mobile and/or other Electronic Devices; and Optimizing Content for Mobile and/or other Electronic Devices; and Enhancing Usability of Mobile Devices |
US7797252B2 (en) * | 2006-10-20 | 2010-09-14 | Target Brands, Inc. | Service plan product and associated system |
US20080098300A1 (en) * | 2006-10-24 | 2008-04-24 | Brilliant Shopper, Inc. | Method and system for extracting information from web pages |
US20080221987A1 (en) * | 2007-03-07 | 2008-09-11 | Ebay Inc. | System and method for contextual advertisement and merchandizing based on an automatically generated user demographic profile |
US20090006188A1 (en) * | 2007-06-26 | 2009-01-01 | Microsoft Corporation | Associating an activity with an online advertisement |
US20090099931A1 (en) * | 2007-10-04 | 2009-04-16 | Cvon Innovations Ltd. | System, method and computer program for assocating advertisements with web or wap pages |
US20090198573A1 (en) * | 2008-01-31 | 2009-08-06 | Iwin, Inc. | Advertisement Insertion System and Method |
US8965865B2 (en) * | 2008-02-15 | 2015-02-24 | The University Of Utah Research Foundation | Method and system for adaptive discovery of content on a network |
US8793256B2 (en) * | 2008-03-26 | 2014-07-29 | Tout Industries, Inc. | Method and apparatus for selecting related content for display in conjunction with a media |
US8352321B2 (en) * | 2008-12-12 | 2013-01-08 | Microsoft Corporation | In-text embedded advertising |
US20100185489A1 (en) * | 2009-01-21 | 2010-07-22 | Satyavolu Ramakrishna V | Method for determining a personalized true cost of service offerings |
-
2010
- 2010-08-05 US US12/851,447 patent/US9082126B2/en active Active
- 2010-08-05 WO PCT/US2010/044561 patent/WO2011037691A1/en active Application Filing
- 2010-08-05 US US12/851,457 patent/US20110078029A1/en not_active Abandoned
- 2010-08-05 US US12/851,451 patent/US20110078015A1/en not_active Abandoned
Patent Citations (13)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US6874120B2 (en) * | 2001-04-05 | 2005-03-29 | International Business Machines Corporation | Method, system, and product for efficient retrieval of information related to data input into a data entry form from the data entry form |
US20020156699A1 (en) * | 2001-04-20 | 2002-10-24 | Joseph Gray | System of upselling in a computer network environment |
US20030177175A1 (en) * | 2001-04-26 | 2003-09-18 | Worley Dale R. | Method and system for display of web pages |
US20050216290A1 (en) * | 2004-03-29 | 2005-09-29 | The Go Daddy Group, Inc. | Web site design and copyright process |
US20080148161A1 (en) * | 2004-12-27 | 2008-06-19 | Sap Aktiengesellschaft | Webpage Autorefresh |
US7975019B1 (en) * | 2005-07-15 | 2011-07-05 | Amazon Technologies, Inc. | Dynamic supplementation of rendered web pages with content supplied by a separate source |
US20100223107A1 (en) * | 2005-09-06 | 2010-09-02 | Interpolls Network Inc. | Systems and methods for integrating xml syndication feeds into online advertisement |
US20070208641A1 (en) * | 2006-03-03 | 2007-09-06 | Bayview Lending Group Llc | Automated loan processing system and method for processing loans |
US20080027878A1 (en) * | 2006-05-12 | 2008-01-31 | Hookumu Incorporated | Systems and methods for establishing a space planning network |
US20080162329A1 (en) * | 2006-12-19 | 2008-07-03 | Knapp Jason J A | Auction For Each Individual Ad Impression |
US20080306816A1 (en) * | 2007-06-06 | 2008-12-11 | Nebuad, Inc. | Network devices for replacing an advertisement with another advertisement |
US20090222317A1 (en) * | 2008-02-29 | 2009-09-03 | Tim Allen | Systems and methods for generating electronic upsell directory |
US20100106565A1 (en) * | 2008-10-27 | 2010-04-29 | Fotomoto, Inc. | Embeddable Distributed E-Commerce And Community Building System |
Cited By (18)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US20120198056A1 (en) * | 2011-01-31 | 2012-08-02 | Yaacov Shama | Techniques for Analyzing Website Content |
US20120290935A1 (en) * | 2011-05-12 | 2012-11-15 | Koji Ihara | Information processing apparatus, server device, information processing method, computer program, and content sharing system |
US9595045B2 (en) | 2011-06-17 | 2017-03-14 | Google Inc. | Advertisements in view |
US11334910B2 (en) | 2011-06-17 | 2022-05-17 | Google Llc | Advertisements in view |
US9317868B2 (en) * | 2011-06-17 | 2016-04-19 | Google Inc. | Advertisements in view |
US12039565B2 (en) | 2011-06-17 | 2024-07-16 | Google Llc | Advertisements in view |
US9535889B2 (en) | 2011-06-17 | 2017-01-03 | Google Inc. | Method to determine whether advertisements in a web page are in view |
US9576303B2 (en) | 2011-06-17 | 2017-02-21 | Google Inc. | Advertisements in view |
US20150051969A1 (en) * | 2011-06-17 | 2015-02-19 | Google Inc. | Advertisements in view |
US9147199B2 (en) | 2011-06-17 | 2015-09-29 | Google Inc. | Advertisements in view |
US10157402B2 (en) | 2011-06-17 | 2018-12-18 | Google Llc | Advertisements in view |
US9830392B1 (en) | 2013-12-18 | 2017-11-28 | BloomReach Inc. | Query-dependent and content-class based ranking |
US10810275B2 (en) | 2013-12-18 | 2020-10-20 | BloomReach Inc. | Query-dependent and content-class based ranking |
US10726380B2 (en) | 2014-12-22 | 2020-07-28 | International Bridge, Inc. | Parcel shipping screening and validation |
US11599844B2 (en) | 2014-12-22 | 2023-03-07 | International Bridge, Inc. | Parcel shipping screening and validation |
WO2016105676A1 (en) * | 2014-12-22 | 2016-06-30 | International Bridge, Inc. | Parcel shipping screening and validation |
US10417602B2 (en) | 2017-04-18 | 2019-09-17 | International Bridge, Inc. | Item shipping screening and validation |
US11334839B2 (en) | 2017-04-18 | 2022-05-17 | International Bridge, Inc. | Item shipping screening and validation |
Also Published As
Publication number | Publication date |
---|---|
US20110078487A1 (en) | 2011-03-31 |
US20110078015A1 (en) | 2011-03-31 |
US9082126B2 (en) | 2015-07-14 |
WO2011037691A1 (en) | 2011-03-31 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
US9082126B2 (en) | Service plan web crawler | |
US10904117B1 (en) | Insights for web service providers | |
US8230089B2 (en) | On-site dynamic personalization system and method | |
US10621240B2 (en) | System and method for keyword extraction | |
US9262766B2 (en) | Systems and methods for contextualizing services for inline mobile banner advertising | |
US20080249855A1 (en) | System for generating advertising creatives | |
US8112310B1 (en) | Internet advertising system that provides ratings-based incentives to advertisers | |
US20050216335A1 (en) | System and method for providing on-line user-assisted Web-based advertising | |
US20090076899A1 (en) | Method for analyzing, searching for, and trading targeted advertisement spaces | |
US20100174623A1 (en) | System and Method for Managing Items of Interest Selected from Online Merchants | |
US20100293221A1 (en) | Apparatuses, Methods And Systems For Integrated, Information-Engineered And Self-Improving Advertising, E-Commerce And Online Customer Interactions | |
US20120290910A1 (en) | Ranking sentiment-related content using sentiment and factor-based analysis of contextually-relevant user-generated data | |
US20120203651A1 (en) | Method and system for collaborative or crowdsourced tagging of images | |
US20130054356A1 (en) | Systems and methods for contextualizing services for images | |
US20090094525A1 (en) | System and method for dynamic media integration into web pages | |
US20120290606A1 (en) | Providing sentiment-related content using sentiment and factor-based analysis of contextually-relevant user-generated data | |
US20150039442A1 (en) | Multiple-Resolution, Information-Engineered, Self-Improving Advertising and Information Access Apparatuses, Methods and Systems | |
US20140249935A1 (en) | Systems and methods for forwarding users to merchant websites | |
US20120290622A1 (en) | Sentiment and factor-based analysis in contextually-relevant user-generated data management | |
US20120290908A1 (en) | Retargeting contextually-relevant user-generated data | |
US20170178179A1 (en) | Modifying advertisement presentations | |
US10013699B1 (en) | Reverse associate website discovery | |
US9135345B1 (en) | Generating and updating online content using standardized tagged data | |
US9058623B2 (en) | Semantic tagged ads | |
JP4992088B2 (en) | Web server device, web page management method, and web server program |
Legal Events
Date | Code | Title | Description |
---|---|---|---|
AS | Assignment |
Owner name: NATIONAL ELECTRONICS WARRANTY, LLC, VIRGINIA Free format text: ASSIGNMENT OF ASSIGNORS INTEREST;ASSIGNOR:BICKLE, ERIC;REEL/FRAME:024798/0259 Effective date: 20100715 |
|
AS | Assignment |
Owner name: BANK OF AMERICA, N.A., AS COLLATERAL AGENT, NORTH Free format text: FIRST LIEN PATENT SECURITY AGREEMENT;ASSIGNORS:WARRANTY COMPANY OF AMERICA, LLC;NATIONAL ELECTRONICS WARRANTY, LLC;REEL/FRAME:027898/0686 Effective date: 20120316 |
|
AS | Assignment |
Owner name: BANK OF AMERICA, N.A., AS COLLATERAL AGENT, NORTH Free format text: SECOND LIEN PATENT SECURITY AGREEMENT;ASSIGNORS:WARRANTY COMPANY OF AMERICA, LLC;NATIONAL ELECTRONICS WARRANTY, LLC;REEL/FRAME:027924/0408 Effective date: 20120316 |
|
AS | Assignment |
Owner name: BANK OF AMERICA, N.A., AS COLLATERAL AGENT, NORTH Free format text: SECOND LIEN PATENT SECURITY AGREEMENT;ASSIGNORS:WARRANTY COMPANY OF AMERICA, LLC;ASURION, LLC, A DELAWARE LIMITED LIABILITY COMPANY;ASURION SERVICES, LLC, A DELAWARE LIMITED LIABILITY COMPANY;REEL/FRAME:032388/0969 Effective date: 20140303 |
|
STCB | Information on status: application discontinuation |
Free format text: ABANDONED -- FAILURE TO RESPOND TO AN OFFICE ACTION |