1. Technical Field of the Invention
This invention pertains to Web technology. More particularly, it pertains to resolving and storing dynamic links as static links for publishing web content.
2. Background Art
Off-line Web browsers download web pages, and all associated graphics or the like, and save them on local media, such as a client hard drive, for viewing off-line. Many of these browsers provide the capability to the a user to specify a “depth” (maximum number of recursive links that are to be followed) and will follow links from the pages the user specifies. This is useful for users with limited time on-line, or who want to save a particularly good web page, graphics and all.
Available in the art are many such client web caching programs. These include, for example, GetBot, Robo Surfer, Web Buddy, WebCopy99, WebZip, and Surf Express. In addition, many web servers have a server side cache function that operates in much the same manner as these client-side web caching programs.
However, none of these caching programs provide the ability to follow data driven dynamic links, those links that are derived by executing some logic on the server, possibly in conjunction with parameters passed from user interaction with a web page, and to modify the original page to contain all of the necessary information, including static links or Javascript, to access the pages that have been followed.
It is an object of the invention to provide a system and method for publishing dynamically linked, interactive content as a statically linked web hierarchy at a client side process.
It is a further object of the invention to provide a system and method for discovering the structure of a web site and convert any and all dynamically generated content into static pages.
It is a further object of the invention to provide a system and method for modifying function components in dynamically linked, interactive web page content to provide equivalent behaviors at a client without server side transaction processing.
It is a further object of the invention to provide a system and method for publishing highly interactive web content to a distributable media, thereby eliminating the need for a server or network connection.
It is a further object of the invention to provide a system and method for interacting with highly interactive web content when in a disconnected mode or in an area of the world where network infrastructure requires distribution on local media.
It is a further object of the invention to provide a system and method for publishing the content of HTML pages dynamically generated by a web server based on user interaction as if it was retrieved interactively and making the resulting content available via local media.
It is a further object of the invention to provide a system and method for accessing the content of HTML pages dynamically generated by a web server based on user interaction, without being connected to the server.
It is a further object of the invention to provide a system and method for publishing web content to a CDROM or other client based storage medium and for accessing that content through any non-connected computer browser.
It is a further object of the invention to provide a system and method for following dynamic links, those that rely on server side Java or Common Gateway Architecture (CGA) program logic.
It is a further object of the invention to provide a system and method with the ability to follow data driven dynamic links and modify the original page to contain all of the necessary information to access the followed pages.
It is a further object of the invention to provide a system and method which enables a client web caching program to follow data driven dynamic links, those links that are derived by executing some logic on the server in conjunction with some parameters passed from user interaction with a web page, and modify the original page to contain all of the necessary information, including static links, Javascript and the like, to access the followed pages.
It is a further object of the invention to provide a system and method for transforming a set of Hyper-text Markup Language (HTML) that requires server interaction to a set of HTML that does not require server interaction.
In accordance with the method and system of the invention, a Hypertext Markup Language (HTML) web page is parsed by an agent to identify dynamic links, those that require the server to generate a next set of HTML. These dynamic links are then replaced with computed static representations in one or more files in persistent storage where they are available to a browser.
In accordance with an aspect of the invention, there is provided a computer program product configured to be operable to replace dynamic HTML links with computed static representations.
Other features and advantages of this invention will become apparent from the following detailed description of the presently preferred embodiment of the invention, taken in conjunction with the accompanying drawings.
Referring to
In accordance with the preferred embodiment of the method of the invention, with client 20 connected to server 22, agent tool 30 simulates user interaction and traversal of dynamic web pages, causing the server-side processes 22, 24 to serve HTML pages to client 20. As these pages are served, they are collected by agent 30, modified to include static hyperlinks to replace the server side directed navigation logic, and then persistently stored in files 32 where they are available for off-line navigation by browser 34 without the need for servers 22, 24. In effect, the HTML pages are published.
Referring to
Referring to
Referring to
By way of a first example, generating a client based web page such as is illustrated in
By way of a second example, generating a client based web page such as is illustrated in
If, in example 1, a truth table is used to link answers to response pages, it is not required that the links be persistent in the HTML. Rather, as is illustrated in
Above example truth table indicates that answers of C & B is correct, all others are incorrect. The client side javascript examines the answer the user provides and compares that answer to the valid values provided in the truth table and make a determination on the path to be followed. The truth table is built by agent 30 during processing and is inserted into the resulting client side, generated web content file 32.
Referring to
Referring to
In an alternative embodiment, page 54 may correspond to page 72, and pages 64 and 66 to response pages 75. Response truth table 73 is a location in main storage temporarily used for creating links from page 72 to response pages 75.
Referring to
In step 80, client 20 gets the IP address 9.243.100.100 of server w3.ibm.com 22.
In step 82, next url variable is set to the entire address w3.ibm.com/hr/index.html.
In step 84, a url connection is opened to next url.
In step 86, agent 30 requests and stores the content of that url connection to memory.
In step 88, agent 30 parses through the contents of memory, retrieving and collecting all references to server 22 or IP addresses or other addresses of other servers 24.
In step 90, steps 84-88 are repeated through all references, with agent 30 requesting of servers 22, 24 and storing content served back in new local files 32, and updating next url for each iteration through steps 84-88.
In step 92, agent 30 processes the stored files 32, replacing server references (links to servers 22, 24) with local file references (links to other files within the collection of files 32).
The result is a set of local files 32 referencing each other, rather than the server(s) 22, 24.
Referring to
In step 100, agent 30 gets the IP address of server 22.
In step 102, next url is set equal to source file w3.ibm.com/hr/index.html.
In step 104, a url connection is opened to next url.
In step 106, agent 30 requests and stores the content of that url to memory.
In step 108, agent 30 parses through the contents of memory, identifying (tagging) all references to server 22 (that is, url w3.ibm.com/hr/index.html or ip address 9.243.100.100, and addresses of other servers 24).
In step 110, agent 30 processes url content in stored files 32 by replacing server references with local file 32 references or calls to local logic.
In step 112, steps 104-110 are repeated for all references, updating next url for each iteration.
The create local logic step 110 requires that agent 30 keep a truth table 73 or equivalent representation of all the different combinations of answers A, B, C and D, and a link to the page to which they are resolved. This allows the look and feel to be preserved in the case where there are multiple inputs, as is illustrated in
It is an advantage of the invention that there is provided a system and method for publishing dynamically linked, interactive content as a statically linked web hierarchy at a client side process.
It is a further advantage of the invention that there is provided a system and method for discovering the structure of a web site and convert any and all dynamically generated content into static pages.
It is a further advantage of the invention that there is provided a system and method for modifying function components in dynamically linked, interactive web page content to provide equivalent behaviors at a client without server side transaction processing.
It is a further advantage of the invention that there is provided a system and method for publishing highly interactive web content to a distributable media, thereby eliminating the need for a server or network connection.
It is a further advantage of the invention that there is provided a system and method for interacting with highly interactive web content when in a disconnected mode or in an area of the world where network infrastructure requires distribution on local media.
It is a further advantage of the invention that there is provided a system and method for publishing the content of HTML pages dynamically generated by a web server based on user interaction as if those pages were retrieved interactively and making the resulting content available via local media.
It is a further advantage of the invention that there is provided a system and method for accessing the content of HTML pages dynamically generated by a web server based on user interaction, without being connected to the server.
It is a further advantage of the invention that there is provided a system and method for publishing web content to a CDROM or other client based storage medium and for accessing that content through any non-connected computer browser.
It is a further advantage of the invention that there is provided a system and method for following dynamic links, those that rely on server side Java or CGA program logic.
It is a further advantage of the invention that there is provided a system and method with the ability to follow data driven dynamic links and modify the original page to contain all of the necessary information to access the followed pages.
It is a further advantage of the invention that there is provided a system and method which enables a client web caching program to follow data driven dynamic links, those links that are derived by executing some logic on the server in conjunction with some parameters passed from user interaction with a web page, and modify the original page to contain all of the necessary information, including static links, Javascript and the like, to access the followed pages.
It is a further advantage of the invention that there is provided a system and method for transforming a set of Hyper-text Markup Language (HTML) that requires server interaction to a set of HTML that does not require server interaction.
It will be appreciated that, although specific embodiments of the invention have been described herein for purposes of illustration, various modifications may be made without departing from the spirit and scope of the invention. In particular, it is within the scope of the invention to provide a computer program product or program element, or a program storage or memory device such as a solid or fluid transmission medium, magnetic or optical wire, tape or disc, or the like, for storing signals readable by a machine, for controlling the operation of a computer according to the method of the invention and/or to structure its components in accordance with the system of the invention.
Further, each step of the method may be executed on any general computer, such as an IBM System 390, AS/400, PC or the like and pursuant to one or more, or a part of one or more, program elements, modules or objects generated from any programming language, such as C++, Java, Pl/1, Fortran or the like. And still further, each said step, or a file or object or the like implementing each said step, may be executed by special purpose hardware or a circuit module designed for that purpose.
Accordingly, the scope of protection of this invention is limited only by the following claims and their equivalents.
This application is a divisional of and claims priority of U.S. patent application ser. No. 09/427,459 filed 22 Oct. 1999 U.S. Pat. No. 7,096,417 issued 22 Aug. 2006 by Craig A. Bennett, Michael J. Beranek, Jeffrey J. Bonasso, Christopher J. Davis, and Steven W. Stapel, for System, Method, and Computer Program Product for Publishing Interactive Web Content as a Statically Linked Web Hierarchy.
Number | Name | Date | Kind |
---|---|---|---|
5551030 | Linden et al. | Aug 1996 | A |
5715453 | Stewart | Feb 1998 | A |
5745360 | Leone et al. | Apr 1998 | A |
5761673 | Bookman et al. | Jun 1998 | A |
5802367 | Held et al. | Sep 1998 | A |
5804803 | Cragun et al. | Sep 1998 | A |
5894554 | Lowery et al. | Apr 1999 | A |
5903902 | Orr et al. | May 1999 | A |
5933606 | Mayhew | Aug 1999 | A |
5963208 | Dolan et al. | Oct 1999 | A |
5968125 | Garrick et al. | Oct 1999 | A |
5973696 | Agranat et al. | Oct 1999 | A |
5987480 | Donohue et al. | Nov 1999 | A |
5999912 | Wodarz et al. | Dec 1999 | A |
6018748 | Smith | Jan 2000 | A |
6021426 | Douglis et al. | Feb 2000 | A |
6038598 | Danneels | Mar 2000 | A |
6101510 | Stone et al. | Aug 2000 | A |
6112242 | Jois et al. | Aug 2000 | A |
6163779 | Mantha et al. | Dec 2000 | A |
6182122 | Berstis | Jan 2001 | B1 |
6259958 | Steinman et al. | Jul 2001 | B1 |
6408360 | Chamberlain et al. | Jun 2002 | B1 |
6411999 | Tinkler | Jun 2002 | B1 |
6462754 | Chakraborty et al. | Oct 2002 | B1 |
6466970 | Lee et al. | Oct 2002 | B1 |
6466981 | Levy | Oct 2002 | B1 |
6493758 | McLain | Dec 2002 | B1 |
6549944 | Weinberg et al. | Apr 2003 | B1 |
6581065 | Rodkin et al. | Jun 2003 | B1 |
6584498 | Nguyen | Jun 2003 | B2 |
6597377 | MacPhail | Jul 2003 | B1 |
6601100 | Lee et al. | Jul 2003 | B2 |
6647535 | Bozdagi et al. | Nov 2003 | B1 |
6826594 | Pettersen | Nov 2004 | B1 |
6832222 | Zimowski | Dec 2004 | B1 |
6839757 | Romano et al. | Jan 2005 | B1 |
7096417 | Bennett et al. | Aug 2006 | B1 |
20020026563 | Chamberlain et al. | Feb 2002 | A1 |
20020049828 | Pekarek-Kostka | Apr 2002 | A1 |
20020091725 | Skok | Jul 2002 | A1 |
20020198939 | Lee et al. | Dec 2002 | A1 |
20030018612 | Melbin | Jan 2003 | A1 |
20030140045 | Heninger et al. | Jul 2003 | A1 |
20040254913 | Berstein et al. | Dec 2004 | A1 |
20050021862 | Schroeder et al. | Jan 2005 | A1 |
20050028195 | Feinleib et al. | Feb 2005 | A1 |
20050060162 | Mohit et al. | Mar 2005 | A1 |
20050081140 | Allen et al. | Apr 2005 | A1 |
Number | Date | Country |
---|---|---|
WO 9908182 | Feb 1999 | WO |
Number | Date | Country | |
---|---|---|---|
20060248453 A1 | Nov 2006 | US |
Number | Date | Country | |
---|---|---|---|
Parent | 09427459 | Oct 1999 | US |
Child | 11479190 | US |