GROUP UNIVERSAL RESOURCE IDENTIFIERS

Information

  • Patent Application
  • 20120131045
  • Publication Number
    20120131045
  • Date Filed
    November 14, 2011
    13 years ago
  • Date Published
    May 24, 2012
    12 years ago
Abstract
A message is received with an encoding of a group universal resource identifier that identifies a resource group and of a plurality of member universal resource identifiers for a plurality of resources that constitute the resource group. The message is received subsequent to requesting the resource group with the group universal resource identifier. For each of the plurality of member universal resource identifiers in an order designated by the message, the member universal resource identifier is extracted. The member universal resource identifier comprises a member resource name and a universal resource identifier that identifies a corresponding one of the plurality of resources. The member universal resource identifier is inserted into navigation history of a web browser. The member universal resource identifier is inserted into the navigation history in accordance with the order.
Description
BACKGROUND

The inventive subject matter relates to data processing, or, more specifically, group URIs.


Special needs computer users often have limited ability to navigate through a series of links embedded in HTML documents or web pages. It is often physically difficult for special needs users to perform the tasks of moving interface pointers to web links and invoking the links to move among web pages. Browsers do not support recording series of navigational actions for later playback. Browsers do not support the persistence of playback of navigated links once a browser session is completed.


Browsers do provide storage of single web addresses as bookmarks or favorites listings. In the Netscape Navigator community such single address listings are referred to as ‘bookmarks,’ and they are called ‘favorites’ by users of Microsoft's Internet Explorer. For clarity in this specification, all such single address listings are referred to as ‘bookmarks.’ In current art, however bookmarks are not saved as groups, but rather as single addresses. The locations visited by a user before and after a web address recorded as a bookmark are lost.


In addition, web content providers often cause a newly navigated web page to be displayed in a new instance of a web browser, leaving behind in a first browser the navigation history of the user's current session and disabling the ‘Back’ button for the new instance of the browser. The ‘back’ button in the new browser is not effective to return the user to the window from which the web page was ordered. The effect, for example, is that a user reading a book cannot turn the page back to page two when reading page three. In order to return to a previous page in the book example, a user must terminate a present instance of the browser or otherwise bring a previous instance of the browser into focus in, for example, another window or frame. This is inconvenient for all users, but it is very inconvenient for disabled users.


SUMMARY

Embodiments include a method that receives message with an encoding of a group universal resource identifier that identifies a resource group and of a plurality of member universal resource identifiers for a plurality of resources that constitute the resource group. The message is received subsequent to requesting the resource group with the group universal resource identifier. For each of the plurality of member universal resource identifiers in an order designated by the message, the member universal resource identifier is extracted. The member universal resource identifier comprises a member resource name and a universal resource identifier that identifies a corresponding one of the plurality of resources. The member universal resource identifier is inserted into navigation history of a web browser. The member universal resource identifier is inserted into the navigation history in accordance with the order.


Embodiments include a computer program product for resource group administration. The computer program product comprises a computer readable recording medium having computer usable program code embodied therewith. The computer usable program code comprises a computer usable program code configured to determine that a header of a message indicates a data type as group universal resource identifier and that the message indicates a group universal resource identifier that identifies a resource group. The computer usable program code is configured to query a database of group universal resource identifiers with the group universal resource identifier. The computer usable program code is configured to, responsive to the query, obtain a plurality of member universal resource identifiers that identifies a plurality of resources that constitutes the resource group. The computer usable program code is configured to create a response message that indicates the group universal resource identifier and the plurality of member resource identifiers in an order defined for the resource group.





BRIEF DESCRIPTION OF THE DRAWINGS


FIG. 1 is a data flow diagram of an exemplary embodiment of a method for administration of URIs in groups.



FIG. 2 is a data flow diagram of a further exemplary embodiment of a method for administration of URIs in groups.



FIG. 3 is a data flow diagram of a still further exemplary embodiment of a method for administration of URIs in groups.



FIG. 4 is a data flow diagram of an even further exemplary embodiment of a method for administration of URIs in groups.



FIG. 5 is a data flow diagram of an even further exemplary embodiment of a method for administration of URIs in groups.



FIG. 6 is a data flow diagram of a method of identifying an embedded hyperlink within a search result and a method of storing a member URI and a group URI.



FIG. 7 is a data flow diagram of still a further exemplary embodiment of a method for administration of URIs in groups.



FIG. 8 is a block diagram illustrating aspects of browser user interfaces useful in various exemplary embodiments.





DETAILED DESCRIPTION

The present inventive subject matter is described to a large extent in this specification in terms of methods for administration of URIs in groups. Persons skilled in the art, however, will recognize that any computer system that includes suitable programming means for operating in accordance with the disclosed methods also falls well within the scope of the present inventive subject matter.


Suitable programming means include any means for directing a computer system to execute the steps of the method of the inventive subject matter, including for example, systems comprised of processing units and arithmetic-logic circuits coupled to computer memory, which systems have the capability of storing in computer memory, which computer memory includes electronic circuits configured to store data and program instructions, programmed steps of the method of the inventive subject matter for execution by a processing unit. The inventive subject matter also may be embodied in a computer program product, such as a diskette or other recording medium, for use with any suitable data processing system.


Embodiments of a computer program product may be implemented by use of any recording medium for machine-readable information, including magnetic media, optical media, or other suitable media. Persons skilled in the art will immediately recognize that any computer system having suitable programming means will be capable of executing the steps of the method of the inventive subject matter as embodied in a program product. Persons skilled in the art will recognize immediately that, although most of the exemplary embodiments described in this specification are oriented to software installed and executing on computer hardware, nevertheless, alternative embodiments implemented as firmware or as hardware are well within the scope of the present inventive subject matter.


DEFINITIONS

In this specification, the terms “field,” “data element,” and “attribute,” unless the context indicates otherwise, generally are used as synonyms, referring to individual elements of digital data. Aggregates of data elements are referred to as ‘1-ecords” or “data structures.” Definitions of complex data structures that include member methods, functions, or software routines in addition to data elements are referred to as “classes.” Instances of complex data structures are referred to as “objects” or “class objects.” Aggregates of records are referred to as “tables” or “files.” Aggregates of files are referred to as “databases.”


“Anchor element” refers to a markup language element that identifies and implements a ‘link’ or ‘web link’ or ‘hyperlink.’ Links are the basic hypertext construct, the central function of the web. A common example form of an anchor element is:

    • <a href=“\\SrvrX\DocY”>Press Here For Document Y</a>


      This example anchor element includes a start tag <a>, and end tag </a>, an href attribute that identifies the target of the link as a document named ‘DocY’ on a web 25 server named ‘SrvrX,’ and an anchor. The “anchor” is the display text that is set forth between the start tag and the end tag. That is, in this example, the anchor is the text “Press Here For Document Y.” In typical usage, the anchor is displayed in highlighting, underscored, inverse, specially colored, or some other fashion setting it apart from other screen text and identifying it as an available hyperlink. In addition, the screen display area of the anchor is sensitized to user interface operations such as GUI pointer operations such as mouse clicks. In typical operation, a user points to the anchor with a mouse pointer or other GUI pointer, clicks on the anchor to invoke the link, and the browser then retrieves and displays Document Y from server SrvrX. The “anchor element” is the entire markup from the start tag to the end tag.


“Browser” means a web browser, a software application for locating and displaying web pages. Browsers typically comprise a markup language interpreter, web page display routines, and an HTTP communications client. Typical browsers today can display text, graphics, audio and video. Browsers are operative in web-enabled devices, including wireless web-enabled devices. Browsers in wireless web-enabled devices often are downsized browsers called “microbrowsers.” Microbrowsers in wireless web-enabled devices often support markup languages other than HTML, including for example, WML and HDML.


CGI means “Common Gateway Interface,” a standard technology for data communications of resources between web servers and web clients. More specifically, CGI provides a standard interface between servers and server-side ‘gateway’ programs which administer actual reads and writes of data to and from files systems and databases. The CGI interface typically sends data to gateway programs through environment variables or as data to be read by the gateway programs through their standard inputs. Gateway programs typically return data through standard output. It is typically a gateway program that provides a MIME type in a return message header advising a server, and eventually therefore a browser or other communications client, of the type of data returned from CGI gateway programs.


A “data communications client” is any data communications software capable of performing network-based data communications, including email clients, browsers, and special purpose software systems. In typical embodiments of the present inventive subject matter, data communications clients run on “data communications devices,” which are any automated computing machinery capable of supporting data communications including web-enabled devices and handheld devices including telephones, web enabled personal digital assistants, laptop computers, handheld radios, and communicators.


An “embedded hyperlink” is a reference to a resource name or a resource network address that is embedded within another resource. Invoking the embedded hyperlink allows the named resource or resource network address to be accessed.


“HTML” stands for ‘HypterText Markup Language,’ a standard markup language for displaying web pages on browsers.


“HTTP” stands for ‘HyperText Transport Protocol,’ the standard data communications protocol of the World Wide Web.


A “hyperlink,” also referred to as “link” or “web link” is a reference to a resource name or network address which when invoked allows the named resource or network address to be accessed. Often the hyperlink identifies a network address at which is stored a web page. As used here, “hyperlink” is a broader term than “HTML anchor element.” Hyperlinks include links affected through anchors as well as URIs invoked through ‘back’ buttons on browsers, which do not involve anchors. Hyperlinks include URIs typed into address fields on browsers and invoked by a ‘Go’ button, also not involving anchors. In addition, although there is a natural tendency to think of hyperlinks as retrieving web pages, their use is broader than that. In fact, hyperlinks access “resources” generally available through hyperlinks including not only web pages but many other kinds of data and server-side script output as well.


“MIME” means Multipurpose Internet Mail Extensions. MIME is a standard that extends the format of Internet mail and other Internet documents to allow non-USASCII textual messages, non-textual messages, multipart message bodies, and non-US-ASCII information in message headers. MIME allows mail messages to contain multiple objects in a single document, text having unlimited line length or overall length, character sets other than ASCII (allowing non-English language document), multi-font documents, binary or application specific files, and images, audio, video and multi-media messages. MIME is originally an email standard, but it is used in web communications also. MIME is defined by an Internet standard document called “RFC1521.” The MIME standard is written to allow MIME to be extended in certain ways, without having to revise the standard. MIME specifies sets of values that are allowed for various fields and parameters. This provides a procedure for extending these sets of values by registering them with an entity called the Internet Assigned Numbers Authority (IANA).


MIME includes a header field called ‘content-type’ that describes the data contained in a MIME document so that communications clients such as email applications and browsers can pick an appropriate mechanism to present the data to the user, or otherwise deal with the data appropriately. The content-type header field is used to specify the nature of data in the body or body part, by giving type and subtype identifiers. The top-level content-type is used to declare the general type of data, while the subtype specifies a specific format for that type of data. Thus, a content-type of image/xyz is enough to tell a mail reader or a browser that the data is an image, even if the mail reader has no knowledge of the specific image format xyz.


In this specification, a MIME content-type is generally referred to as a “MIME type.” There are many MIME types. Here is an example listing of several representative MIME types in the standard form “top-level content-type/subtype” along with a description of the kind of data represented by each MIME type:













Mime Type
Description







text/html
HTML text data—RFC1866


text/plain
plain text documents, program listings


text/enriched
enriched text markup—RFC1896


image/gif
GIF image file


image/jpeg
JPEG image file


image/tiff
TIFF image file


audio/basic
“basic” audio, 8-bit u-law PCM


audio/x-wav
Microsoft audio


audio/z-mpeg
MPEG audio


video/mpeg
MPEG video


video/quicktime
Macintosh Quicktime video


application/postscript
PostScript file


application/zip
zip data compression archive


application/javascript
Javascript program


application/ms-word
Microsoft Word document


application/ms-powerpoint
Microsoft PowerPoint presentation


application/ms-excel
Microsoft Excel spreadsheet


multipart/mixed
document or message with multiparts









“Network” is used in this specification to mean any networked coupling for data communications among computers or computer systems. Examples of networks useful with the inventive subject matter include intranets, extranets, intranets, local area networks, wide area networks, and other network arrangements as will occur to those of skill in the art.


“Resource” means any aggregation of information administered over networks by various embodiments of the present inventive subject matter. Network communications protocols generally, for example, HTTP, transmit resources, not just files. A resource is an aggregation of information capable of being identified by a URI or URL. In fact, the ‘R’ in ‘URI’ is ‘Resource.’ The most common kind of resource is a file, but resources include dynamically-generated query results, the output of a CGI scripts, dynamic server pages, documents available in several languages, and so on. It may sometimes be useful to think of a resource as similar to a file, but more general in nature. Files as resources include web pages, graphic image files, video clip files, audio clip files, files of data having any MIME type, and so on. As a practical matter, most HTTP resources are currently either files or server-side script output. Server side script output includes output from CGI programs, Java servlets, Active Server Pages, Java Server Pages, and so on.


“Server” in this specification refers to a computer or device comprising automated computing machinery on a network that manages network resources. A “web server” in particular is a server that communicates with browsers by means of HTTP in order to manage and make available to networked computers markup language documents and digital objects.


A “target attribute” is an HTML attribute that can be set as an attribute an HTML anchor element. The general use of the target attribute is to specify the name of a frame where a linked resource (new document, file, web pa˜, or other resource) is to be opened. A more particular use of the target element is to cause a user agent, that is usually a browser of some kind, to open a linked resource in a new, unnamed window. This is accomplished in HTML, for example, simply by setting a target attribute value equal to ‘_blank’ in any anchor element. ‘_blank’ is a standard target value in HTML that instructs a browser of other user client to display the resource linked through the anchor in a new window or frame. That is, use of “target=_blank” as an anchor attribute that typically in practical operation is a way of displaying a linked resource in a new instance of a browser, cutting off navigation history of the user's current session and disabling the ‘Back’ button for the new instance of the browser.


A “URI” or “Universal Resource Identifier” is an identifier of a named object in any namespace accessible through a network. URIs are functional for any access scheme, including for example, the File Transfer Protocol or “FTP,” Gopher, and the web. A URI as used in typical embodiments of the present inventive subject matter usually includes an internet protocol address, or a domain name that resolves to an internet protocol address, identifying a location where a resource, particularly a web page, a CGI script, or a servlet, is located on a network, usually the Internet. URLs directed to particular resources, such as particular HTML files, JPEG files, or MPEG files, typically include a path name or file name locating and identifying a particular resource in a file system coupled to a network. To the extent that a particular resource, such as a CGI file or a servlet, is executable, for example to store or retrieve data, a URI often includes query parameters, or data to be stored, in the form of data encoded into the URI Such parameters or data to be stored are referred to as ‘URI encoded data.’


“URI encoded data” is data packaged in a URI for data communications. In the case of HTTP communications, the HTTP GET and POST functions are often used to transmit URI encoded data. In this context, it is useful to remember that URIs do more than merely request file transfers. URIs identify resource on servers. Such resource may be files having filenames, but the resources identified by URIs also include, for example, queries to databases. Results of such queries do not necessarily reside in files, but they are nevertheless data resources identified by URIs and identified by a search engine and query data that produce such resources. An example of URI encoded data is:

    • http://www.foo.com/cgi-bin/MyScript.cgi?field1=value1&field2=value2


This is an example of URI encoded data, which is how HTML forms typically are submitted over the web using HTTP GET request messages. This method using the GET message is useful when the amount of data to be encoded is fairly small. For larger amounts of data, it is more common to use HTTP POST messages for form submissions.


More specifically, the entire example above is a URI bearing encoded data, and the encoded data is the string “field1=value1&field2=value2.” The encoding method is to string field names and field values separated by, &’ and “=” with spaces represented by ‘+.’ There are no quote marks or spaces in the string. Having no quote marks, spaces are encoded with ‘+.’ For example, if an HTML form has a field called “name” set to “Lucy”, and a field called “neighbors” set to “Fred & Ethel”, the data string encoding the form would be:

    • name=Lucy&neighbors=Fred+%26+Ethel


“URLs” or “Universal Resource Locators” comprise a kind of subset of URIs, 10 wherein each URL resolves to a network address. That is, URIs and URLs are distinguished in that URIs identify named objects in namespaces, where the names may or may not resolve to addresses, while URLs do resolve to addresses. Although standards today are written on the basis of URIs, it is still common to such see web-related identifiers, of the kind used to associate web data locations with network addresses for data communications, referred to as “URLs.” In this specification, we refer to such identifiers generally as URIs.


“World Wide Web,” or more simply “the web,” refers to a system of internet protocol (“IP”) servers that support specially formatted documents, documents formatted in markup languages such as HTML, XML, WML, or HDML. The term “Web” is used in this specification also to refer to any server or connected group or interconnected groups of servers that implement the HyperText Transport Protocol, “HTTP,” in support of URIs and documents in markup languages, regardless whether such servers or groups of servers are coupled to the World Wide Web as such.


“XML” stands for ‘eXtensible Markup Language,’ a language that support user-defined markup including user-defined elements, tags, and attributes. XML's extensibility contrasts with most web-related markup languages, such as HTML, which are not extensible, but which instead use a standard defined set of elements, tags, and attributes. XML's extensibility makes it a good foundation for defining other languages. WML, the Wireless Markup Language, for example, is a markup language based on XML. Modern browsers and other communications clients tend to support markup languages other than HTML, including, for example, XML.


DETAILED DESCRIPTION

Turning to FIG. 1, a first exemplary embodiment of the present inventive subject matter is illustrated as a method for administration of URIs in groups. Embodiments of the kind illustrated typically include creating (208), in a group URI-enabled data communications client (226), a group URI (254) identifying a remote computer resource (232) accessible through a computer network (234). We use the term “remote computer resource” to refer to the aggregation of computer resources useful with various embodiments of the present inventive subject matter to store and retrieve from remote locations group URIs and member URIs. As depicted in FIG. 1, remote computer resources include data communications servers, web servers, database servers, databases, file systems, CGI scripts, Java Server Pages, Microsoft Active Server pages, or any other remote computer resource that will occur to those of skill in the art.


A group URI-enabled data communications client is a data communications client modified to administer group URIs and member URIs in accordance with the present inventive subject matter. Data communications clients are modified to administer group and member URIs in many ways, all within the scope of the present inventive subject matter. For example, a data communications client, such as a browser, in some embodiments, is altered at the source-code level, simply expanded and recompiled, to include computer software implementing a method of the present inventive subject matter. Such embodiments, altered in their own source code, are expected typically to include alternations to administer documents, files, and other resources in dependence upon a MIME type for group URIs.


In other embodiments of group URI-enabled data communications programs, a separate group URI application program is written in the source code of any computer language, such as C, C++, or Java. The separate group URI application program is then compiled and installed as a separate native executable on the same computer with a data communications client. Then a new MIME type, such as ‘application/groupURI,’ is registered with a data communications client such as a browser or email client, and is registered also upon the remote computer resource that stores and serves up the group URIs and member URIs. In this approach to developing a group URI-enabled data communications client, except for registering the new MIME type, the only change needed in the data communications client itself is to install a user interface control, such as a GUI toolbar button or a pull-down menu entry, to invoke the new application. Then the data communications client will invoke the separate group URI application program both upon request of a user and upon receiving from a server a document having a header MIME type entry of ‘application/groupURI.’


Another way to modify a data communication client to implement a method of the present inventive subject matter is with a plug-in. A “plug-in” is a hardware or software module that adds a specific feature or service to a larger system. For example, there are a number of plug-ins for the popular browsers and email clients such as Netscape Navigator, Microsoft Internet Explorer, and Microsoft Outlook, that enable such data communications clients to display different types of audio or video messages based on MIME types.


More particularly, in embodiments using plug-ins, a plug-in is written in the source code of any computer language, such as C, C++, or Java. The plug-in is then installed in a data communications client such as a browser, and a MIME type for group URIs is registered with, for example, the browser and is registered also upon the remote computer resource that stores and serves up the group URIs and member URIs. The plug-in, when invoked, accesses the user interface through the browser to install its own user controls such as GUI buttons, toolbars, pull down menus, and pull down menu entries. The data communications client invokes the separate group URI application program both upon request of a user, who invokes the plug-in through a user interface control, and upon receiving from a server a document having a header MIME type entry of ‘application/groupURI.’


Described just above are three ways to implement a group URI-enabled data communications client useful in various embodiments of the present inventive subject matter. Persons of skill in the art will think of other ways to implement such data communications clients, all of which are well within the scope of the present inventive subject matter.


Embodiments of the kind shown in FIG. 1 generally include creating (210), in response to at least one navigation event (288) invoking a hyperlink (291) to a document page (268) at a network location (233), a member URI (236) identifying the network location (233) of the document page (268). A navigation event is any interface event invoking a hyperlink, including, for example, invocation of a browser ‘back’ button, a ‘forward’ button, an anchor, or entry of a URL or URI in an address field of a browser.


The term “document page” is used to denote a file type broader than a web page. “Web page” denotes markup, hyperlinking documents such as HTML or XML documents served up through HTTP. Document pages of the present inventive subject matter include document that do not support markup, such as plain text, for example, and do not necessarily support hyperlinking, because a group URI is sometimes created, for example, through use of typed-in URIs or URLs rather than invoked anchors. In addition, document pages of the present inventive subject matter are often delivered by SMTP, POP, FTP, or some other protocol, not involving the web at all. Many document pages are web pages, of course, but not all of them. Although, the member URI (236) of the method of FIG. 1 identifies a network location of a document page, in various alternate embodiments, the member URI identifies any resource, such as web pages, graphic image files, video clip files, audio clip files, files of data having any MIME type, or any other resource that will occur to those of skill in the art.


Embodiments according to FIG. 1 typically include storing (238), together in the remote computer resource (232), the group URI (254) and the member URI (236). An example of a way to store a group URI and one or more member URIs (ordinarily there will be more than one member URI) is to transmit an HTTP POST request having a URI similar in form to the following, bearing encoded data:

    • http://www.foo.com/cgi-biniMyScript.cgi?[attach encoded data here]


And the encoded data in this example is a string of the form:

















groupURIname=MyGrpURI-1 &



mbrURI1 =http//www.google.com/&



mbrURI2=http/ /www.msnbc.com/&



mbrURI3=http//www.nsi.com/&



mbrURI376= http://www.ncsa.uiuc.edu/










The encoded data example is a single long string, broken into several lines in this example to make it a little easier to read. The example implicitly encodes 376 member URIs, but we omitted 372 of them for ease of illustration. This particular example is directed to the web, but it shows how easily a tremendous amount of network navigation can be encoded into a single group URI.


Turning now to FIG. 2, a further exemplary embodiment of the inventive subject matter is shown as including establishing (112) a remote storage URI (108) that identifies a remote computer resource (232). ill such embodiments, creating (208) a group URI (254) typically includes establishing (104) a group URI name (106) for the group URI, and concatenating (110) the group URI name (106) and the remote storage URI (108). In our present example:

    • http://www.foo.com/cgi-biniGuriScript.cgi?[attach encoded data here]


      the string “http://www.foo.com/cgi-biniMyScript.cgi” is a remote storage URI. This particular example of a remote storage URI identifies a resource CGI script accessible through an HTTP GET or POST request.


We have named an example CGI script twice, MyScript.cgi and GuriScript.cgi. Perhaps the names sound a little like the scripts are specially written for embodiments of the present inventive subject matter. They could be, but there is no such requirement in the scope of the present inventive subject matter. The remote data storage requirements of the present inventive subject matter in fact are handled in most embodiments by off-the-shelf, as it were, software technology for remote data access including for example, CGI scripts, Java servlets, Java Server Pages, and Active Server Pages.


In our current example, “MyGrpURI-1” is a group URI name. In some embodiments, establishing a group URI name involves automated name generation (102), as for example, through an algorithm and a random number generator. An example of such an algorithm is:


Step 1: generate a random number and convert it to text


Step 2: concatenate the text random number with the string “GURI”


Such a method would generate automated group URI names having the form:


GURI29384


GURI78120


GURI75890


GURI87654


And so on . . . .


Another way to establish a group URI name, for example, is to prompt a user to type in a name and receive the name as text through a user control (286), such as a data entry field, in a user interface (240). Hence a name similar to the one in our example, “MyGrpURI-1.” And in this example, a group URI formed by concatenating (110) a group URI name such as “MyGrpURI-1” and a remote storage URI such as “http://www.foo.com/cgi-biniGuriScript.cgi?” creates a group URI having the form:

    • http://www.foo.com/cgi-biniGuriScript.cgi?groupURIname=MyGrpURI-1


Turning to FIG. 3, a still further exemplary embodiment is shown in which a navigation event (288) invoking a hyperlink includes a requirement (289) to display the document page in a new instance of a data communications client. An example of a hyperlink including a requirement to display a document page in a new instance of a data communications client is an anchor element in an HTML document having a target attribute set to “_blank.” Embodiments according to FIG. 2 typically include storing (502) the group URI (254) and the member URI (236) in a memory storage location (504) in computer memory, in which the memory storage location (504) is accessible to a second instance (227) of the group URI-enabled data communications client.


There are many ways to implement a memory storage location (504) accessible to a second instance of a client. The first instance and the second instance in some embodiments mutually possess a shared memory segment with semaphore-controlled mutually exclusive access. In other embodiments, a memory storage location storage location (504) accessible to a second instance of a client is a predefined file system storage location on a magnetic disk or other form of non-volatile storage. In other embodiments, a memory storage location storage location (504) accessible to a second instance of a client is a predefined environment variable. The usefulness of the memory storage location storage location (504) accessible to a second instance of a client is to flag to the second instance that a group URI recording is underway, so that the second instance simply continues the recording unperturbed.


Exemplary embodiments of the kind shown in FIG. 3 typically include creating (210), in response to the navigation event (288), a second instance (227) of the group URI-enabled data communications client, and reading (506) from the memory storage location (504), in the second instance (227) of the group URI-enabled data communications client, at least the group URI (254), and, optionally, the member URI (236). In exemplary embodiments of the kind shown in FIG. 3, storing (238), together in the remote computer resource (232), the group URI (254) and the member URI (236) typically includes storing the member URI including only a URI from the hyperlink, whereby the member URI is stored in a condition that allows display of the document page in the group URI-enabled data communications client independent of any requirement to display the document page in a new instance of a data communications client. The usefulness of storing only a URI from the hyperlink as a member URI is to exclude any requirement for a second instance of the data communication client when the member URI is eventually played back to a disabled user, or any user, so that upon playback, no second instance of the data communications client is created, and any session history and ‘back’ button remain intact and functional. In the case of the anchor element target attribute “_blank,” in the HTML example, such an attribute is excluded from a member URI created from such an anchor element.


Next we turn to consider the example of a document page, set of document pages, or any other resource for inclusion as member URIs, that a user wishes to remain static. In the case of the web, many web pages change often. Web-based news service change daily or hourly. Commercial sites on the web change often. If a user wishes to freeze a web site for later playback in a group URI, the user must have a way to copy and store the present content of the site away from the manipulations of its content provider. Turning to FIG. 4, therefore, a still further exemplary embodiment of the present inventive subject matter is shown in which a document page (268) includes URIs (271) identifying digital objects (273), such as files or other resources, in a first storage location (908) for display in the document page (268). In embodiments of the kind illustrated in FIG. 4, storing (238) the member URI (236) typically includes storing (904) in a second location (902) in a file system (282) in the remote computer resource (232) the document page and all digital objects (273) identified by URIs (271) included within the document page (268), and changing (906) the member URI (236) identifying the network location of the document page so that the member URI identifies the second location (902) as the network location of the document page.


Take, for example, a web page at http://www.msnbc.com/. Such an example page contains many URIs identifying many other files for display within the page, including graphic image files, text files, and so on. A user sees upon the page a story interesting for later review, but the user knows that the page will change soon and the story will be gone. Modem browsers include the capability of saving of the files needed to display the page, including graphics, frames, style sheets, and so on, saving each referenced file in its original format, although such storage is static on the user's personal drive, not accessible by others, and not amenable to playback in sequence.


To gain the benefits of the present inventive subject matter, the user sets a flag made available through the user interface (240) advising a group URI-enabled data communications client to store the page itself and all its referenced contents as a member URI The group URI-enabled data communications client is programmed through, for example, a plug-in, to change the member URI so that it identifies a second network, for example, http://www.foo.com/msnbc/. as the network location of the document page formerly identified as http://www.msnbc.com/. Now the member URI can, at any time, even after the original has been changed, be played back in sequence in a group URI, retaining its original content, playback occurring from anywhere in the world through any group URI-enabled data communications client.


Next we turn to consider another exemplary method for administration of URIs in groups illustrated in the data flow diagram of FIG. 5. The method of FIG. 5 includes creating (474) a group URI (254). In many example embodiments of the method of FIG. 5, creating (209) a group URI (254) includes establishing a group URI name for the group URI, and concatenating the group URI name and a storage URI. In some example embodiments of the method of FIG. 5, the storage URI identifies a remote storage accessible across a network, while in other example embodiments, the storage URI identifies memory located on the computer on which the group URI enabled data communications client is installed.


In some embodiments of methods for administration of URIs in groups according to the present inventive subject matter, establishing a group URI name includes automated name generation. In other embodiments, establishing a group URI name includes prompting a user to enter a name and receiving the name as text through a user control such as a data entry field in a user interface.


The method of FIG. 5 includes receiving (482), from a user, a search term (484) and providing (486) the search term (484) to a search engine (488). In many examples of the method of the FIG. 5, receiving (482), from a user, a search term (484) includes receiving a search term from a user as text through a user control (286), such as a data entry field, in a user interface (240). In some examples of the method of FIG. 5, providing (486) the search term (484) to a search engine (488) includes transmitting an HTTP POST request bearing data encoding identifying the search term.


In an alternate embodiment of the method of FIG. 5, receiving (482), from a user, a search term includes receiving the search term as speech. In many examples of the method of FIG. 5, receiving the search term as speech is carried out by a group URI enabled data communications client, through for example, a plug-in designed for speech-to-text conversion. Web browsers supporting speech-to-text conversion are currently available. Home Page Reader™, available from IBM® is a currently available Web browser that supports speech-to-text conversion.


A “search engine” is a program or group of programs that returns, in response to a user's query of at least one keyword called a “search term,” a search result. The search result typically includes a list of indexed resources that the search engine identified as relevant to the search term. Many different kinds of search engines. Currently available search engines accessible with a Web browser include Yahoo.com, Google.com, Hotbot.com, Alta Vista.com, and many others that will occur to those of skill in the art.


The search result includes indexed resources. The indexed resources are resources for which a search engine maintains an index including the location of the resource and information describing the content of the resource. Search engines typically use programs called “spiders” or “crawlers” that search the Internet, identify the location of a resource, identify information about the content of the resource, and store the location of the resource, and the information about the content resource in the search engine's index. It is common to think of search engines as maintaining indexes of web pages, however, many search engines maintain indexes of resources such, as graphic image files, video clip files, audio clip files, and many other resources as will occur to those of skill in the art.


In response to the search term received from a user and provided to the search engine, typical search engines, such as the search engine of the method of FIG. 5, compare (490) the search term with the index (498) of indexed resources to identify indexed resources relevant to the search term. Various search engines use different proprietary 5 methods to compare the search terms with their index. Many search engines also rank the identified indexed resources to present a user with indexed resources the search engine determined most relevant. Various search engines use different proprietary methods to rank the identified indexed resources.


Once the search engine has identified at least one relevant indexed resource or that no relevant indexed resources exist, the search engine provides a search result to the user. Many typical search results include an HTML document containing embedded hyperlinks to the indexed resources and a summary of information about the resource.


The method of FIG. 5 includes receiving (472) a search result (271) including an embedded hyperlink (272) to an indexed resource (270). In many examples of the method of FIG. 5, the search result includes a list of indexed resources. In many examples of the method of FIG. 5, a search result (271) is an HTML document including embedded hyperlinks to indexed resources.


Disabled users of group URI-enabled data communication clients may have difficulty physically invoking a small GUI interface control or manipulating a mouse to direct a cursor to a sensitized location on a display screen to invoke an embedded hyperlink in a search result. Otherwise able-bodied users may also have similar difficulty invoking embedded hyperlinks in a search result when these able-bodied users are occupied, such as, for example, when using a group URI-enabled data communications client installed on a PDA while driving a car. The method of FIG. 5, therefore, includes identifying (476) the embedded hyperlink (272) within the search result (271) and creating (478), in dependence upon the embedded hyperlink (272), a member URI (237).


In some examples of the method of FIG. 5, an identifying an embedded hyperlink within an indexed resource includes identifying an HTML anchor element. An HTML anchor element refers to a markup language element that identifies and implements the embedded hyperlink. A common example form of an anchor element is:

    • <a href=“\\SrvrX\DocY”>Press Here For Document Y</a>


This exemplary anchor element includes a start tag <a>, and end tag </a>. The exemplary anchor element includes an href attribute that identifies the target of the link as a document named ‘Doc Y’ on a web server named ‘SrvrX.’ The exemplary anchor element also includes an anchor. The “anchor” is the display text that is set forth between the start tag and the end tag. That is, in this example, the anchor is the text “Press Here For Document Y.” In typical usage, the anchor is displayed in highlighting, underscored, inverse, specially colored, or some other fashion setting it apart from other screen text and identifying it as an available embedded hyperlink. The “anchor element” is the entire markup from the start tag to the end tag.


The method of FIG. 5 includes creating (478), in dependence upon the embedded hyperlink (272), a member URI (237). In many typical embodiments of the method of FIG. 5, creating (478), in dependence upon the embedded hyperlink (272), a member URI (237) includes establishing a member URI name for the member URI, and concatenating the member URI name with a URI identifying the location of the indexed resource (270). In some example embodiments, the URI identifying the location of the indexed resource is a remote storage accessible across a network, while in other example embodiments of the method of FIG. 5, the URI identifying the location of the indexed resource identifies memory located on the computer on which the group URI enabled data communications client is installed.


In some examples of the method of FIG. 5, the member URI name is created by automatic name generation using for example, a random number generator. In other examples of the method of FIG. 5, a user enters a member URI name through, for example, a user interface. An example of a member URI created by concatenating the member URI name and the URI identifying the resource is:

    • mbrURI2=http//news.ibm.com/


Typical search results (271) include a plurality of embedded hyperlinks to a plurality of indexed resources. Many typical embodiments of the method of FIG. 5, therefore, include identifying, within the search result, a plurality of embedded hyperlinks and creating, in dependence upon the plurality of embedded hyperlinks, a plurality of member URIs. By creating a group URI including a plurality of member URIs identifying the plurality of indexed resources, playback of the group URI allows disabled users to view the indexed resources identified in the search result without having to physically invoke a small QUI interface control or manipulate a mouse to direct a cursor to a sensitized location on a display screen to invoke an embedded hyperlink in a search result.


The method of FIG. 5 includes storing (480) the group URI (254) and the member URI (237). Many examples of the method of FIG. 5 include storing a plurality of member URIs with the group URI in a remote computer resource (232). In some examples of the method of FIG. 5 storing the group URI (254) and all member URIs (237) includes transmitting an HTTP POST request bearing encoding identifying the group URI, and the member URI. An example of an HTTP POT request is:

    • http://www.foo.com/cgi-bin/MyScript.cgi?[attach encoded data here]


And the encoded data in this example is a string of the form:














groupURIname=MyGrpURI-l&


mbrURIl=http//www.ibm.com/&


mbrURI2= http://www.ibm.com/products/us/ &


mbrURI3= http://www-l.ibm.com/services/ondemand/index_flash.html&


...










FIG. 6 is a data flow diagram illustrating an exemplary method of identifying (476) an embedded hyperlink (272) within the search result (271). In the method of FIG. 6, identifying (476) an embedded hyperlink (272) within the search result (271) comprises finding (752) a start tag (755) of an anchor element (754) and reading (756) a target (758) identifying the indexed resource (267). Again, a common example form of an anchor element is:

    • <a href=“\\SrvrX\DocY”>Press Here For Document Y</a>


In this example, the start tag is <a. In this example, ‘href’ identifies the target indexed resource, Document Y, and the target indexed resource's location, SrvX. Some examples of the method of FIG. 6 include using a text search to find the start tag <a, and reading the target identified by the ‘href.’



FIG. 6 also illustrates an exemplary method of storing (480) a group URI (254) and a member URI (237). In the method of FIG. 6, storing (480) the group URI (254) and the member URI (237) includes finding (762) the search term (484) in the indexed resource (270) and highlighting (764) the search term (484). Highlighting the search term in the indexed resource allows a user to quickly identify those search terms when the indexed resource is displayed during playback of the group URI. In one example of the method of FIG. 6, where the indexed resource is an HTML document, finding (762) the search term (484) includes using a text search to find the search term, and highlighting the search terms includes identifying the font markup associated with the search term and changing the color value of font markup. The following is an HTML example of a search term that is set apart as a single paragraph with accompanying markup identifying the font size of the search term as having a value of “2” and the color of the search term as black.

















<p>



<font size=“2” color=“black”>



search term



</font>



</p>










Highlighting the search term by changing the color value associated with the search, term from black to blue includes finding the font tag, <font, preceding the search term, and identifying the color value associated with the search term as black. Highlighting the search term includes changing the color value associated with the search term from black to blue by deleting the value “black” and writing the value “blue”.


In many typical embodiments of the method of FIG. 6, a group URI enabled data communications client will not have permission to highlight the search term in the indexed resource by writing to the indexed resource stored in its original location. In many embodiments, therefore, the method of FIG. 6 includes saving (760) the indexed resource (270). In some examples of the method of FIG. 6, saving the indexed resource includes saving the indexed resource, as well as all of the digital objects for display with the indexed resource Take, for example, a web page at http://www.ibm.com/. Such an example page contains many URIs identifying many other files for display within the page, including graphic image files, text files, and so on. Modern browsers include the capability of saving the files needed to display the page, including graphics, frames, style sheets, and so on, saving each referenced file in its original format.


In some example embodiments, saving the indexed resource includes saving the indexed resource to memory in the computer on which the group URI enabled data communications client is installed. In other example embodiments, saving the indexed resource includes saving the indexed resource to memory accessible across a network. When the indexed resource is saved to a new location, some exemplary embodiments of method for administering URIs in groups include changing the member URI. The member URI is changed to identify the new location of the indexed resource.


Turning now to FIG. 7, FIG. 7 is a data flow diagram illustrating a method for administering the playback of a group URI. The method of FIG. 7 includes retrieving (580), in dependence upon the group URI (254), a plurality of member URIs (237). Consider the example group URI described above:

    • http://www.foo.com/cgi-bin/GuriScript.cgi?groupURlname=MyGrpURI-1


Again considering case of HTTP, in typical embodiments, in order to retrieve member URIs, such a group URI is transmitted to a web server (284) in an HTTP GET request message. The web server passes the request through a CGI interface (292) to a CGI script named GuriScript.cgi. The CGI script named GuriScript.cgi is fashioned in this example to retrieve from a database (244) and concatenate into a data encoded URI string, all the member URIs associated with the group URI. In other words, the group URI represents a kind of database query and the CGI script carries out the query, encodes and returns the results of the query, including a header describing the MIME type of the response as, for example, “application/groupURI.” The web server returns the member URIs in data encoded format in an HTTP response message, including a header with the MIME type. The member URIs in data encoded format have the form described earlier:

















mbrURIl=http//www.google.com/&



mbrURI2=http//www.msnbc.com/&



mbrURI3=http//www.nsi.com/&



...



mbrURI376= http://www.ncsa.uiuc.edu/










Embodiments according to FIG. 7 typically include storing (582) the plurality of member URIs in data communications client navigation memory. When a typical example group URI-enabled data communications client of the present inventive subject matter receives an HTTP response message with a MIME type set to “application/groupURI” and a data encoded list of member URIs, the data communications client is programmed to extract the member URIs from the data encoding and insert them into normal navigation memory so that they appear to data communications client to have already been navigated. That is, in the case of a browser, for example, the member URIs now appear in the pull down listing under the ‘forward’ button. In the case of a browser, a user can now use the browser's ‘forward’ and ‘back’ buttons to navigate through the member URLs, just as if they had been navigated one-by-one by hand, and are therefore listed in the browsers ‘back’/‘forward’ navigation history.


The method of FIG. 7 includes retrieving (584) a plurality of indexed resources (270) identified by the plurality of member URIs (237) and displaying (586) the plurality retrieved resources (269). As described above indexed resources are resources indexed by a search engine. At least one of the member URIs of the group 15 URI was created in dependence upon an embedded hyperlink to the indexed resource in a search result. After the first resource identified by the first member URI in navigation memory is displayed, it is usual for embodiments of group URI enabled data communications clients to display the next resource identified by the next member URI in navigation memory in response to user manipulation of user controls in the user interface (240). That is, a user can now navigate the other member URIs in navigation memory by use of user controls in a user interface, including for example, a browser's ‘back’ and ‘forward’ buttons.


In the method of FIG. 7, displaying (588) the plurality retrieved resources (269) includes displaying (588) each indexed resource for a display interval length (406). In embodiments of the kind illustrated in FIG. 7, displaying resources identified by the member URIs stored in navigation memory includes repeatedly invoking the next member URI in sequence in navigation memory periodically at intervals having a display interval length (406). This is a kind of playback of the group URI, or rather, of the resources identified by the member URIs. In typical embodiments, the display interval length (406), and therefore the playback speed is set by a user through a user interface control, such as a data entry field in a user interface (240) and stored in computer memory, where it is changed by the user at will.


Readers will notice that many exemplary embodiments in this disclosure are described in terms of CGI, but that is for explanation, not for limitation. In fact, remote access to resources through use of URIs can be accomplished well within the scope of the present inventive subject matter by any remote access technology as will occur to those of skill in the art, including, for example, Java servlets.


In addition to other features described in this disclosure, many embodiments of the present inventive subject matter include emailing the group URI. Some examples of methods for administering URIs in groups include emailing the group URI in the form of plain text. More specifically, typical embodiments include a facility, such as a user interface control, for calling an email client and passing to it for inclusion in the body of an email message a group URI in text form. The advantages are these. Modem email clients support hyperlinks. In typical modem email clients, the group URL appears to be a normal hyperlink in a display of a normal email message. It will be displayed as such and will be invocable by a user. When a user receives the email message bearing the group URL and invokes it as a hyperlink, the email client will invoke an appropriate data communications client, such as, in the case of an HTTP hyperlink, a browser, and the browser will attempt to retrieve and display the resource identified by the group URI.


Remember, at this point in our example, the group URI appears to the browser to be a standard hyperlink. In fact, it is. It is not until the data encoded member URIs are returned in a response message with a MIME type that the browser can know it is dealing with anything other than a normal download of a web page. If the browser is not a group URI-enabled data communications client of the present inventive subject matter, then, upon receiving the response message, the browser will be confused. It will not know what to do with data encoded member URIs. If, however, the browser is a group URI-enabled data communications client of the present inventive subject matter, then, upon receiving the response message, the browser will proceed to extract URIs, place them in browser navigation memory, and invoke the first one in accordance with the present inventive subject matter. This illustrates one of the principal benefits of the present inventive subject matter: that users are effectively empowered to email a program of many, many URIs in an email message comprising only one group URI, typically a short single line of text comprised simply of a group URI name and a remote storage URI.


By way of further explanation, we turn to a further more particular exemplary embodiment in the form of a web browser with a plug-in, illustrated with the aid of FIG. 8. This example is described in terms of web browsers and email applications, HTML, HTTP, and email-oriented data communications protocols, although these details are for illustration and example only, not for limitation of the inventive subject matter. FIG. 8 illustrates a browser (714) of the present inventive subject matter, that is, in this example, a browser implemented by use of a plug-in as a group URI-enabled data communications client.


The browser of FIG. 8 has certain standard elements, including a title line (715), which typically says something like “Netscape Navigator,” “Microsoft Internet Explorer,” or “NCSA Mosaic.” In addition, the title line often may include a title from a header of a web page presently displayed in the main display area (724) of the browser. Standard browser elements include a horizontal pull down menu (716), although the menu entry “Group URI” is nonstandard, an element of an embodiment of the present inventive subject matter. Standard elements include a GUI toolbar (718) with a ‘back button’ (730), a ‘forward button’ (732), and buttons for refreshing the display, searching, printing, and send links or web pages in email. Standard browser features include also an address field and a ‘Go’ button to invoke a hyperlink typed into the address field (722).


Non-standard elements, that is, browser elements according to the present inventive subject matter include the GroupURL menu entry (726) mentioned above and a set of user controls implemented as GUI buttons in a group URI toolbar (720). Such user controls are implemented in various ways in various embodiments, including for example, as entries in a pull down menu or radio buttons in a dialog box. The group URI toolbar buttons include a Rewind button (705, a Fast Forward button (706), an Interval button (707), a Play button (708), a Stop button (710), a Record button (712), and an Email button (730). All such user controls when invoked result in calls to software routines in a browser plug-in for administration of group URIs.


Invoking the GroupURI menu entry (726) calls a software routine programmed to display a group URI pull down menu (701). The group URI pull down menu includes a ‘Group URI Toolbar’ entry (702), an ‘Edit A Group URI’ entry (703), and a half dozen group URI name entries (704). Invoking the Group URI Toolbar entry calls a software routine in the plug-in that displays the group URI toolbar (720). Invoking the Edit A Group URI entry (703) calls a software routine in the plug-in that downloads from remote storage the member URIs of a selected group URI, displays the member URIs in a GUI edit window (not shown), and accepts user edits in the member URIs, and the stores member URIs back into remote storage. In this way, users are empowered to make changes in previously recorded groups of member URIs without necessarily repeating an entire recording process.


The group URI name entries (704) display group URI names from group URIs presently known to the browser, that is, group URIs presently stored in computer memory accessible to the browser. Invoking a group URI name entry from the group URI pull down menu calls a software routine that displays the group URI toolbar (720). The group URI name in the group URI name entry identifies a group URI, which the plug-in uses to download from remote storage a group of member URIs. The plug-in then disposes the member URIs in browser navigation memory so that the browser's Forward button (732) is active and, when invoked, will step the user to the next member URI in navigation memory. The plug-in then retrieves and displays or otherwise renders the resource identified by the first member URI in browser navigation memory. At this point, all the member URIs in the group are disposed in the browser ready for a user to view as the user wishes.


The user is empowered to simply step through the member URIs by mouse clicking on the browser's standard Forward button (732). The user can use the browser's standard Back button (730) to step back to previously viewed member URIs. Or the user can set the display interval length to a value of the user's choice and invoke the Play (720) to instruct the plug-in to step through the member URIs at a pace corresponding to the display interval length. Invoking the IN button (707) calls a software routine in the browser plug-in that displays a data entry field, prompts the user for a display interval length, and stores the display interval length in browser memory. Invoking the Play button (708) calls a browser plug-in software routine programmed to step through the member URIs, displaying each in turn, but waiting for the display interval length between displays.


More particularly, consider the example of a disabled user who wishes to read a book. Such a user is empowered to download a chapter of the book with two mouse clicks, one on the GroupURI menu entry (726) and a second mouse click on a group URI name entry in the group URI pull down menu (704) entitled, for example, “Chap. 1 of Some Book.” If the user knows his reading speed is about a page a minute, we assume for purposes of example that the display interval length is already set to 60 seconds. The first page of the book is automatically downloaded and displayed by the plug-in as soon as the user makes the second mouse click on the group URI name entry. Now with only a third mouse click on the Play button (720), the user causes the pages of the chapter, encoded as member URIs, to be displayed in sequence at one minute intervals. Three mouse clicks, which of course can be implemented with a variety of prosthetics depending on the extent of disability, and the user then reads the chapter with no further physical motion. Some plug-ins in some embodiments reduce the number of mouse clicks required to only two by automatically invoking the Play button, or the software routine corresponding to the Play button any time a group URI name entry (704) is invoked from the group URI pull down menu (701) and the display interval length is set to any length other than zero.


Invoking the Stop button (710) interrupts the operation of the software routine called by invocation of the Play button (708). When the Stop button is invoked, the Back button and the Forward button (730, 732) have their normal operations, so that the user can step back a page or two if desired, and then again press the Play button to continue automatic repetitive navigation through the group of member URIs.


Invoking the Rewind button (705), when a group of member URIs is loaded in navigation memory, calls a software routine programmed to load and display the resource identified by the first member URI in navigation memory and dispose the other member URIs for sequential access through the Forward button (732). In this example, the Fast Forward button (706) sets the display interval length to zero and then repetitively invokes a series of member URIs in turn, that is, churns through the member URIs as fast as the browser can download and display the resources identified by them. That is how Rewind and Fast Forward work in this example. In other embodiments, Rewind sets the interval and steps through member URIs quickly, while Fast Forward zips to the end. In other embodiments they both reset the interval and step quickly through member URIs, Fast Forward going forward through the member URIs in navigation memory, Rewind in the other direction.


Invoking the Record button (712) calls a plug-in software routine that prompts the user to enter a group URI name, concatenates the group URI name to a remote storage URI to form a group URI, records as the first of the member URIs the URI of the web page presently displayed by the browser, and, in response to subsequent navigation events resulting from the user's navigating among web sites on the web, records other member URIs in browser memory. In response to a navigation event comprising invoking an anchor, the plug-in reads the HREF attribute of the anchor element containing the anchor and records it as a member URI In response to a navigation event comprising a user's entering a URI into the browser Address field and mouse clicking the Go button, the plug-in records the URI so entered as a member URI. In response to a navigation event comprising mouse clicking the Back button (730), the plug-in records as a member URI a corresponding URI from navigation memory. In response to a navigation event comprising mouse clicking the Forward button (732), the plug-in records as a member URI a corresponding URI from navigation memory.


During record, on invocation of the Save button (715), the plug-in concatenates the group URI and the member URIs into a data encoded URI and transmits the data encoded URI for remote storage using an HTTP POST request message. Invocation of the Static Storage button (713) calls a software routine that toggles a static storage flag in browser memory. While the flag is set, the operation of the record routine is to store remotely at a second location all files needed to display a web page identified by a member URI and change the member URI to point to the second location. While the flag is reset, the operation of the record routine is to store the original member URI only.


During record, the operation of the software routine called upon invocation of the Stop button is to stop the record routine. The user is then empowered to navigate the web for a while and the invoke Record (712) again to continue recording under the same group URI. Or the user can Save (715), the present URI and begin recording another. The group of member URIs so recorded can be Saved (715) and later Edited (703), or Edited (703) and later Saved (715), or both, which begins to show the reader some of the power and flexibility of embodiments of the present inventive subject matter.


Invoking the Email button (730) calls a plug-in software routine that reads from browser memory a selected member URI, calls an email application, such as Microsoft Outlook, and passes the member URI to the email application as message body text. In this example, a user selects a member URI by selecting its member URI name (704) from the pull down menu (701). Then the plugin, when the Email button is invoked, identifies the group URI in browser memory by matching it with the selected group URI name and passes the group URI so identified to the email application. Other embodiments prompt the user for a group URI name when the Email button in invoked. Persons of skill in the art will think other ways to select a particular group URI for passing to an email application, and all such ways are well within the scope of the present inventive subject matter.


It will be understood from the foregoing description that various modifications and changes are made and will be made in the exemplary embodiments of the present inventive subject matter without departing from its true spirit. The descriptions in this specification are for purposes of illustration only and are not to be construed in a limiting sense. The scope of the present inventive subject matter is limited only by the language of the following claims.

Claims
  • 1. A method comprising: receiving a message with an encoding of a group universal resource identifier that identifies a resource group and of a plurality of member universal resource identifiers for a plurality of resources that constitute the resource group, wherein said receiving is subsequent to requesting the resource group with the group universal resource identifier;for each of the plurality of member universal resource identifiers in an order designated by the message, extracting the member universal resource identifier, wherein the member universal resource identifier comprises a member resource name and a universal resource identifier that identifies a corresponding one of the plurality of resources; andinserting the member universal resource identifier into navigation history of a web browser, wherein the member universal resource identifier is inserted into the navigation history in accordance with the order.
  • 2. The method of claim 1 further comprising detecting in a header of the message an indication of Multipurpose Internet Mail Extension type as group universal resource identifier, wherein said extracting and said inserting are responsive to said detecting.
  • 3. The method of claim 1, wherein the plurality of resources comprises web pages.
  • 4. The method of claim 3, wherein each of the web pages comprises at least one of a graphic image, an audio file, a video file, text, output of an executed script, a dynamically generated query result, and a dynamic server page.
  • 5. The method of claim 1 further comprising presenting, via the web browser, a first of the plurality of resources identified by a first of the plurality of member universal resource identifiers that occurs first in the navigation history.
  • 6. The method of claim 5 further comprising successively presenting, via the web browser, the other ones of the plurality of resources identified by the subsequent ones of the plurality of member universal resource identifiers in accordance with the order as inserted into the navigation history of the web browser, wherein each of the plurality of resources is presented for a given time interval.
  • 7. The method of claim 1 further comprising: generating a request message that requests the group resource, wherein the request message indicates the group universal resource identifier.
  • 8. A computer program product for resource group administration, the computer program product comprising: a computer readable recording medium having computer usable program code embodied therewith, the computer usable program code comprising a computer usable program code configured to:determine that a header of a message indicates a data type as group universal resource identifier and that the message indicates a group universal resource identifier that identifies a resource group;query a database of group universal resource identifiers with the group universal resource identifier;responsive to the query, obtain a plurality of member universal resource identifiers that identifies a plurality of resources that constitutes the resource group; andcreate a response message that indicates the group universal resource identifier and the plurality of member resource identifiers in an order defined for the resource group.
  • 9. The computer program product of claim 8, wherein the computer usable program code configured to query the database with the group universal resource identifier comprises the computer usable program code configured to submit the group universal resource identifier to a script interface along with a script identified in the message.
  • 10. The computer program product of claim 9, wherein the message comprises a script execution request with a universal resource identifier data encoding that comprises the group universal resource identifier.
  • 11. The computer program product of claim 8, wherein the plurality of member resource identifiers are stored in the database in accordance with the order defined for the resource group.
  • 12. The computer program product of claim 8, wherein each of the plurality of member universal resource identifiers comprises a member name and a universal resource identifier that identifies a corresponding one of the plurality of resources.
  • 13. The computer program product of claim 12, wherein the member name for each of the plurality of member universal resource identifiers represents a place in the order in the resource group for the corresponding resource of the plurality of resources.
  • 14. The computer program product of claim 8, wherein the computer usable program code configured to create the response message that indicates the group universal resource identifier and the plurality of member resource identifiers in an order defined for the resource group comprises the computer usable program code configured to: write the group URI into the message; andsuccessively append each of the plurality of member resource identifiers in accordance with the order of the resource group.
  • 15. A computer program product for resource group administration, the computer program product comprising: a computer readable recording medium having computer usable program code embodied therewith, the computer usable program code comprising a computer usable program code configured to:create a request message for a resource group, the request message created with a group universal resource identifier that identifies the resource group;receive a response message with an encoding of the group universal resource identifier and of a plurality of member universal resource identifiers for a plurality of resources that constitute the resource group;for each of the plurality of member universal resource identifiers in an order designated by the response message, extract the member universal resource identifier, wherein the member universal resource identifier comprises a member resource name and a universal resource identifier that identifies a corresponding one of the plurality of resources; andinsert the member universal resource identifier into navigation history of a web browser, wherein the computer useable program code is configured to insert the member universal resource identifier in accordance with the order.
  • 16. The computer program product of claim 15, wherein the computer usable program code is further configured to detect in a header of the response message an indication of Multipurpose Internet Mail Extension type as group universal resource identifier, wherein the computer usable program code is configured to extract and insert responsive to detecting.
  • 17. An apparatus comprising: a processing unit; anda computer-readable recording medium having computer usable program code embodied therewith, the computer usable program code comprising a computer usable program code configured to:create a request message for a resource group, the request message created with a group universal resource identifier that identifies the resource group;receive a response message with an encoding of the group universal resource identifier and of a plurality of member universal resource identifiers for a plurality of resources that constitute the resource group;for each of the plurality of member universal resource identifiers in an order designated by the response message, extract the member universal resource identifier, wherein the member universal resource identifier comprises a member resource name and a universal resource identifier that identifies a corresponding one of the plurality of resources; andinsert the member universal resource identifier into navigation history of a web browser, wherein the computer useable program code is configured to insert the member universal resource identifier in accordance with the order.
  • 18. The apparatus of claim 17, wherein the computer usable program code is further configured to detect in a header of the response message an indication of Multipurpose Internet Mail Extension type as group universal resource identifier, wherein the computer usable program code is configured to extract and insert responsive to detecting.
  • 19. The apparatus of claim 17, wherein the plurality of resources comprises web pages.
  • 20. The apparatus of claim 19, wherein each of the web pages comprises at least one of a graphic image, an audio file, a video file, text, output of an executed script, a dynamically generated query result, and a dynamic server page.
  • 21. The apparatus of claim 17, wherein the computer usable program code is further configured to present, via the web browser, a first of the plurality of resources identified by a first of the plurality of member universal resource identifiers that occurs first in the navigation history.
  • 22. The apparatus of claim 21, wherein the computer usable program code is further configured to successively present, via the web browser, the other ones of the plurality of resources identified by the subsequent ones of the plurality of member universal resource identifiers in accordance with the order as inserted into the navigation history of the web browser, wherein each of the plurality of resources is presented for a given time interval.
Divisions (1)
Number Date Country
Parent 10388975 Mar 2003 US
Child 13295986 US