WO2001011488A2 - Method and apparatus for selecting and viewing portions of web pages - Google Patents

Method and apparatus for selecting and viewing portions of web pages Download PDF

Info

Publication number
WO2001011488A2
WO2001011488A2 PCT/US2000/021700 US0021700W WO0111488A2 WO 2001011488 A2 WO2001011488 A2 WO 2001011488A2 US 0021700 W US0021700 W US 0021700W WO 0111488 A2 WO0111488 A2 WO 0111488A2
Authority
WO
WIPO (PCT)
Prior art keywords
web page
user
short
elements
page
Prior art date
Application number
PCT/US2000/021700
Other languages
French (fr)
Other versions
WO2001011488A3 (en
Inventor
Mark Tsimelzon
Original Assignee
Akamai Technologies, Inc.
Priority date (The priority date is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the date listed.)
Filing date
Publication date
Priority claimed from US09/372,402 external-priority patent/US6834306B1/en
Priority claimed from US09/371,161 external-priority patent/US6763388B1/en
Application filed by Akamai Technologies, Inc. filed Critical Akamai Technologies, Inc.
Priority to AU67619/00A priority Critical patent/AU6761900A/en
Publication of WO2001011488A2 publication Critical patent/WO2001011488A2/en
Publication of WO2001011488A3 publication Critical patent/WO2001011488A3/en

Links

Classifications

    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F16/00Information retrieval; Database structures therefor; File system structures therefor
    • G06F16/90Details of database functions independent of the retrieved data types
    • G06F16/95Retrieval from the web
    • G06F16/957Browsing optimisation, e.g. caching or content distillation
    • G06F16/9577Optimising the visualization of content, e.g. distillation of HTML documents
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F16/00Information retrieval; Database structures therefor; File system structures therefor
    • G06F16/90Details of database functions independent of the retrieved data types
    • G06F16/95Retrieval from the web
    • G06F16/958Organisation or management of web site content, e.g. publishing, maintaining pages or automatic linking

Definitions

  • the present invention relates generally to computer networks and, specifically, to a method and apparatus that allow users to select certain portions of web pages to form "short" web pages.
  • the web World Wide Web
  • users obtain more and more information from the web, they must visit greater numbers of different web pages to obtain the information. This information is often contained on several separate web pages or web sites. Alternately, a user may wish to see only a small piece of information that is contained in a very large and complex page or site. The user must search through the pages in which he is not interested to reach the information that he wishes to see.
  • What is needed is a way to avoid regularly re-entering the same multiplicity of web addresses and a way to avoid having to navigate through multi-level web sites to reach desired information.
  • a described embodiment of the present invention allows users to select certain sub- elements of web pages for later viewing.
  • the user can use any of a wide variety of client devices to view the web page, such as a computer, a handheld device, or a cell phone.
  • client devices such as a computer, a handheld device, or a cell phone.
  • the user views the shortened web page at a later time, only the sub-elements of the web page selected by the user are displayed. Thus, the user views only preselected sub-elements of the web page.
  • Multiple users can share a short page. Such a shared shortpage is called a shared portal. For example, multiple users can place information on a short page. Alternately, multiple users can view a shortpage created by a third party or third parties.
  • the invention is a method for creating a short web page, comprising: allowing a user to choose a subset of elements that appear on an original web page; saving the user's choices; and creating a short web page that is based on the original web page, and includes the elements chosen by the user in accordance with the user's saved choices.
  • the invention is a method for creating a short web page, comprising: storing in a memory selection information specifying the elements on a short web page, the short web page being based on an original web page; retrieving the original web page upon which the short web page is based; and creating the short web page from elements on the original web page in accordance with the selection information.
  • the invention is a computer-implemented method performed by a server data processing system, comprising: receiving, from a client, a request for a web page; retrieving the requested web page; sending the requested web page to the client; receiving, from the client, selection information for the requested web page, the selection information indicating a subset of the information of the web page that is smaller than the set of all information on the web page; and storing the selection information in the server data processing system.
  • the invention is a computer-implemented method performed by a server data processing system, comprising: receiving, from a client, a request for a user's short page; retrieving a web page on which the user's short page is based; selecting sub-elements of the retrieved web page, in accordance with selection information of the user stored in the server data processing; and sending the user's short page, containing the selected sub- elements of the retrieved web page to the user.
  • the invention is a computer-implemented method performed by a client data processing system, comprising: sending, by a client, a request for a web page; receiving the requested web page; allowing the user to select sub-elements of the received web page as being hidden or shown, the hidden sub-elements being indicated by selection information; and sending, to a server, the selection information for the web page.
  • the invention is an apparatus to create a short web page, comprising: a software portion configured to allow a user to choose a subset of elements that appear on an original web page; a software portion configured to save the user's choices; and a software portion configured to create a short web page that is based on the original web page, and that includes the elements chosen by the user in accordance with the user's saved choices.
  • the invention is an apparatus for creating a short web page, comprising: a software portion configured to store in a memory selection information specifying the elements on a short web page, the short web page being based on an original web page; a software portion configured to retrieve the original web page upon which the short web page is based; and a software portion configured to create the short web page from elements on the original web page in accordance with the selection information.
  • Fig. 1 is a block diagram of data processing elements in accordance with a preferred embodiment of the present invention.
  • Figs. 2(a) and 2(b) are block diagrams showing an information flow in a preferred embodiment of the present invention.
  • Fig. 3(a) shows a display of a startpage that allows a user to create and edit shortpages.
  • Figs. 3(b)-3(e) show the HTML source for a startpage.
  • Figs. 4(a)-4(c) are flow charts showing how a client and a server interact to perform shortpage operations, such as create, edit, delete, and view.
  • Fig. 5(a) shows a display of an exemplary web page.
  • Figs. 5(b) and 5(c) show the web page of Fig. 5(a) displayed along with selection- enabling information.
  • Fig. 5(d) shows the web page of Fig. 5(b) with a different level of block detail.
  • Fig. 5(e) shows a web page that allows the user to view/edit shortpage properties.
  • Fig. 6 is a flow chart showing how the client and the server interact to allow the user to create/edit a shortpage.
  • Fig. 7 shows an example of HTML parsing used to create/edit shortpages.
  • Fig. 8 shows an example of a split page method used to create/edit shortpages.
  • Fig. 9 is a flow chart of how to determine a display level when creating shortpages.
  • Fig. 10 shows the startpage of Fig. 3(a) after a shortpage has been created based on the web page of Fig. 5(a).
  • Fig. 11 shows the shortpage created from the web page of Fig. 5(a).
  • Fig. 12 shows a fullpage corresponding to the web page of Fig. 5(a).
  • Fig. 13 is a flow chart showing how the client and server interact to allow the user to view a shortpage.
  • Fig. 14 is a flow chart showing details of determining whether a URL is the URL of a shortpage.
  • Fig. 15 is a flow chart for viewing a shortpage when the client is a personal digital assistant.
  • Fig. 16 is a block diagram of data flow when a shortpage is viewed on a personal digital assistant.
  • Fig. 17 is a display of a shared portal shortpage.
  • a described embodiment of the present invention allows users to select certain sub- elements of one or more web pages as a shortpage.
  • the user selects certain sub-elements of an original web page to create a shortpage.
  • the user's selection information is saved and, when the user views the shortpage at a later time, only the sub-elements of the web page indicated by the user are displayed for viewing by the user.
  • the user views only preselected sub-elements of the web page.
  • Fig. 1 is a block diagram of data processing elements in accordance with a preferred embodiment of the present invention.
  • Fig. 1 includes a server data processing system 120 communicating with one or more client data processing systems.
  • client data processing systems include, but are not limited to, a desktop personal computer (PC) 102, a laptop computer 104, a palm computer (personal computer/assistant or handheld device) 106, a pager 108 (such as an alphanumeric pager), a web-enabled telephone or a cell phone 110, or some other appropriate web-enabled device or appliance 111.
  • a web-enabled telephone or device could use, for example, the WAP (Wireless Application Protocol) or any other appropriate protocol.
  • WAP Wireless Application Protocol
  • Fig. 1 also includes a plurality of web page servers 132, 134, 136. Each web page server communicates with server 120 and stores one or more web sites or web pages. Server 120 stores selection information 122 for each user and further stores selection-enabling information 124 that is added to a web page to enable a user to make selections from a web page. Communication can be over a network, such as the internet, an intranet, a wireless network, or in any other appropriate manner.
  • Fig. 2(a) shows an overview of creation of a shortpage.
  • a client 202 sends a request to server 120 for a web page.
  • Server 120 retrieves the web page from an appropriate one of web sites 132-136.
  • the server 120 adds selection- enabling information to the retrieved web page and sends the web page to the client.
  • the client selects sub-elements of the web page and sends that selection information to server 120.
  • Server 120 stores selection information 122 describing the shortpages defined by a user.
  • Fig. 2(b) shows an overview of viewing a shortpage.
  • the client sends a request for a shortpage to server 120.
  • Server 120 determines the page or pages needed to view the shortpage in accordance with the stored selection information and retrieves the page or pages from the web site 132. Server 120 shortens the retrieved web page in accordance with the selection information to form a shortpage and sends the shortpage to the client.
  • each of the clients, servers, and web servers in the described embodiment preferably includes a processor and a memory.
  • the memory includes instructions capable of being executed by the processor to perform the functions described below.
  • a client and/or a server can also include a computer readable medium for storing the instructions.
  • Server 120 communicates with the clients and the web page servers via any appropriate communication mechanism, including but not limited to a network, an intranet, the internet, wireless communications, telecommunications, cable modems, and satellite communications.
  • a client may include browser software suitable for viewing web pages.
  • the browser software can be standalone or integrated within other software products.
  • the functionality can be stored, for example, as a link, a JavaScript, or as a Java applet.
  • Handheld clients contain a specialized browser that receive "snipped" sub-elements of web pages for viewing on a handheld client. Other clients (such as cell phones) do not necessarily contain a browser.
  • references herein to "HTML" can be understood to refer to any appropriate page specification language, such as a hypertext language or a proprietary language.
  • Fig. 3(a) shows a display of a "startpage" on a browser in a client.
  • the startpage allows a user to create and edit shortpages and displays existing shortpages. Each user has his own startpage.
  • the information needed to make a startpage is preferably stored in server 120.
  • the startpage of Fig. 3(a) includes a link to a Notifications page 312, a link to an Edit profile page 314, and a link to a Help page 316.
  • 3(a) allows a user to create, edit, delete, and view shortpages and their options.
  • the user enters a URL of a page into area 318 and selects "Create Shortpage" button 320. After a shortpage is created, its name will be displayed in Shortpages column 332.
  • An existing shortpage can be viewed ("Go"), edited, options edited, or deleted by selecting the corresponding action in action box 330 and selecting a name of an existing shortpage.
  • Figs. 3(b)-3(e) are an example of the HTML source code for an exemplary startpage, similar to the StartPage of Fig. 3(a). This source code is included for the purpose of example and is not to be taken in a limiting sense.
  • Figs. 4(a)-4(c) are flow charts showing how a client and a server interact to perform shortpage operations, such as create, edit, delete, and view.
  • Figs. 4(a) and 4(b) show a method performed by the client.
  • the functionality of Figs. 4(a) and 4(b) are implemented via a Java Script executed by the client browser, although any appropriate implementation can be used.
  • Fig. 4(c) shows a method performed by server 120.
  • Figs. 4(c) shows a method performed by server 120.
  • the client receives the user's actions (e.g., entering the URL of a web page and clicking "Create shortpage") and determines whether the user wants to create a shortpage (element 410), edit a shortpage (element 420), view a shortpage (element 430), delete a shortpage (element 440), or edit an option (element 450).
  • the user's actions e.g., entering the URL of a web page and clicking "Create shortpage
  • the client sends the URL of the page to shorten and a request to create a shortpage to server 120.
  • the client receives a page created from the requested page and from selection-enabling information.
  • the selection-enabling information allows the user to indicate that sub-elements of the page are shown or hidden.
  • the client displays the page, and allows the user to create a shortpage as described below.
  • the resulting selection information is sent to server 120.
  • selection information is sent to the server each time a page element is marked as "shown" or "hidden.”
  • a new preview of the shortpage is sent from the server to the client, so that the preview view of the short page reflects the currently shown/hidden element.
  • the server adds the name of the shortpage to the list of shortpages 332 on the page. If the user wants to edit a shortpage (element 420), the client sends the URL of the shortpage to edit and a request to edit a shortpage to server 120. The client receives a shortpage created from the original fullpage including selection-enabling information. The selection enabling information includes show/hide buttons and header links. The client then displays the page upon which the shortpage is based, including the selection-enabling information, and allows the user to edit the shortpage as described below. The resulting selection information is sent to server 120.
  • the show/hide buttons can instead be implemented as a one-button user interface, or by using some other appropriate type of user interface that allows the user to choose a subset of the web page elements.
  • the client sends the URL of the shortpage to view and a request to view a shortpage to server 120.
  • the client receives the shortpage from server 120.
  • the shortpage to be viewed does not include any selection- enabling information.
  • the client then displays the shortpage.
  • the client sends the URL of the shortpage to delete and a request to delete a shortpage to server 120.
  • Server 120 deletes the shortpage and returns an indication to the client that the shortpage has been deleted.
  • the server removes the name of the shortpage from its list of shortpages 332.
  • the client wants to edit options for a shortpage, the client sends the URL of the shortpage and a request to edit the options of the shortpage.
  • the client receives the edit page from server and displays it.
  • the user then edits the options and sends the edits to the server.
  • Fig. 4(c) shows an overview of an exemplary shortpage method on the server side.
  • the server receives a request from the client's browser to create, edit, delete, or view a shortpage or option (element 450)
  • the server translates the request into the appropriate request(s) to the web server(s) and retrieves the requested web page(s) or site(s) from the server(s) (element 452).
  • these requests are HTTP requests and the web pages are written in HTML or a similar hypertext language.
  • the server does the user-specified action (such as adding selection-enabling information when a shortpage is to be created or edited) or selecting the relevant parts of the web page (when a shortpage is to be viewed) (element 456).
  • the server adds the selection-enabling information to the retrieved web page and sends the resulting page to the client's browser.
  • Table 1 shows an example of Web Procedure Calls (WPCs) used to communicate between the client and the server.
  • Creating/Editing a Shortpage The following paragraphs provide exemplary details of how to create/edit a shortpage.
  • the web page shown has a URL of http://abc.gov.
  • a user visits this web site frequently and desires to select sub-elements of the web site to be placed on a shortpage. If the user desires to create a shortpage based on the web page of Fig. 5(a), he enters the URL of the web page into address 318 of Fig. 3 and selects "Create Shortpage" button 320.
  • the server will retrieve the requested web page and add selection-enabling information to the page.
  • Figs. 5(b) and 5(c) show the web page of Fig. 5(a) displayed along with selection- enabling information.
  • the server has broken the web page into blocks, each block having selection-enabling information.
  • the selection-enabling information is a pair of show/hide boxes, having a check mark and an "X" respectively.
  • the check mark indicates that the corresponding block will be shown in the shortpage.
  • the "X" indicates that the corresponding block will be hidden (not shown) in the shortpage.
  • Fig. 5(b) shows an editing area 510 and a preview area 520. Each of these areas can be sized and scrolled by the user. Initially all blocks in the page are marked as "hide.”
  • FIG. 5(b) shows all blocks marked as "show.” Therefore, in the example, preview area 520 shows all blocks in the page. In contrast, in Fig. 5(c), the user has clicked on the "X" box 505, causing the corresponding block 504 to be hidden in the shortpage. Note that the block 504 is not shown in the preview area 520 of Fig. 5(c).
  • Fig. 5(d) shows the web page of Fig. 5(a) with a different level of block detail.
  • a command is sent to the server and the server re-determines the blocks of the page using a higher level of detail than previously used.
  • a similar "less detail” button 561' is displayed on the web page of Fig. 5(d)).
  • a method of determining blocks on a page in accordance with a current level of detail is described below in connection with Fig. 9.
  • the page is broken into fewer blocks. For example, block 504 does not exist in editing area 510.
  • FIG. 5(e) shows a web page that allows the user to view/edit shortpage properties.
  • the web page of Fig. 5(e) is requested when the user clicks on "Next" link 560, as shown in Figs. 5(b) - 5(d).
  • This page allow the user to enter properties of a shortpage.
  • the user can change the name associated with the shortpage (for example, the name shown in area 332 of Fig. 3) by entering a new name in area 570.
  • the user can enter comments in area 572.
  • the user can indicate that the shortpage does not show the page background in area 574.
  • the user can indicate that changes since the last time the shortpage was viewed should be highlighted on the shortpage in area 576.
  • the user can indicate that the shortpage should be used for similar pages and all URLs starting with a specified string (areas 578 and 580). Other properties could be included or certain properties shown in the figure excluded without departing from the spirit or scope of the invention.
  • the client sends the entered information to server 120, which stores the entered information in connection with the shortpage.
  • Fig. 6 is a flow chart showing how the client and the server interact to allow the user to create/edit a shortpage.
  • Each element of the flow chart has a notation next to it indicating whether it is preferably performed by the client, server, or a combination.
  • the server needs to break the page down into blocks and to add selection-enabling information to the page for each block.
  • the server uses the SplitPage method (Fig. 8) and the Level of Detail method (Fig. 9) to break the page into blocks.
  • the server adds selection-enabling information to the retrieved web page. Specifically, the server adds a "Show" button and a "Hide” button next to the block and puts a border ( ⁇ table>) around it.
  • the client's browser thus, displays the web page along with the selection-enabling information for each block.
  • the server When the user selects "Show” or “Hide,” an HTTP request that uniquely identifies the button is sent to the server (see Table 1).
  • the server marks the corresponding block as either “shown” or “hidden” in the representation tree (RepTree) for the shortpage. This information is a part of the selection information stored on the server.
  • the server returns a preview of the resulting shortpage to the user, which is displayed in a separate frame (preview area 520).
  • the marked-up RepTree is stored as the template for future references to this shortpage.
  • the RepTree forms at least part of the selection information. It will be understood that, although the example shows certain actions being performed by the client or the server, other embodiments may implement the client or server to perform actions not shown as being performed by them. For example, the selection information could be stored on the client side.
  • Fig. 7 shows an example of parsing used by the server to create and edit shortpages.
  • This figure shows the Split Page method.
  • a page is represented by an HTML file.
  • the HTML is parsed in a manner known to persons of ordinary skill in the art to yield a Representation Tree.
  • a simple tag is defined as a tag that has no children and a complex tag is defined as a tag that has children.
  • Server 120 parses the HTML file into a RepTree and iterates down the tree in a depth-first way to mark each node in the tree according to whether it is a single block.
  • the RepTree includes a flag for each block indicating whether it is shown or hidden.
  • Table 2 A detailed example of the format of a RepTree is shown in Table 2. This format is not to be taken in a limiting sense.
  • Fig. 8 shows an example of a split page method used to create/edit shortpages.
  • a node corresponds to a simple tag that is an image, input, iframe, or object, it is marked as a single block.
  • a node corresponds to a complex tag of type ⁇ tr> and there are more than two rows or columns in the table, mark the node.
  • a node corresponds to a complex tag of type ⁇ form>, do not mark the node.
  • a node corresponds to a complex tag of other types, mark the node if it has any text.
  • continue traversing the RepTree For each complex node, walk down the list of its children. Any nodes between two single blocks become one complex block. To avoid creating extra blocks, if a node has only one child block, give the block status to the parent node instead.
  • Fig. 9 is a flow chart of how to determine a display level when creating shortpages.
  • the level of detail is used to decrease the number of blocks displayed at a given time. This flow chart demonstrates how to work with two levels (high and low), but any number of levels can be supported. If the level of detail is low, element
  • element 904 determines whether the block's parent has less than L nodes below its children.
  • L can be, for example, 5. If the block's parent has less than L nodes below its children, the block is shown as a separate block when the user creates or edits a shortpage. Otherwise, the block is not shown as a separate block.
  • element 906 determines whether the block has more than K nodes below its children. K can be, for example, 1. If the block has more than K nodes below its children, the block is shown as a separate block when the user creates a shortpage. Otherwise, the block is not shown as a separate block.
  • Fig. 10 shows the startpage of Fig. 3 after a shortpage has been created based on the web page of Fig.
  • Server 120 indicates to the client that a shortpage has been created and adds the name of the shortpage to area 332 of the user's startpage.
  • the startpage having the name of the new shortpage is sent to the browser, where it is displayed.
  • Fig. 11 shows the shortpage created from the web page of Fig. 5(a).
  • the user selected certain sub-elements of the page. Specifically, the user indicated that all but a leftmost block of the page is marked as hidden. Thus, the shortpage shows only the non- hidden block.
  • the shortpage also includes a link to the user's startpage 1102, a link to a notification page 1104, a link to a help page 1106, a link to a page that allows the user to edit a shortpage 1105 and a link to the fullpage 1103 upon which the shortpage is based. Note that the user has indicated that the background of the original page is not to be shown in this shortpage (see Fig. 5(e)).
  • Fig. 12 shows a fullpage corresponding to the web page of Fig. 11.
  • the fullpage is displayed when the user clicks on the fullpage link 1103 of Fig. 11.
  • the original page's background is shown, since it is part of the page.
  • the user is "JSmith".
  • the action is to get/fetch a page.
  • the URL of the full page is http://www.abc.gov. Further example of parameters used to communicate between the client and the server are described in Table 1.
  • Fig. 13 is a flow chart showing how the client and server interact to allow the user to view a shortpage.
  • the user has selected a name of a shortpage in area 332 and selected "go" in area 330.
  • a shortpage may be based on a particular web page, that web page may have changed since the shortpage was created, either because content may have been changed, added, or deleted. It is necessary to parse the web page on which the shortpage is based (the target) and determine whether the blocks marked "show" in the template are still present in the target.
  • the target page on which the shortpage is based is retrieved and parsed into a RepTree by the server. Each shortpage has a RepTree associated with it.
  • the server performs a "double traverse” method, recursively traversing down both the template and the target RepTrees, trying to match the nodes. If two nodes match by type and tag, assign the "Show” or "Hide” flags of the template node to the target node. If there is no match, start to look for the closest match. If, for example, we are currently on nodes Temp[I], Targ[J], then we are looking for matching Temp[K] and Targ[L] such that, for K and L, K-I+L-J is the smallest possible value.
  • any template nodes that are not matched were the nodes that have disappeared from the page. Any target nodes that were not matched were the nodes that have been added to the page. All target nodes with "Show" flags (i.e., all target blocks that matched a block in the template) are part of the shortpage. These blocks are sent to the requesting client. Other appropriate matching methods can also be used.
  • the user can enter the address of a web page to be shortened. For example, the user can enter a URL in area 318 and click on button 340. If the user has previously defined a shortpage for this URL or for a URL on this web site, the shortpage is displayed. Similarly, if a page has a link to another page within it and the link is selected, server 120 will check the new link to determine whether it is a shortpage.
  • Fig. 14 is a flow chart showing details of determining whether a URL is the URL of a shortpage. As described in element 1402, this method will be used when, instead of requesting a specific shortpage, the user enters or browses to a particular URL.
  • server 120 compares the URL, host name, document name, and CGI argument lists. The server does this for both a shortpage requested address and for the actual address. The requested address and the actual address may be different because of HTTP redirection.
  • Step 1410 calculates match ranking as follows. For each matching RepNode of RepTree, add (l/(Node depth)) to the rank. For each mismatch, subtract the same amount. In step 1414, select the shortpage with the highest matching rank for customizing this request. If no match occurs, then show the full page.
  • Fig. 16 is a block diagram of data flow when a shortpage is viewed on a personal digital assistant, such as a Palm VII Personal Digital Assistant (Available from 3Com Corporation) or a similar handheld device.
  • PDAs often use a "web clipping" system to view web pages. The PDA views predefined web clippings by sending a request for the clipped pages to a proxy server.
  • a "web clipping" application which contains a single link to the user's startpage is created and downloaded into the user's handheld device.
  • the user creates his shortpages as described above. Preferably, these shortpages are created on the user's PC, although other embodiments may allow the user to create them on the handheld.
  • the user simply goes to his startpage "web clipping" in the handheld and selects a link to the shortpage. As shown in Fig. 16, this action causes a request to be sent to the proxy server 1604, which passes the request to the shortpage server 1606, which forwards the request to the web site 1608 hosting the full page.
  • the web site returns the requested page(s) to the shortpage server 1606, which creates a shortpage as described above and which then passes the created shortpage to the proxy server 1604.
  • the proxy server sends the shortpage to the handheld client 1602.
  • Fig. 15 is a flow chart for viewing a shortpage when the client is a personal digital assistant.
  • a web clipping short page application which contains a single link to the user's startpage is created and downloaded into the user's PDA.
  • the user creates his shortpage as before, using his PC or similar device.
  • the user simply goes to his startpage "web clipping" and selects a link to the shortpage.
  • the request goes through a proxy server (such as palm.net of 3Com) and is forwarded to the site hosting the page or pages.
  • the response from the web server is customized by the Shortpage server and goes back to the user.
  • the shortpage server creates a modified version of a shortpage when it knows that the client is a handheld device. For example, the shortpage server removes large graphic files and Java Script code. Other embodiments may make other modifications or no modifications, depending on the nature and capabilities of the handheld client.
  • the proxy server also modifies the page somewhat before sending the page to the handheld client.
  • Fig. 17 is a display of a shared portal shortpage application.
  • a shared portal is created by one or more persons and is viewable by multiple persons. Different users may have different access permissions stored within the server. For example, in one embodiment, a single user has permissions to create folders (such as folder 1702), but any user can add shortpages within folders (link 1704 is a link to a page titled "Bay Area News"). As another example, only a single user can add folders and links, but any user can access the shortpages.
  • the server first checks the permissions of the user. The user may be required to enter a password and/or to Log on from an approved machine.
  • a shared portals may be open to all users or may be restricted to certain groups, such as families, employees of a company, employees of a department, or clubs.
  • server 120 resides on a number of nodes, which are dual-Pentium Windows NT PCs.
  • data is stored in a shared RAID file server.
  • a hardware load-balancer such as a Big DP load balancer from FS Networks, Inc. of Seattle, Washington is used to route user requests to the least busy node.
  • Such an implementation uses persistent connections with, for example, a ten minute timeout to ensure that the requests from the same address get to the same server.
  • the user's data is read from the file server. If there is no activity for the time Q (for example, Q>T, 12 minutes), the data for the user is cleared from memory.
  • NewUserLogin Allows the user to enter registration information RegisterUser - Submits usemame, full name, password, email, and other info for a new user.
  • LoginUser login user. Takes usemame and password
  • WizardAction takes object (shortpage, notification, or combopage) id Edit - start editing the object
  • P_SelectionFrame - Displays the selection frame (upper frame) for the shortpage creation
  • P_DoCommand - do editing command such as "Show” block, or "Hide” block. Takes block id as a parameter, and command id ("Show", “Hide”, “Notify”, etc.)
  • SCRIPT // script node contains both ⁇ SCRIPT> and ⁇ /SCRIPT> WHITESPACE,// whatever "trims" to an empty string.

Abstract

A method and system that allows users to select certain sub-elements of web pages for later viewing. The user selects certain sub-elements of a web page that he wishes to view at a later time. The user's selection information is saved and, when the user views the web page at a later time, only the sub-elements of the web page indicated by the user is displayed for viewing by the user. Thus, the user views only preselected sub-elements of the web page.

Description

Method and Apparatus for Selecting and Viewing Portions of Web Pages
BACKGROUND OF THE INVENTION
The present invention relates generally to computer networks and, specifically, to a method and apparatus that allow users to select certain portions of web pages to form "short" web pages.
The expanded popularity of the World Wide Web ("the web") has brought new problems for web users. As users obtain more and more information from the web, they must visit greater numbers of different web pages to obtain the information. This information is often contained on several separate web pages or web sites. Alternately, a user may wish to see only a small piece of information that is contained in a very large and complex page or site. The user must search through the pages in which he is not interested to reach the information that he wishes to see.
Many users visit the same sequence of web pages or sites on a daily or a regular basis. For example, some users might check the weather or their stock portfolio on a daily basis. Even though a user may visit the same web pages and/or sites regularly, the user must still take individual actions to visit each of his regularly visited web pages or sites. For example, the user may have to enter the web addresses of each page or click on each page in a list of saved addresses in his browser. This repeated entry of web addresses is time consuming and involves un-needed repetitive action by the user.
What is needed is a way to avoid regularly re-entering the same multiplicity of web addresses and a way to avoid having to navigate through multi-level web sites to reach desired information.
SUMMARY OF THE INVENTION
A described embodiment of the present invention allows users to select certain sub- elements of web pages for later viewing. The user can use any of a wide variety of client devices to view the web page, such as a computer, a handheld device, or a cell phone. When the user views the shortened web page at a later time, only the sub-elements of the web page selected by the user are displayed. Thus, the user views only preselected sub-elements of the web page. Multiple users can share a short page. Such a shared shortpage is called a shared portal. For example, multiple users can place information on a short page. Alternately, multiple users can view a shortpage created by a third party or third parties.
In accordance with the purpose of the invention, as embodied and broadly described herein, the invention is a method for creating a short web page, comprising: allowing a user to choose a subset of elements that appear on an original web page; saving the user's choices; and creating a short web page that is based on the original web page, and includes the elements chosen by the user in accordance with the user's saved choices.
In further accordance with the purpose of the invention, as embodied and broadly described herein, the invention is a method for creating a short web page, comprising: storing in a memory selection information specifying the elements on a short web page, the short web page being based on an original web page; retrieving the original web page upon which the short web page is based; and creating the short web page from elements on the original web page in accordance with the selection information. In further accordance with the purpose of the invention, as embodied and broadly described herein, the invention is a computer-implemented method performed by a server data processing system, comprising: receiving, from a client, a request for a web page; retrieving the requested web page; sending the requested web page to the client; receiving, from the client, selection information for the requested web page, the selection information indicating a subset of the information of the web page that is smaller than the set of all information on the web page; and storing the selection information in the server data processing system.
In further accordance with the purpose of the invention, as embodied and broadly described herein, the invention is a computer-implemented method performed by a server data processing system, comprising: receiving, from a client, a request for a user's short page; retrieving a web page on which the user's short page is based; selecting sub-elements of the retrieved web page, in accordance with selection information of the user stored in the server data processing; and sending the user's short page, containing the selected sub- elements of the retrieved web page to the user. In further accordance with the purpose of the invention, as embodied and broadly described herein, the invention is a computer-implemented method performed by a client data processing system, comprising: sending, by a client, a request for a web page; receiving the requested web page; allowing the user to select sub-elements of the received web page as being hidden or shown, the hidden sub-elements being indicated by selection information; and sending, to a server, the selection information for the web page.
In further accordance with the purpose of the invention, as embodied and broadly described herein, the invention is an apparatus to create a short web page, comprising: a software portion configured to allow a user to choose a subset of elements that appear on an original web page; a software portion configured to save the user's choices; and a software portion configured to create a short web page that is based on the original web page, and that includes the elements chosen by the user in accordance with the user's saved choices. In further accordance with the purpose of the invention, as embodied and broadly described herein, the invention is an apparatus for creating a short web page, comprising: a software portion configured to store in a memory selection information specifying the elements on a short web page, the short web page being based on an original web page; a software portion configured to retrieve the original web page upon which the short web page is based; and a software portion configured to create the short web page from elements on the original web page in accordance with the selection information.
Advantages of the invention will be set forth in part in the description which follows and in part will be obvious from the description or may be learned by practice of the invention. The objects and advantages of the invention will be realized and attained by means of the elements and combinations particularly pointed out in the appended claims and equivalents.
BRIEF DESCRIPTION OF THE DRAWINGS
The accompanying drawings, which are incorporated in and constitute a part of this specification, illustrate several embodiments of the invention and, together with the description, serve to explain the principles of the invention.
Fig. 1 is a block diagram of data processing elements in accordance with a preferred embodiment of the present invention.
Figs. 2(a) and 2(b) are block diagrams showing an information flow in a preferred embodiment of the present invention.
Fig. 3(a) shows a display of a startpage that allows a user to create and edit shortpages. Figs. 3(b)-3(e) show the HTML source for a startpage.
Figs. 4(a)-4(c) are flow charts showing how a client and a server interact to perform shortpage operations, such as create, edit, delete, and view. Fig. 5(a) shows a display of an exemplary web page. Figs. 5(b) and 5(c) show the web page of Fig. 5(a) displayed along with selection- enabling information.
Fig. 5(d) shows the web page of Fig. 5(b) with a different level of block detail. Fig. 5(e) shows a web page that allows the user to view/edit shortpage properties. Fig. 6 is a flow chart showing how the client and the server interact to allow the user to create/edit a shortpage.
Fig. 7 shows an example of HTML parsing used to create/edit shortpages. Fig. 8 shows an example of a split page method used to create/edit shortpages. Fig. 9 is a flow chart of how to determine a display level when creating shortpages. Fig. 10 shows the startpage of Fig. 3(a) after a shortpage has been created based on the web page of Fig. 5(a).
Fig. 11 shows the shortpage created from the web page of Fig. 5(a). Fig. 12 shows a fullpage corresponding to the web page of Fig. 5(a). Fig. 13 is a flow chart showing how the client and server interact to allow the user to view a shortpage. Fig. 14 is a flow chart showing details of determining whether a URL is the URL of a shortpage.
Fig. 15 is a flow chart for viewing a shortpage when the client is a personal digital assistant.
Fig. 16 is a block diagram of data flow when a shortpage is viewed on a personal digital assistant.
Fig. 17 is a display of a shared portal shortpage.
DETAILED DESCRIPTION OF EMBODIMENTS Reference will now be made in detail to several embodiments of the present invention, examples of which are illustrated in the accompanying drawings. Wherever practicable, the same reference numbers will be used throughout the drawings to refer to the same or like parts.
I. General Discussion A described embodiment of the present invention allows users to select certain sub- elements of one or more web pages as a shortpage. The user selects certain sub-elements of an original web page to create a shortpage. The user's selection information is saved and, when the user views the shortpage at a later time, only the sub-elements of the web page indicated by the user are displayed for viewing by the user. Thus, the user views only preselected sub-elements of the web page. This section discusses an exemplary data processing system used to implement a preferred embodiment of the present invention.
Fig. 1 is a block diagram of data processing elements in accordance with a preferred embodiment of the present invention. Fig. 1 includes a server data processing system 120 communicating with one or more client data processing systems. These client data processing systems include, but are not limited to, a desktop personal computer (PC) 102, a laptop computer 104, a palm computer (personal computer/assistant or handheld device) 106, a pager 108 (such as an alphanumeric pager), a web-enabled telephone or a cell phone 110, or some other appropriate web-enabled device or appliance 111. A web-enabled telephone or device could use, for example, the WAP (Wireless Application Protocol) or any other appropriate protocol. It should be understood that the client data processing systems shown in Fig. 1 are shown for purposes of example only and are not to be construed in a limiting sense. Any other appropriate type of client can be used in conjunction with the present invention. Fig. 1 also includes a plurality of web page servers 132, 134, 136. Each web page server communicates with server 120 and stores one or more web sites or web pages. Server 120 stores selection information 122 for each user and further stores selection-enabling information 124 that is added to a web page to enable a user to make selections from a web page. Communication can be over a network, such as the internet, an intranet, a wireless network, or in any other appropriate manner.
Fig. 2(a) shows an overview of creation of a shortpage. As shown in Fig. 2(a), during operation, a client 202 sends a request to server 120 for a web page. Server 120 retrieves the web page from an appropriate one of web sites 132-136. The server 120 adds selection- enabling information to the retrieved web page and sends the web page to the client. The client selects sub-elements of the web page and sends that selection information to server 120. Server 120 stores selection information 122 describing the shortpages defined by a user. Fig. 2(b) shows an overview of viewing a shortpage. The client sends a request for a shortpage to server 120. Server 120 determines the page or pages needed to view the shortpage in accordance with the stored selection information and retrieves the page or pages from the web site 132. Server 120 shortens the retrieved web page in accordance with the selection information to form a shortpage and sends the shortpage to the client.
It should be understood that each of the clients, servers, and web servers in the described embodiment preferably includes a processor and a memory. The memory includes instructions capable of being executed by the processor to perform the functions described below. A client and/or a server can also include a computer readable medium for storing the instructions. Server 120 communicates with the clients and the web page servers via any appropriate communication mechanism, including but not limited to a network, an intranet, the internet, wireless communications, telecommunications, cable modems, and satellite communications.
A client may include browser software suitable for viewing web pages. The browser software can be standalone or integrated within other software products. The functionality can be stored, for example, as a link, a JavaScript, or as a Java applet. Handheld clients contain a specialized browser that receive "snipped" sub-elements of web pages for viewing on a handheld client. Other clients (such as cell phones) do not necessarily contain a browser. It should be understood that references herein to "HTML" can be understood to refer to any appropriate page specification language, such as a hypertext language or a proprietary language.
The following paragraphs describe an example of how a user makes a shortpage. This example is provided for exemplary purposes only and is not to be interpreted in a limiting sense.
Fig. 3(a) shows a display of a "startpage" on a browser in a client. The startpage allows a user to create and edit shortpages and displays existing shortpages. Each user has his own startpage. The information needed to make a startpage is preferably stored in server 120. Fig. 3(a) shows a URL 310 of the exemplary startpage for user John Smith (http://www.shortware.com:9999 UserName=Jsmith&ProcName=StartPage). The startpage of Fig. 3(a) includes a link to a Notifications page 312, a link to an Edit profile page 314, and a link to a Help page 316. The startpage of Fig. 3(a) allows a user to create, edit, delete, and view shortpages and their options. To create a shortpage, in the described embodiment, the user enters a URL of a page into area 318 and selects "Create Shortpage" button 320. After a shortpage is created, its name will be displayed in Shortpages column 332. An existing shortpage can be viewed ("Go"), edited, options edited, or deleted by selecting the corresponding action in action box 330 and selecting a name of an existing shortpage.
Figs. 3(b)-3(e) are an example of the HTML source code for an exemplary startpage, similar to the StartPage of Fig. 3(a). This source code is included for the purpose of example and is not to be taken in a limiting sense.
Figs. 4(a)-4(c) are flow charts showing how a client and a server interact to perform shortpage operations, such as create, edit, delete, and view. Figs. 4(a) and 4(b) show a method performed by the client. In the described embodiment, the functionality of Figs. 4(a) and 4(b) are implemented via a Java Script executed by the client browser, although any appropriate implementation can be used. Fig. 4(c) shows a method performed by server 120. In Figs. 4(a) and 4(b), the client receives the user's actions (e.g., entering the URL of a web page and clicking "Create shortpage") and determines whether the user wants to create a shortpage (element 410), edit a shortpage (element 420), view a shortpage (element 430), delete a shortpage (element 440), or edit an option (element 450).
If the user wants to create a new shortpage (element 410), the client sends the URL of the page to shorten and a request to create a shortpage to server 120. The client receives a page created from the requested page and from selection-enabling information. In the example, the selection-enabling information allows the user to indicate that sub-elements of the page are shown or hidden. The client then displays the page, and allows the user to create a shortpage as described below. The resulting selection information is sent to server 120. In the described embodiment, selection information is sent to the server each time a page element is marked as "shown" or "hidden." In return, a new preview of the shortpage is sent from the server to the client, so that the preview view of the short page reflects the currently shown/hidden element. The server adds the name of the shortpage to the list of shortpages 332 on the page. If the user wants to edit a shortpage (element 420), the client sends the URL of the shortpage to edit and a request to edit a shortpage to server 120. The client receives a shortpage created from the original fullpage including selection-enabling information. The selection enabling information includes show/hide buttons and header links. The client then displays the page upon which the shortpage is based, including the selection-enabling information, and allows the user to edit the shortpage as described below. The resulting selection information is sent to server 120. Note that the show/hide buttons can instead be implemented as a one-button user interface, or by using some other appropriate type of user interface that allows the user to choose a subset of the web page elements. If the user wants to view a shortpage (element 430), the client sends the URL of the shortpage to view and a request to view a shortpage to server 120. The client receives the shortpage from server 120. The shortpage to be viewed does not include any selection- enabling information. The client then displays the shortpage.
If the user wants to delete a shortpage (element 440), the client sends the URL of the shortpage to delete and a request to delete a shortpage to server 120. Server 120 deletes the shortpage and returns an indication to the client that the shortpage has been deleted. The server removes the name of the shortpage from its list of shortpages 332.
If the client wants to edit options for a shortpage, the client sends the URL of the shortpage and a request to edit the options of the shortpage. The client receives the edit page from server and displays it. The user then edits the options and sends the edits to the server. Fig. 4(c) shows an overview of an exemplary shortpage method on the server side. When the server receives a request from the client's browser to create, edit, delete, or view a shortpage or option (element 450), the server translates the request into the appropriate request(s) to the web server(s) and retrieves the requested web page(s) or site(s) from the server(s) (element 452). In the described embodiment, these requests are HTTP requests and the web pages are written in HTML or a similar hypertext language. The server does the user-specified action (such as adding selection-enabling information when a shortpage is to be created or edited) or selecting the relevant parts of the web page (when a shortpage is to be viewed) (element 456). For example, the server adds the selection-enabling information to the retrieved web page and sends the resulting page to the client's browser. Table 1 shows an example of Web Procedure Calls (WPCs) used to communicate between the client and the server. The WPC is part of the URL sent by the client and has the format: /UserName=<username>&ProcName=<procname>{&argl=vall } {&arg2=val2} ... {& arglast=:vallast} where a string in pointed brackets "<" ">" indicates a type of data and a string in curly brackets "{" "}" indicates optional arguments.
II. Creating/Editing a Shortpage The following paragraphs provide exemplary details of how to create/edit a shortpage. The example shown in based on an exemplary web page shown in Fig. 5(a). The web page shown has a URL of http://abc.gov. In the example, a user visits this web site frequently and desires to select sub-elements of the web site to be placed on a shortpage. If the user desires to create a shortpage based on the web page of Fig. 5(a), he enters the URL of the web page into address 318 of Fig. 3 and selects "Create Shortpage" button 320. The server will retrieve the requested web page and add selection-enabling information to the page.
Figs. 5(b) and 5(c) show the web page of Fig. 5(a) displayed along with selection- enabling information. The server has broken the web page into blocks, each block having selection-enabling information. In the described embodiment, the selection-enabling information is a pair of show/hide boxes, having a check mark and an "X" respectively. The check mark indicates that the corresponding block will be shown in the shortpage. The "X" indicates that the corresponding block will be hidden (not shown) in the shortpage. Fig. 5(b) shows an editing area 510 and a preview area 520. Each of these areas can be sized and scrolled by the user. Initially all blocks in the page are marked as "hide." The example of Fig. 5(b) shows all blocks marked as "show." Therefore, in the example, preview area 520 shows all blocks in the page. In contrast, in Fig. 5(c), the user has clicked on the "X" box 505, causing the corresponding block 504 to be hidden in the shortpage. Note that the block 504 is not shown in the preview area 520 of Fig. 5(c).
Fig. 5(d) shows the web page of Fig. 5(a) with a different level of block detail. When the user clicks "more details" link 561 of Fig. 5(c), a command is sent to the server and the server re-determines the blocks of the page using a higher level of detail than previously used. (A similar "less detail" button 561' is displayed on the web page of Fig. 5(d)). A method of determining blocks on a page in accordance with a current level of detail is described below in connection with Fig. 9. In Fig. 5(d), for example, the page is broken into fewer blocks. For example, block 504 does not exist in editing area 510. Fig. 5(e) shows a web page that allows the user to view/edit shortpage properties. The web page of Fig. 5(e) is requested when the user clicks on "Next" link 560, as shown in Figs. 5(b) - 5(d). This page allow the user to enter properties of a shortpage. The user can change the name associated with the shortpage (for example, the name shown in area 332 of Fig. 3) by entering a new name in area 570. The user can enter comments in area 572. The user can indicate that the shortpage does not show the page background in area 574. The user can indicate that changes since the last time the shortpage was viewed should be highlighted on the shortpage in area 576. The user can indicate that the shortpage should be used for similar pages and all URLs starting with a specified string (areas 578 and 580). Other properties could be included or certain properties shown in the figure excluded without departing from the spirit or scope of the invention. When the user clicks a "Done" button 582, the client sends the entered information to server 120, which stores the entered information in connection with the shortpage.
Fig. 6 is a flow chart showing how the client and the server interact to allow the user to create/edit a shortpage. Each element of the flow chart has a notation next to it indicating whether it is preferably performed by the client, server, or a combination. In element 602, after the server has retrieved a page from a web server, the server needs to break the page down into blocks and to add selection-enabling information to the page for each block. The server uses the SplitPage method (Fig. 8) and the Level of Detail method (Fig. 9) to break the page into blocks. In element 604, the server adds selection-enabling information to the retrieved web page. Specifically, the server adds a "Show" button and a "Hide" button next to the block and puts a border (<table>) around it. The client's browser, thus, displays the web page along with the selection-enabling information for each block.
When the user selects "Show" or "Hide," an HTTP request that uniquely identifies the button is sent to the server (see Table 1). In element 608, the server marks the corresponding block as either "shown" or "hidden" in the representation tree (RepTree) for the shortpage. This information is a part of the selection information stored on the server. In element 610, the server returns a preview of the resulting shortpage to the user, which is displayed in a separate frame (preview area 520). The marked-up RepTree is stored as the template for future references to this shortpage. Thus, the RepTree forms at least part of the selection information. It will be understood that, although the example shows certain actions being performed by the client or the server, other embodiments may implement the client or server to perform actions not shown as being performed by them. For example, the selection information could be stored on the client side.
Fig. 7 shows an example of parsing used by the server to create and edit shortpages. This figure shows the Split Page method. In the example, a page is represented by an HTML file. The HTML is parsed in a manner known to persons of ordinary skill in the art to yield a Representation Tree. The Representation Tree has complex multipart tags (e.g., <ul>), simple tags (e.g., <img src=Img.gif>), and text nodes (e.g., iteml). A simple tag is defined as a tag that has no children and a complex tag is defined as a tag that has children. Server 120 parses the HTML file into a RepTree and iterates down the tree in a depth-first way to mark each node in the tree according to whether it is a single block. The RepTree includes a flag for each block indicating whether it is shown or hidden. A detailed example of the format of a RepTree is shown in Table 2. This format is not to be taken in a limiting sense.
Fig. 8 shows an example of a split page method used to create/edit shortpages. As shown in Fig. 8, if a node corresponds to a simple tag that is an image, input, iframe, or object, it is marked as a single block. If a node corresponds to a complex tag of type <tr> and there are more than two rows or columns in the table, mark the node. If a node corresponds to a complex tag of type <form>, do not mark the node. If a node corresponds to a complex tag of other types, mark the node if it has any text. For other types of nodes, continue traversing the RepTree. For each complex node, walk down the list of its children. Any nodes between two single blocks become one complex block. To avoid creating extra blocks, if a node has only one child block, give the block status to the parent node instead.
Fig. 9 is a flow chart of how to determine a display level when creating shortpages. In the described embodiment, the level of detail is used to decrease the number of blocks displayed at a given time. This flow chart demonstrates how to work with two levels (high and low), but any number of levels can be supported. If the level of detail is low, element
904 determines whether the block's parent has less than L nodes below its children. L can be, for example, 5. If the block's parent has less than L nodes below its children, the block is shown as a separate block when the user creates or edits a shortpage. Otherwise, the block is not shown as a separate block. If the level of detail is high, element 906 determines whether the block has more than K nodes below its children. K can be, for example, 1. If the block has more than K nodes below its children, the block is shown as a separate block when the user creates a shortpage. Otherwise, the block is not shown as a separate block. Fig. 10 shows the startpage of Fig. 3 after a shortpage has been created based on the web page of Fig. 5(a). Server 120 indicates to the client that a shortpage has been created and adds the name of the shortpage to area 332 of the user's startpage. The startpage having the name of the new shortpage is sent to the browser, where it is displayed. Fig. 11 shows the shortpage created from the web page of Fig. 5(a). In the example, the user selected certain sub-elements of the page. Specifically, the user indicated that all but a leftmost block of the page is marked as hidden. Thus, the shortpage shows only the non- hidden block. The shortpage also includes a link to the user's startpage 1102, a link to a notification page 1104, a link to a help page 1106, a link to a page that allows the user to edit a shortpage 1105 and a link to the fullpage 1103 upon which the shortpage is based. Note that the user has indicated that the background of the original page is not to be shown in this shortpage (see Fig. 5(e)).
Fig. 12 shows a fullpage corresponding to the web page of Fig. 11. The fullpage is displayed when the user clicks on the fullpage link 1103 of Fig. 11. In contrast to the shortpage, the original page's background is shown, since it is part of the page. Even though all blocks of the fullpage are shown, the full page is fetched via server 120 and not directly from the web page server. This is shown by the URL of the fullpage: http://shortwave.com:9999/UserName=JSmith ProcName=B_GetPage&purpose=7& txtURL=http://www.abc.gov . In this example, the user is "JSmith". The action is to get/fetch a page. "Purpose = 7" indicates that a full page should be fetched. The URL of the full page is http://www.abc.gov. Further example of parameters used to communicate between the client and the server are described in Table 1.
III. Viewing a ShortPage
Fig. 13 is a flow chart showing how the client and server interact to allow the user to view a shortpage. In the described embodiment, the user has selected a name of a shortpage in area 332 and selected "go" in area 330. It should be remembered that, although a shortpage may be based on a particular web page, that web page may have changed since the shortpage was created, either because content may have been changed, added, or deleted. It is necessary to parse the web page on which the shortpage is based (the target) and determine whether the blocks marked "show" in the template are still present in the target. The target page on which the shortpage is based is retrieved and parsed into a RepTree by the server. Each shortpage has a RepTree associated with it.
In element 1304, the server performs a "double traverse" method, recursively traversing down both the template and the target RepTrees, trying to match the nodes. If two nodes match by type and tag, assign the "Show" or "Hide" flags of the template node to the target node. If there is no match, start to look for the closest match. If, for example, we are currently on nodes Temp[I], Targ[J], then we are looking for matching Temp[K] and Targ[L] such that, for K and L, K-I+L-J is the smallest possible value.
After element 1308, any template nodes that are not matched were the nodes that have disappeared from the page. Any target nodes that were not matched were the nodes that have been added to the page. All target nodes with "Show" flags (i.e., all target blocks that matched a block in the template) are part of the shortpage. These blocks are sent to the requesting client. Other appropriate matching methods can also be used.
In the described embodiment, the user can enter the address of a web page to be shortened. For example, the user can enter a URL in area 318 and click on button 340. If the user has previously defined a shortpage for this URL or for a URL on this web site, the shortpage is displayed. Similarly, if a page has a link to another page within it and the link is selected, server 120 will check the new link to determine whether it is a shortpage.
Fig. 14 is a flow chart showing details of determining whether a URL is the URL of a shortpage. As described in element 1402, this method will be used when, instead of requesting a specific shortpage, the user enters or browses to a particular URL. In element 1404, for each shortpage that the user has, server 120 compares the URL, host name, document name, and CGI argument lists. The server does this for both a shortpage requested address and for the actual address. The requested address and the actual address may be different because of HTTP redirection.
If, in element 1406, the host name, document, name, and CGI parameter names match, it is a "clear match." If a clear match occurs, use this shortpage for customizing the request. If a clear match does not occur, control passes to element 1410. In element 1410, for each "approximate match" (which is defined as host name and document name match), calculate "match ranking." Step 1412 calculates match ranking as follows. For each matching RepNode of RepTree, add (l/(Node depth)) to the rank. For each mismatch, subtract the same amount. In step 1414, select the shortpage with the highest matching rank for customizing this request. If no match occurs, then show the full page.
IV. Handheld client As discussed in connection with Fig. 1, the present invention can be implemented for a wide variety of clients. Fig. 16 is a block diagram of data flow when a shortpage is viewed on a personal digital assistant, such as a Palm VII Personal Digital Assistant (Available from 3Com Corporation) or a similar handheld device. PDAs often use a "web clipping" system to view web pages. The PDA views predefined web clippings by sending a request for the clipped pages to a proxy server.
Initially, a "web clipping" application, which contains a single link to the user's startpage is created and downloaded into the user's handheld device. The user creates his shortpages as described above. Preferably, these shortpages are created on the user's PC, although other embodiments may allow the user to create them on the handheld. To view a shortpage, the user simply goes to his startpage "web clipping" in the handheld and selects a link to the shortpage. As shown in Fig. 16, this action causes a request to be sent to the proxy server 1604, which passes the request to the shortpage server 1606, which forwards the request to the web site 1608 hosting the full page. The web site returns the requested page(s) to the shortpage server 1606, which creates a shortpage as described above and which then passes the created shortpage to the proxy server 1604. The proxy server sends the shortpage to the handheld client 1602.
Fig. 15 is a flow chart for viewing a shortpage when the client is a personal digital assistant. In element 1502, a web clipping short page application, which contains a single link to the user's startpage is created and downloaded into the user's PDA. In element 1504, the user creates his shortpage as before, using his PC or similar device. In element 1506, to view a shortpage, the user simply goes to his startpage "web clipping" and selects a link to the shortpage. In element 1508, the request goes through a proxy server (such as palm.net of 3Com) and is forwarded to the site hosting the page or pages. In element 1510, the response from the web server is customized by the Shortpage server and goes back to the user. In the described embodiment, the shortpage server creates a modified version of a shortpage when it knows that the client is a handheld device. For example, the shortpage server removes large graphic files and Java Script code. Other embodiments may make other modifications or no modifications, depending on the nature and capabilities of the handheld client. In the described embodiment, the proxy server also modifies the page somewhat before sending the page to the handheld client.
V. Shared Portal
Fig. 17 is a display of a shared portal shortpage application. A shared portal is created by one or more persons and is viewable by multiple persons. Different users may have different access permissions stored within the server. For example, in one embodiment, a single user has permissions to create folders (such as folder 1702), but any user can add shortpages within folders (link 1704 is a link to a page titled "Bay Area News"). As another example, only a single user can add folders and links, but any user can access the shortpages. In a shared portal, whenever a user attempts to edit or create a shortpage, the server first checks the permissions of the user. The user may be required to enter a password and/or to Log on from an approved machine. Similarly, whenever a user attempts to access a shortpage, the server checks the permissions of the user to determine whether the user is authorized to access the page he has requested. A shared portals may be open to all users or may be restricted to certain groups, such as families, employees of a company, employees of a department, or clubs.
VI. Cluster Implementation
In one embodiment of the present invention, server 120 resides on a number of nodes, which are dual-Pentium Windows NT PCs. In this implementation, data is stored in a shared RAID file server. A hardware load-balancer, such as a Big DP load balancer from FS Networks, Inc. of Seattle, Washington is used to route user requests to the least busy node. Such an implementation uses persistent connections with, for example, a ten minute timeout to ensure that the requests from the same address get to the same server. When the first request for the given user comes to the given server, the user's data is read from the file server. If there is no activity for the time Q (for example, Q>T, 12 minutes), the data for the user is cleared from memory.
While the invention has been described in conjunction with a specific embodiment, it is evident that many alternatives, modifications and variations will be apparent to those skilled in the art in light of the foregoing description. For example, in one embodiment, shortpages are pre-created and offered to third persons who want specialized information or who want shorter web pages. Accordingly, it is intended to embrace all such alternatives, modifications and variations as fall within the spirit and scope of the appended claims and equivalents.
Table 1 (Page 1 of 1)
WPCs - Web Procedure Call list All WPCs take a usemame.
// The WPC consists of: (without "<" or ">") //
/Usemame=<usemame>&ProcName=<procname>&arg 1 =val 1 &arg2=val2&...&argLast=val Last // (The number of args is variable, and the "last" arg is optional).
// New user registration and user login.
NewUserLogin - Allows the user to enter registration information RegisterUser - Submits usemame, full name, password, email, and other info for a new user. LoginUser - login user. Takes usemame and password
// Wizard Action
WizardAction - takes object (shortpage, notification, or combopage) id Edit - start editing the object
Props - Displays properties of the object
CreateShortpage - creates a shortpage
CreateNotification - creates a notification
CreateCombopage - creates a combopage Browse - browse to the given URL
Go - go to the given shortpage/combopage
Delete - delete given object
Next - present logically the next screen in the wizard
Done - done with the editing Cancel - cancel editing
B_GetPage - Get a page. Takes a URL
B_GetPageS - Same, but the request came through a script, URL needs some massaging.
Takes a URL and a base URL for the page to be appended to it. StartPage - show Start Page for the user
NotifPage - Show notification page for the user
U_DeleteNotifs - delete certain notification messages. Takes message ids.
P_SelectionFrame - Displays the selection frame (upper frame) for the shortpage creation
P_DoCommand - do editing command, such as "Show" block, or "Hide" block. Takes block id as a parameter, and command id ("Show", "Hide", "Notify", etc.)
ProfileMgrAction - Edit profile settings Table 2 (Page 1 of 2) typedef CArray<CRepNode*, CRepNode*> CRepNodeArray; class CRepNode
{ friend class CRepBuilder; public:
CReρNode(CRepNode *pParent=NULL, int ilndex=0); virtual ~CRepNode(); void AddChild(CRepNode *pChild); void InsertChild(CRepNode *pChild, int ilndex); void Serialize(CMyArchive& ar); enum Type{
NONE,
TEXT, SIMPLE_TAG,
CONTAINER_TAG,
COMMENT,
BADTAG, // bad closing tag.
SCRIPT, // script node contains both <SCRIPT> and </SCRIPT> WHITESPACE,// whatever "trims" to an empty string.
BAD_CLOSING
};
Type m_Type;
#define FLG_BLOCK_BEGIN 0x1 #defme FLG_BLOCK_END 0x2
#define FLG_BLOCK_MASK (FLG_BLOCK_BEGIN | FLG_BLOCK_END)
#define FLG_FHDE 0x10 // hide this node. #define FLG_CHANGED 0x20 // node has changed
#define FLG_NOMATCH 0x40 // couldn't match this node.
#define FLG SHOW 0x80 // show the node and subnodes.
#define FLG_NOTIFY 0x100 // Notify on this node.
#define FLG_B ADLY_CLOSED 0x200 // This node is incorrectly nested. #define FLG_TEMP OxfOOO // The mask for temp bits used by stuff
// here and there for a short time. Table 2 (Page 2 of 2)
ULONG m_Flags; CNodelnfo *m_pInfo; // any data can be stored here.
// not saved to the disk! CNotifylnfo *m_pNotify; // Notification info on this node.
// must be serialized.
// has either the text, or a simple tag or // the full tag with params, but without nested tags.. Example: // "<TD WTDTH=117 VALIGN=TOP ALIGN=LEFT>"
CString m_Text;
// Children of a complex tag. CRepNodeArray m_aKids;
// the following two fields are redundant for all known (to our // program) tags. TAG m_Tag;
// The tag without params and < or >, like "TD"
// Note that there is never a closing tag, like </TD> in the representation.
// If the type of the node is CONTAINER_TAG, then it is assumed that
// there is a closing tag after all m_aKids. CString m_TagName;
CString mJSTodeHeader;
CRepNode *GetParent() { return m_pParent; } int Getlndex() { return m_Index; }
CRepNode *m_pParent; // root object has this NULL int m_Index; // index into the array of the parent node. #if DEBUG void AssertValidO; // CObject-like validation function. #endif
} ;

Claims

WHAT IS CLAIMED IS:
1. A method for creating a short web page, comprising: allowing a user to choose a subset of elements that appear on an original web page; saving the user's choices; and creating a short web page that is based on the original web page, and includes the elements chosen by the user in accordance with the user's saved choices.
2. The method of claim 1, wherein creating a short web page includes: retrieving a current version of the original web page; selecting the user's chosen elements from the current version of the original web page; and creating the short web page that includes the chosen elements.
3. The method of claim 1, wherein the short web page includes only the chosen elements.
4. The method of claim 1, wherein allowing the user to choose a subset of elements includes: adding selection-enabling information to the original web page; sending the original web page including the selection-enabling information to the user's browser; and receiving an indication that the user has selected at least one element of the original web page.
5. The method of claim 1, wherein the short web page is displayed on a client system.
6. The method of claim 5, wherein the client system is a personal computer.
7. The method of claim 5, wherein the client system is a personal digital assistant device.
8. The method of claim 5, wherein the client system is a web-enabled telephone having a display.
9. The method of claim 5, wherein the client system is an alphanumeric paging device.
10. The method of claim 5, wherein the client system is a web-enabled device.
11. The method of claim 1, wherein the client system is a device using the WAP protocol.
12. The method of claim 1, wherein the original web page is a world wide web page.
13. The method of claim 1, wherein the original web page is specified in a hypertext markup language.
14. A method for creating a short web page, comprising: storing in a memory selection information specifying the elements on a short web page, the short web page being based on an original web page; retrieving the original web page upon which the short web page is based; and creating the short web page from elements on the original web page in accordance with the selection information.
15. The method of claim 14, wherein the short web page is displayed on a client system.
16. The method of claim 15, wherein the client system is a personal computer.
17. The method of claim 15, wherein the client system is a personal digital assistant device.
18. The method of claim 15, wherein the client system is a web-enabled telephone.
19. The method of claim 15, wherein the client system is an alphanumeric paging device.
20. The method of claim 15, wherein the client system is a web-enabled device.
21. The method of claim 14, wherein the client system is a device using the WAP protocol.
22. The method of claim 14, wherein the original web page is a world wide web page.
23. The method of claim 14, wherein the original web page is specified in a hypertext markup language.
24. A computer-implemented method performed by a server data processing system, comprising: receiving, from a client, a request for a web page; retrieving the requested web page; sending the requested web page to the client; receiving, from the client, selection information for the requested web page, the selection information indicating a subset of the information of the web page that is smaller than the set of all information on the web page; and storing the selection information in the server data processing system.
25. The method of claim 24, further comprising, by the server data processing system: splitting the retrieved web page into page elements, by the server data processing system; and creating a new version of the retrieved web page, the new version of the web page including selection-enabling information, wherein sending the requested web page to the client includes sending the new version of the retrieved web page that includes the selection-enabling information.
26. The method of claim 24, wherein the requested web page sent to the client does not include selection- enabling information, and wherein the selection-enabling information is added to the retrieved web page by the client.
27. A computer-implemented method performed by a server data processing system, comprising: receiving, from a client, a request for a user's short page; retrieving a web page on which the user's short page is based; selecting sub-elements of the retrieved web page, in accordance with selection information of the user stored in the server data processing; and sending the user's short page, containing the selected sub-elements of the retrieved web page to the user.
28. The method of claim 27, wherein the selection information indicates whether sub- elements of the retrieved web page are shown or hidden in the shortpage.
29. The method of claim 27, wherein receiving a request for a user's short page is performed at initialization of the user's browser.
30. The method of claim 27, further comprising: receiving, from the user, a request to create a page for the user.
31. A computer-implemented method performed by a client data processing system, comprising: sending, by a client, a request for a web page; receiving the requested web page; allowing the user to select sub-elements of the received web page as being hidden or shown, the hidden sub-elements being indicated by selection information; and sending, to a server, the selection information for the web page.
32. The method of claim 31, further comprising: receiving a web page that is split into page elements, each page element having a selection-enabling information associated therewith; receiving input from a user selecting at least one page element of the web page to yield selection information; and sending the selection information to a server.
33. An apparatus to create a short web page, comprising: a software portion configured to allow a user to choose a subset of elements that appear on an original web page; a software portion configured to save the user's choices; and a software portion configured to create a short web page that is based on the original web page, and that includes the elements chosen by the user in accordance with the user's saved choices.
34. The apparatus of claim 33, wherein the software portion configured to creating a short web page includes: a software portion configured to retrieve a current version of the original web page; a software portion configured to select the user's chosen elements from the current version of the original web page; and a software portion configured to create the short web page that includes the chosen elements.
35. The apparatus of claim 33, wherein the software portion configured to allow the user to choose a subset of elements includes: a software portion configured to add selection-enabling information to the original web page; a software portion configured to end the original web page including the selection-enabling information to the user's browser; and a software portion configured to receive an indication that the user has selected at least one element of the original web page.
36. The apparatus of claim 33, wherein the software portions are in a web-enabled device.
37. The apparatus of claim 33, further comprising: a software portion configured to receive a short web page via the WAP protocol.
38. An apparatus for creating a short web page, comprising: a software portion configured to store in a memory selection information specifying the elements on a short web page, the short web page being based on an original web page; a software portion configured to retrieve the original web page upon which the short web page is based; and a software portion configured to create the short web page from elements on the original web page in accordance with the selection information. 39. A computer program product, comprising: a computer readable medium, storing computer instructions thereon to create a short web page, including: program code devices configured to allow a user to choose a subset of elements that appear on an original web page; program code devices configured to save the user's choices; and program code devices configured to create a short web page that is based on the original web page, and that includes the elements chosen by the user in accordance with the user's saved choices.
40. The computer program product of claim 39, wherein program code devices configured to create a short web page include: program code devices configured to retrieve a current version of the original web page; program code devices configured to select the user's chosen elements from the current version of the original web page; and program code devices configured to create the short web page that includes the chosen elements.
41. The computer program product of claim 39, wherein the program code devices configured to allow the user to choose a subset of elements include: program code devices configured to add selection-enabling information to the original web page; program code devices configured to end the original web page including the selection-enabling information to the user's browser; and program code devices configured to receive an indication that the user has selected at least one element of the original web page.
42. The computer program product of claim 39, wherein a client system is a web- enabled device.
43. The computer program product of claim 39, further comprising: program code devices configured to receive a short web page via the WAP protocol.
44. A computer program product, comprising a computer readable medium storing computer instructions thereon to create a short web page, including: program code devices configured to store in a memory selection information specifying the elements on a short web page, the short web page being based on an original web page; program code devices configured to retrieve the original web page upon which the short web page is based; and program code devices configured to create the short web page from elements on the original web page in accordance with the selection information.
45. The computer program product of claim 39, wherein a client system is a web- enabled device.
6. The method of claim 1, wherein the short web page is a shared portal.
PCT/US2000/021700 1999-08-10 2000-08-08 Method and apparatus for selecting and viewing portions of web pages WO2001011488A2 (en)

Priority Applications (1)

Application Number Priority Date Filing Date Title
AU67619/00A AU6761900A (en) 1999-08-10 2000-08-08 Method and apparatus for selecting and viewing portions of web pages

Applications Claiming Priority (6)

Application Number Priority Date Filing Date Title
US37241099A 1999-08-10 1999-08-10
US09/371,161 1999-08-10
US09/372,402 1999-08-10
US09/372,402 US6834306B1 (en) 1999-08-10 1999-08-10 Method and apparatus for notifying a user of changes to certain parts of web pages
US09/372,410 1999-08-10
US09/371,161 US6763388B1 (en) 1999-08-10 1999-08-10 Method and apparatus for selecting and viewing portions of web pages

Publications (2)

Publication Number Publication Date
WO2001011488A2 true WO2001011488A2 (en) 2001-02-15
WO2001011488A3 WO2001011488A3 (en) 2004-02-19

Family

ID=27409003

Family Applications (3)

Application Number Title Priority Date Filing Date
PCT/US2000/021702 WO2001011503A2 (en) 1999-08-10 2000-08-08 Method and apparatus for notifying a user of changes to certain parts of web pages
PCT/US2000/021700 WO2001011488A2 (en) 1999-08-10 2000-08-08 Method and apparatus for selecting and viewing portions of web pages
PCT/US2000/021701 WO2001011502A2 (en) 1999-08-10 2000-08-08 Method and apparatus for combining parts of different web pages

Family Applications Before (1)

Application Number Title Priority Date Filing Date
PCT/US2000/021702 WO2001011503A2 (en) 1999-08-10 2000-08-08 Method and apparatus for notifying a user of changes to certain parts of web pages

Family Applications After (1)

Application Number Title Priority Date Filing Date
PCT/US2000/021701 WO2001011502A2 (en) 1999-08-10 2000-08-08 Method and apparatus for combining parts of different web pages

Country Status (2)

Country Link
AU (3) AU6761900A (en)
WO (3) WO2001011503A2 (en)

Cited By (9)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US6763388B1 (en) * 1999-08-10 2004-07-13 Akamai Technologies, Inc. Method and apparatus for selecting and viewing portions of web pages
US6834306B1 (en) 1999-08-10 2004-12-21 Akamai Technologies, Inc. Method and apparatus for notifying a user of changes to certain parts of web pages
US6904455B1 (en) 1999-11-24 2005-06-07 Robert C. Yen Method and system for providing local content for use in partially satisfying internet data requests from remote servers
US7222161B2 (en) 1999-11-24 2007-05-22 Yen Robert C Method and system for facilitating usage of local content at client machine
US7245634B2 (en) 2000-09-27 2007-07-17 Yen Robert C Wireless internet access with enhanced bandwidth capabilities
US7970816B2 (en) 2002-03-01 2011-06-28 NetSuite Inc. Client-side caching of pages with changing content
US8516146B1 (en) 1999-11-24 2013-08-20 Robert C. Yen Method and system for reduction of delay and bandwidth requirements in internet data transfer
CN104994183A (en) * 2015-06-19 2015-10-21 小米科技有限责任公司 Short network address determining method and device
US9538386B2 (en) 1999-11-24 2017-01-03 Robert C. Yen Wireless internet access with enhanced bandwidth capabilities

Families Citing this family (5)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
JP2004005500A (en) * 2002-03-28 2004-01-08 Matsushita Electric Ind Co Ltd Information processor and information processing program
US8745515B2 (en) 2004-04-07 2014-06-03 Nokia Corporation Presentation of large pages on small displays
BRPI0414379A (en) 2003-09-24 2006-11-21 Nokia Corp method for presenting at least a portion of an object, computing program, computing program product, and, device and system for presenting at least a portion of an object
US7559016B1 (en) 2004-10-07 2009-07-07 Google Inc. System and method for indicating web page modifications
CN103314370A (en) * 2010-08-13 2013-09-18 索尼爱立信移动通讯有限公司 Automatic notification

Citations (1)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US5649186A (en) * 1995-08-07 1997-07-15 Silicon Graphics Incorporated System and method for a computer-based dynamic information clipping service

Family Cites Families (1)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US5898836A (en) * 1997-01-14 1999-04-27 Netmind Services, Inc. Change-detection tool indicating degree and location of change of internet documents by comparison of cyclic-redundancy-check(CRC) signatures

Patent Citations (1)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US5649186A (en) * 1995-08-07 1997-07-15 Silicon Graphics Incorporated System and method for a computer-based dynamic information clipping service

Non-Patent Citations (2)

* Cited by examiner, † Cited by third party
Title
BICKMORE T W ET AL: "Digestor: device-independent access to the World Wide Web" COMPUTER NETWORKS AND ISDN SYSTEMS, NORTH HOLLAND PUBLISHING. AMSTERDAM, NL, vol. 29, no. 8-13, 1 September 1997 (1997-09-01), pages 1075-1082, XP004095305 ISSN: 0169-7552 *
T. KAMBA, K. BHARAT, MC. ALBERS: "The Krakatoa Chronicle An Interactive, Personalized, Newspaper on the Web" INTERNET ARTICLE, [Online] 1995, pages 1-15, XP002257399 Retrieved from the Internet: <URL:http://citeseer.nj.nec.com/kamba95kra katoa.html> [retrieved on 2003-10-10] *

Cited By (14)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US6763388B1 (en) * 1999-08-10 2004-07-13 Akamai Technologies, Inc. Method and apparatus for selecting and viewing portions of web pages
US6834306B1 (en) 1999-08-10 2004-12-21 Akamai Technologies, Inc. Method and apparatus for notifying a user of changes to certain parts of web pages
US8972527B2 (en) 1999-11-24 2015-03-03 Robert C. Yen Method and system for reduction of delay and bandwidth requirements in internet data transfer
US7222161B2 (en) 1999-11-24 2007-05-22 Yen Robert C Method and system for facilitating usage of local content at client machine
US8307113B2 (en) 1999-11-24 2012-11-06 Yen Robert C Wireless internet access with enhanced bandwidth capabilities
US8516146B1 (en) 1999-11-24 2013-08-20 Robert C. Yen Method and system for reduction of delay and bandwidth requirements in internet data transfer
US6904455B1 (en) 1999-11-24 2005-06-07 Robert C. Yen Method and system for providing local content for use in partially satisfying internet data requests from remote servers
US9538386B2 (en) 1999-11-24 2017-01-03 Robert C. Yen Wireless internet access with enhanced bandwidth capabilities
US10091121B2 (en) 1999-11-24 2018-10-02 Robert C. Yen Method and system for reduction of delay and bandwidth requirements in internet data transfer
US10652750B2 (en) 1999-11-24 2020-05-12 Robert C. Yen Wireless internet access with enhanced bandwidth capabilities
US7245634B2 (en) 2000-09-27 2007-07-17 Yen Robert C Wireless internet access with enhanced bandwidth capabilities
US7970816B2 (en) 2002-03-01 2011-06-28 NetSuite Inc. Client-side caching of pages with changing content
US8082299B2 (en) 2002-03-01 2011-12-20 NetSuite Inc. Methods and systems of client-side caching of pages with changing content
CN104994183A (en) * 2015-06-19 2015-10-21 小米科技有限责任公司 Short network address determining method and device

Also Published As

Publication number Publication date
AU6762000A (en) 2001-03-05
WO2001011502A3 (en) 2004-02-19
WO2001011503A3 (en) 2003-12-18
WO2001011503A2 (en) 2001-02-15
AU6762100A (en) 2001-03-05
WO2001011502A2 (en) 2001-02-15
WO2001011488A3 (en) 2004-02-19
AU6761900A (en) 2001-03-05

Similar Documents

Publication Publication Date Title
US6763388B1 (en) Method and apparatus for selecting and viewing portions of web pages
US6834306B1 (en) Method and apparatus for notifying a user of changes to certain parts of web pages
US10142431B2 (en) Real-time information feed
US6412008B1 (en) System and method for cooperative client/server customization of web pages
KR100583874B1 (en) Predictive caching and highliting of web pages
EP1320972B1 (en) Network server
US6278449B1 (en) Apparatus and method for designating information to be retrieved over a computer network
US8793341B2 (en) Web page content translator
US9147004B2 (en) Website builder systems and methods with device detection to adapt rendering behavior based on device type
US6925595B1 (en) Method and system for content conversion of hypertext data using data mining
US5778372A (en) Remote retrieval and display management of electronic document with incorporated images
US20050015772A1 (en) Method and system for device specific application optimization via a portal server
US20060206803A1 (en) Interactive desktop wallpaper system
US20030009489A1 (en) Method for mining data and automatically associating source locations
JP2003512666A (en) Intelligent harvesting and navigation systems and methods
WO2001003011A2 (en) Cross-media information server
WO2001011488A2 (en) Method and apparatus for selecting and viewing portions of web pages
US20020026472A1 (en) Service request method and system using input sensitive specifications on wired and wireless networks
WO2008044821A2 (en) Method and system for previewing web-page with hypertext at web-browsing
US20030009496A1 (en) Bookmarks for world wide web documents with indicators of the hit rates for the web documents from the web sites sending the documents
KR20030039844A (en) System and method of operating contents for wire/wireless total internet service
US9015240B2 (en) Web-styled messaging system
JP3949923B2 (en) Passive browsing data processing method, passive browsing data processing program, terminal-side passive browsing data processing program, passive browsing data browsing program
KR20000012596A (en) Method and system for servicing information and/or services using direct access mode
JPH10301954A (en) Method and system for retrieving image

Legal Events

Date Code Title Description
AK Designated states

Kind code of ref document: A2

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

AL Designated countries for regional patents

Kind code of ref document: A2

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

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

Ref country code: DE

Ref legal event code: 8642

122 Ep: pct application non-entry in european phase
NENP Non-entry into the national phase in:

Ref country code: JP