1. Field of the Invention
The present invention relates to applications such as web-based applications (software systems) which are intended to be executed and manifested within a network client such as within a world wide web (WWW) browser environment.
2. Description of the Related Art
Network clients such as world wide web (WWW) enabled browsers are well known. In fact, browsers have become so widely used, that millions of people rely on the same to carry out their normal affairs. For example, consumers can now access the Internet to make travel arrangements, buy household items, and even trade securities such as stocks and bonds online. Also, users within organizations can access company web sites via internal networks commonly referred to as “intranets” to learn about company events, complete expense reports, exchange project information, etc. As a result, the browser has become almost a staple part of the way people use their computers to generate and receive information.
Although the browser network client, as a tool, has become very powerful and popular in terms of its inherent ability access server systems to receive content therefrom, the browser still remains limited in the functionality it can provide or allow. That is, browsers are designed to access remote server systems (computers) and receive content therefrom instead of providing stand-alone functionality. In other words, although capable of loading files and processing the same from local storage facilitates, they are targeted at accessing remote systems, receiving rich content, and providing a “current” web site experience. To date, browsers have not been utilized as general interfaces to facilitate general computing functionality that has traditionally been provided by stand-alone native applications and executable programs (e.g., form filling applications, etc.).
The aforementioned comments are not to be taken to indicate that developers have not created feature rich applications to operate within browser environments. To the contrary, many developers have created elaborate applications written as JAVA applications or “applets,” for example, and have distributed the same for execution within a browser network client. Typically, however, such applets are executed within a processing space (e.g., within a window) inside of a browser environment to deliver a particular feature set. Unfortunately, such applets are also intended to be distributed from a server system via a network connection and merely form part of a larger web site environment which usually includes content of various types including, but not limited to, hyper-text content (i.e., hyper-text markup language (HTML) content), images, sound files, JAVA, JAVA Script, etc.
Despite the inherent ability of a browser to access server systems and receive and manifest feature rich content (e.g., such as that provided via JAVA, etc.), browsers continue to remain under-utilized. Such under-utilization also is due, in large part, to the fact that there is no current, effective and efficient way to package content and distribute the same via network connection, physical passage (e.g., via computer-readable media such as compact discs, etc.). There is no current way for developers to package all content that may be related to a particular web-based application (e.g., one that would normally be served to a browser from a remote server system in the context of a web site, for example) and to distribute the same in an effective and efficient manner. For example, many people utilize open-standards based tools (e.g., HTML, etc.) to produce presentations, documentation sets, etc. which often include whole collections of files, images, etc. Save for successfully storing all such files in a commonly accessible directory, there is no way for a person to package all such files and make the same available or distribute such a package to client systems equipped with browsers. As such, there is no current way for a complete web-based application to be packaged for automatic processing within a browser environment and without the need for server (URL) distribution.
To address the aforementioned problems, developers have proposed several solutions which have not heretofore effectively allowed people to encapsulate complete web-based applications such as web sites. For example, many developers have developed file archiving formats to produce archive files containing all files related to a particular web application. Unfortunately, such currently available archiving schemes are not directed to the needs of a web-based application; that is, they are not directed to including the actual content necessary for a browser to render or layout web based data—e.g., HTML, etc. Moreover, such archiving schemes are not suited to produce auto-executable or auto-processable files within a browser environment—for example, there is no way to identify a starting file to cause a browser to instantly and automatically load and render a web-based application. And, despite their ability to encapsulate files, such currently available archiving schemes have no ability to provide a stand-alone file that may reside next to a native application and which may be treated within an operating environment as one in the same.
Thus, there exists a need to allow web based application (e.g., those normally associated with a WWW site, etc.) to be encapsulated within a standard file structure, distributed via any form of data distribution, and which may be automatically executed within a browser environment without having to cause to the browser environment to access a remote server system for files forming part of the web based application. Accordingly, there exists a need to provide new and improved systems and methods for encapsulating a web-based application into an open-standards based file format and structure which may be processed by a correspondingly equipped network client or web browser. To be viable, such a system and method of encapsulation must be easy to use.
The present invention solves the aforementioned problems and, in so doing, provides certain benefits not heretofore realized with other network clients and software packaging schemes. In particular, the present invention provides a software component packaging scheme and corresponding network client that facilitates the receipt and processing of self-contained software systems (e.g., web sites, web-based applications, etc.) without requiring network access, etc. The present invention will allow developers and users to package whole collections of open-standards based content (e.g., all content associated with a web site, etc.) and to distribute the same to users who may access the same as though they were native, executable applications. Accordingly, the present invention extends the functionality of current-day web browsers beyond that of network content access tool to allow the same to be considered as application processing environments capable of rich content manifestation, etc. Developers can utilize the present invention to deliver applications based on open-standards without having to be concerned with screen layout, content rendering, and other infrastructure issues which normally must be dealt with when developing stand-alone, native applications. Users will benefit from the present invention by becoming accustomed to a standard application processing environment in which many, if not all, of their applications are executed and run. And, users who are not otherwise connected or coupled to a network server (e.g., users of disconnected laptop computers, etc.) can now receive whole web-based applications and run the same like native applications without having to login into or access a remote server system.
The present invention solves the aforementioned problems and provides the above-described benefits by providing new and improved systems and methods for producing and processing self-contained software systems. In particular the present invention provides a self-contained software package that is adapted to be automatically processed within a browser environment. The self-contained software package includes, but is not limited to, a manifest containing meta-data about the self-contained software package, and at least one reference to an initial content source. The initial content source includes instructions related to a particular intended functionality such as that corresponding to a web site, open-standards application, etc. The manifest and reference(s) to the initial content source are adapted to be automatically received by and processed within a network client environment (e.g., within a world wide web—WWW browser). The initial content source is configured to control the network client environment in accordance with the instructions to achieve the intended functionality.
According to another aspect of the present invention, provided is a web browser adapted to receive and process a self-contained software package. The web browser includes an input module for inputting a manifest containing meta-data about the self-contained software package, and at least one reference to an initial content source. The initial content source includes instructions related to a particular intended functionality such as that provided at or by a web site or by a web based/open standards application, etc. The manifest and reference(s) to the initial content source are automatically received by and processed within the web browser. The initial content source controls the web browser in accordance with the instructions to achieve the particular intended functionality.
According to another aspect of the present invention, provided is a method for generating and automatically processing a self-contained software package within a web browser environment. The method includes the steps of generating a manifest containing meta-data about the self-contained software package, generating at least one reference to an initial content source that includes instructions related to a particular intended functionality, automatically receiving the manifest, the reference(s), and the initial content source, and automatically processing the manifest, the reference(s), and the initial content source within the browser environment. The initial content source controls the browser environment in accordance with the instructions to achieve the particular intended functionality.
According to another aspect of the present invention, provided is a method of using a web browser that includes the steps of receiving a manifest containing meta-data about a self-contained software package, receiving at least one reference to an initial content source that further includes instructions related to a particular intended functionality, and automatically processing the manifest, the reference(s), and the initial content source within a web browser environment. The initial content source controls the browser environment in accordance with the instructions to achieve the particular intended functionality.
The present invention is discussed in detail below with regard to the drawing figures attached hereto, of which:
The present invention is now discussed in detail with regard to the drawing figures that were briefly described above. Unless otherwise indicated, like parts and processes are referred to with like reference numerals.
Referring now to
It should be noted that there is no requirement that ISP 108 be present in the context of the present invention. For example, if network 104 is an Intranet or other private/self-contained network, there is no need to provide for network access to outside users, etc. that may otherwise be remotely connected to network resources and who may require dial-up connections, etc.
In system 100, a software distributor 110 is shown as being coupled to client system 108 via a dashed line. The dashed line in system 100 is meant to indicate that the coupling thereof may be an electronic data communications coupling, or one that allows a client system owner and/operator to acquire an executable, encapsulated software application (e.g., web-based application, etc.) in accordance with the present invention such as via other means such as through retail channels, etc.
Referring now to
In regard to
The creation of an .XJR file in accordance with the present invention will be similar to the creation of .JAR type files and archives as is well known in the art. It is the present invention's addition of initial content identifiers, etc. (e.g., the inclusion of an initial content source like or similar to an initial HTML file) that allows .XJR files to be created and processed by a browser (web browser, etc.) that is equipped to handle and process the same.
Referring now to
Accordingly, with reference to
Referring now to
The systems illustrated in
At step S6-2, a self-contained software package in the form of an .XJR file as discussed above with regard to
Next, at step S6-3, if not already done so within a processing environment such as within an operating system (e.g., within the MICROSOFT WINDOWS 95™ or 98™ operating system environments, etc.), a browser or other network client may be spawned and loaded with the self-contained software package (i.e., the .XJR file as already received at step S6-2). The browser environment will then proceed to access the manifest file (e.g., manifest file 400 as depicted in
Next, processing proceeds to step S6-4 where the browser environment accesses an extracts objects from the .XJR file and executes accordingly as discussed above based upon instructions contained within content thereof etc.
Processing ends at step S6-5.
Based on the forgoing discussion, the present invention will allow an entire web application to be packaged as a modern equivalent of an .EXE (executable) file. With the use of an .XJR type file, as provided by the present invention, a browser environment may be spawned and caused to open and access content within a manifest file and an associated archive containing web site, web applications, etc. and other content for display and manifestation by the web browser. Alternatively, one could associate .XJR files in a WINDOWS type desktop so that they can automatically launch a browser upon instantiation thereof (e.g., via double clicking on an .XJR file icon in accordance with the present invention). Accordingly, applications may be built to run in a browser environment so that they can compete more directly with native machine applications, thus enhancing a browser platform configured and equipped in accordance with the present invention. Accordingly, a browser environment may now be caused to become more of a staple tool much like a word processor, spreadsheet, etc.
Furthermore, because an .XJR file according to the present invention bears the same file structure as a .JAR type file as will be readily understood by those skilled in the art, the same may be signed, thus establishing security credentials quickly and easily across all files within an .XJR file with a single signature thus greatly streamlining the need to sign individual scripts, and other components contained therein.
As a result, the present invention makes a browser type environment a more powerful place to deploy more powerful web applications, such as those built with Visual JAVAscript, etc.
Thus, having fully described the present invention by way of example with reference to the attached drawings figures, it will be readily appreciated that many changes and modifications may be made to the invention and to any of the exemplary embodiments shown and/or described herein without departing from the spirit or scope of the invention, which is defined in the appended claims.
Number | Name | Date | Kind |
---|---|---|---|
5617526 | Oran et al. | Apr 1997 | A |
5727156 | Herr-Hoyman et al. | Mar 1998 | A |
5790793 | Higley | Aug 1998 | A |
5799285 | Klingman | Aug 1998 | A |
5805804 | Laursen et al. | Sep 1998 | A |
5870559 | Leshem et al. | Feb 1999 | A |
5870767 | Kraft, IV | Feb 1999 | A |
5877766 | Bates et al. | Mar 1999 | A |
5893127 | Tyan et al. | Apr 1999 | A |
5905248 | Russell et al. | May 1999 | A |
5913215 | Rubinstein et al. | Jun 1999 | A |
5944783 | Nieten | Aug 1999 | A |
5946464 | Kito et al. | Aug 1999 | A |
5964836 | Rowe et al. | Oct 1999 | A |
5968116 | Day, II et al. | Oct 1999 | A |
5974441 | Rogers et al. | Oct 1999 | A |
5974454 | Apfel et al. | Oct 1999 | A |
5983233 | Potonniee | Nov 1999 | A |
5999940 | Ranger | Dec 1999 | A |
6009456 | Frew et al. | Dec 1999 | A |
6029175 | Chow et al. | Feb 2000 | A |
6041342 | Yamaguchi | Mar 2000 | A |
6047323 | Krause | Apr 2000 | A |
6049819 | Buckle et al. | Apr 2000 | A |
6052531 | Waldin et al. | Apr 2000 | A |
6065024 | Renshaw | May 2000 | A |
6092178 | Jindal et al. | Jul 2000 | A |
6112023 | Dave et al. | Aug 2000 | A |
6115040 | Bladow et al. | Sep 2000 | A |
6202207 | Donohue | Mar 2001 | B1 |
6216212 | Challenger et al. | Apr 2001 | B1 |
6314565 | Kenner et al. | Nov 2001 | B1 |
6347398 | Parthasarathy et al. | Feb 2002 | B1 |
6351816 | Mueller et al. | Feb 2002 | B1 |
6385643 | Jacobs et al. | May 2002 | B1 |
6397220 | Deisinger et al. | May 2002 | B1 |
6430739 | Ballard | Aug 2002 | B1 |
6587836 | Ahlberg et al. | Jul 2003 | B1 |
6623527 | Hamzy | Sep 2003 | B1 |
6839733 | Lange et al. | Jan 2005 | B1 |
20010029605 | Forbes et al. | Oct 2001 | A1 |