CA2292327C - Systems, methods and computer program products for dynamic placement of web content tailoring - Google Patents
Systems, methods and computer program products for dynamic placement of web content tailoring Download PDFInfo
- Publication number
- CA2292327C CA2292327C CA002292327A CA2292327A CA2292327C CA 2292327 C CA2292327 C CA 2292327C CA 002292327 A CA002292327 A CA 002292327A CA 2292327 A CA2292327 A CA 2292327A CA 2292327 C CA2292327 C CA 2292327C
- Authority
- CA
- Canada
- Prior art keywords
- data processing
- processing system
- tailoring
- content
- computer
- Prior art date
- Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
- Expired - Fee Related
Links
Classifications
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F15/00—Digital computers in general; Data processing equipment in general
- G06F15/16—Combinations of two or more digital computers each having at least an arithmetic unit, a program unit and a register, e.g. for a simultaneous processing of several programs
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F16/00—Information retrieval; Database structures therefor; File system structures therefor
- G06F16/90—Details of database functions independent of the retrieved data types
- G06F16/95—Retrieval from the web
- G06F16/957—Browsing optimisation, e.g. caching or content distillation
- G06F16/9577—Optimising the visualization of content, e.g. distillation of HTML documents
Abstract
Methods, systems and computer program products are provided for tailoring content for a session of a first data processing system communicating with a second data processing system by obtaining session specific information from the first data processing system and distributing tailoring functions between the first data processing system and the second data processing systems based upon the obtained session specific information. In particular, policies which control the distribution of tailoring functions between data processing systems based on session specific information may be obtained from a repository and tailoring functions distributed between the first data processing system and the second data processing system according to the obtained policies and the session specific information.
Description
SYSTEMS, METHODS AND COMPUTER PROGRAM PRODUCTS FOR DYNAMIC
PLACEMENT OF WEB CONTENT TAILORING
Field of the Invention The present invention relates generally to web content and, more particularly, to the transfer and presentation of web content among data processing systems.
Background of the Invention The Internet is a worldwide decentralized network of computers having the ability to communicate with each other. The Internet has gained broad recognition as a viable medium for communicating and interacting across multiple networks. The World Wide Web (Web) was created in the early 1990's, and is composed of server-hosting computers (web servers) connected to the 1o Internet that have hypertext documents or web pages stored therewithin. Web pages are accessible by client programs (i.e., web browsers) utilizing the Hypertext Transfer Protocol (HTTP) via a Transmission Control Protocol/Internet Protocol (TCP/IP) connection between a client-hosting device and a server-hosting device.
An intranet is a private computer network conventionally contained within an enterprise and that conventionally includes one or more servers in communication with multiple user computers.
An intranet may be composed of interlinked local area networks and may also use leased lines in a wide-area network. An intranet may or may not include connections to the outside Internet. Intranets conventionally utilize various Internet protocols and, in general, often look like private versions of the Internet. An intranet user conventionally accesses an intranet server via a web browser running locally on his/her computer.
Exemplary web browsers for both Internet and intranet use include Netscape Navigator (Netscape Communications Corporation, Mountain View, CA) and Internet Explorer (Microsoft Corporation, Redmond, WA). Web browsers typically provide a graphical user interface for retrieving and viewing information, applications and other resources hosted by Internet/intranet servers (hereinafter collectively referred to as "web servers" or "web sites").
Web content including, but not limited to, information, applications, applets and other video and audio resources (collectively referred to herein as "files") are conventionally delivered from a web server to a web browser on a user's computer in the form of web pages. As is known to those skilled in this art, a web page is conventionally formatted via a standard page description language such as HyperText Markup Language (HTML) or Extensible Markup Language (XML), and typically.displays text and graphics, and can play sound, animation, and video data. HTML and XML
provide basic document formatting and allow a web content provider to specify hypertext links (typically manifested as highlighted text) to other servers and files. When a user selects a particular hypertext link, a web browser reads and interprets the address, called a Uniform Resource Locator (URL) associated with the link, connects the web browser with the web server at that address, and makes an HTTP request for the file identified in the link. The web server then sends the requested file to the client in the format of the requested file (e.g. HTML, XML, GIF, JPEG, etc) which the browser interprets and displays to the user.
With the increasing mobility of today's society, the demand for mobile computing capabilities has also increased. Many workers and professionals are downsizing their laptop computers to smaller palm-top or hand-held devices, such as personal digital assistants (PDAs). In addition, many people now utilize cellular telephones to access the Internet and to perform various other computing functions. Hand-held computing devices including, but not limited to, PDAs, cellular telephones, and computing devices utilized within appliances and automobiles, are often collectively referred to as "pervasive" computing devices. Many hand-held computing devices utilize the Microsoft Windows CE and 3Com Palm Computing platforms as well as web browsers such as HandWeb from SmartCode, Inc. and the Pocket Internet Explorer from Microsoft, Inc.
Unfortunately, hand-held computing devices may have limited functionality in comparison to desktop computers for which much web content has been developed. For example, hand-held devices may be voice only, may have limited processing capabilities, limited memory, black and white displays or may have displays that are small in size compared with desktop computer displays.
As a result, images and text otherwise displayable on a desktop computer display may not be displayable on a hand-held computing device display or may be impractical or otherwise undesirable to display on a hand-held computing device. For example, a desktop computer display having an array of 1024 pixels by 768 pixels may be able to display a large (e.g., 2 megabit), 24 bit per pixel image. A hand-held computing device with a display having an array of 120 pixels by 120 pixels and with the ability to display only a few bits per pixel, may ignore much of the image data. As a result the image may not be displayed properly, if at all, via the hand-held computing device display.
Furthermore, text within a file may have a particular font or size that can hinder the display thereof within a hand-held computing.device display.
Files that may not be displayable via a hand-held computing device display can typically be transformed into a format that is displayable within a hand-held computing device display. For example, large, high resolution, color images can be transformed into small, black and white images 1 o that can be displayed within small, low resolution displays. Furthermore, because some web servers can recognize the type of client device requesting a file, files in the proper format for display via the requesting client device can be provided.
Furthermore, these pervasive computing devices may be connected to a network, such as the Internet or an intranet, through different communication methods. For example, the same pervasive computing device may be connected to a network via a direct Local Area Network (LAN) connection such as through a network interface card (NIC) during one session and then in a subsequent session be connected over a wireless communication link, such as over a cellular telephone. These differing connection methods may have substantially differing properties which may impact on the form of content provided to the pervasive computing device. Thus, the LAN connection provide low cost 2o and short delays for acquiring and rendering information while the wireless communication link may be at a higher cost with longer delays. Thus, a form of content which may be acceptable for the LAN
connection may be unacceptable for the wireless communication link.
Similarly, other performance issues, which may change from session to session or during a session, may also impact on the transformation or "tailoring" of content for pervasive computing devices. Thus, for example, the expected duration of the connection, congestion on the communication link or network or the content provided to the pervasive computing device may all impact on the type of tailoring of content to be performed.
Conventionally, this tailoring of content has been performed either at the server providing the content to the pervasive computing device or at the pervasive computing device. See for example, ProxiWeb browser and proxy from Proxinet, Inc., and U.S. Patent No.
5,764,235.
However, such an arbitrary allocation of tailoring functions may result in performance degradation to the server, the pervasive computing device or the network through which these devices communicate. Thus, a need exists for improvements in the tailoring of content for pervasive computing devices to better exploit the resources available to such devices.
Summary of the Invention In view of the above discussion, it is an object of the present invention to provide improved tailoring of content for data processing systems, such as pervasive computing devices.
1o A further object of the present invention is to provide for the improved tailoring of content without requiring modification of existing browsers or servers.
Still another object of the present invention is to provide content tailoring without requiring user intervention in each instance.
These and other objects of the present invention are provided by methods, systems and computer program products for tailoring content for a session (i.e. a period of t ime where the operating environment of a data processing is not expected to change ) of a first data processing system (such as a client) communicating with a second data processing system (such as a server or proxy) by obtaining session specific information from the first data processing system and distributing tailoring functions between the first data processing system 2o and the second data processing system based upon the obtained session specific information. In particular, policies which control the distribution of tailoring functions between data processing systems based on session specific information may be obtained from a repository and tailoring functions distributed between the first data processing system and the second data processing system according to the obtained policies and the session specific information.
An ability to modify the location of content tailoring dynamically allows for the ability to respond to changes in server availability, network conditions, connection types, information presentation characteristics, device types, user preferences and organizational policies. By distributing the tailoring of content provided to a data processing system, such as a pervasive computing device, based on session specific information, the location of the content tailoring may be established based on particular characteristics of a session. The location of content tailoring may be determined to take advantage of the characteristics of a session to provide improvement in the tailoring of content. By basing the distribution of the content tailoring functions on session specific information and established policies, both the concerns of a particular user as well as the overall concerns of network management may be taken into account in tailoring content to be provided to a data processing system. Thus, in a particular instance, the location of content tailoring functions may be divided so as to provide improved tailoring performance to an individual user while maintaining network performance for other users.
In particular embodiment of the present invention, the policies which control the distribution 1 o of tailoring functions between data processing systems are defined and stored in a policy repository accessible to the second data processing system. In such a case, the policies are obtained from the policy repository.
In a further embodiment of the present invention, user preferences associated with the distribution of content tailoring functions between the first data processing system and data processing systems other than the first data processing system are stored in a preferences repository accessible to the second data processing system. The stored user preferences associated with a user of the first data processing system are obtained from the preferences repository and the session information, the obtained policies and the obtained user preferences are coalesced so as to define a content tailoring distribution for the session. The tailoring functions are then distributed between 2o the first data processing system and the second data processing system according to the defined content tailoring distribution for the session.
By providing the policies and user preferences in repositories, the policies and user preferences become "portable" in that a user who has access to the second data processing system may take advantage of the policy based distribution of tailoring functions irrespective of the physical location of the user and the particular device being used by the user.
Furthermore, by coalescing the information, preferences may be tailored for a particular session, thus providing further portability of content tailoring distribution from device to device and session to session. A user may have defined user default preferences which are stored in the repository and are overridden based on the particular characteristics of a device being used by the user. For example, a user may have preferences established for a desktop workstation which are overridden when the user logs on using a PDA. Thus, the present invention may provide flexibility without requiring user intervention on a case by case basis.
In yet another embodiment of the present invention, the session specific information may include information associated with a preference of the first data processing system as to the allocation of content tailoring functions between the first data processing system and data processing systems other than the first data processing system. The session specific information may also include an identification associated with a user of the first data processing system, hardware configuration information associated with the first data processing system, application information associated with an application executing on the first data processing system and/or operating system information associated with an operating system executing on the first data processing system.
In yet another embodiment of the present invention, content to be provided to the first data processing system is tailored at the second data processing system according to a first content tailoring function specified by the obtained policies and the session specific information so as to provide first tailored content. The first tailored content is then provided to the first data processing system. The first tailored content provided to the first data processing system may be fiirther tailored at the first data processing system according to a second content tailoring function specified by the obtained policies and the session specific information so as to provide final tailored content for data presentation.
2o In another embodiment of the present invention, content provided to a first data processing system communicating with a second data processing system is tailored by transmitting a request for content from the first data processing system to the second data processing system. The request for content provides information associated with the tailoring of content to be provided to the first data processing system. In response to receiving the request from the first data processing system at the second data processing system, policies associated with the tailoring of content provided to the first data processing system are obtained. The policies are associated with defining the distribution of fimctions for tailoring content to be provided to the first data processing system between the first data processing system and at least one data processing system other than the first data processing system.
The content requested by the received request is obtained and tailored utilizing a first tailoring operation at the data processing system other than the first data processing system. The first tailoring operation is based on the obtained policies and the information provided by the request. The tailored content is provided to the first data processing system and further tailored at the first data processing system based on the obtained policies and the information provided in the request.
By making the distribution of content tailoring functions responsive to requests from the first data processing system, particular embodiments of the present invention allow for a client-server paradigm. In such a paradigm, the present invention may take the form of a proxy or proxies which may be transparent to the application or users initially generating the requests and to the server or servers responding to the requests. Thus, the present invention provides for the distribution of l0 content tailoring functions without requiring modifications to existing applications.
In a further embodiment of the present invention, the information associated with the tailoring of content includes a user identification associated with a user of the first data processing system.
User preferences associated with the distribution of content tailoring functions between the first data processing system and data processing systems other than the first data processing system are stored 15 in a preferences repository accessible to the second data processing system. The stored user preferences associated with the user of the first data processing system are then obtained from the preferences repository and the obtained content tailored utilizing a first tailoring operation based on the obtained policies, the obtained stored user preferences and the information provided by the request. Furthermore, the user preferences received from the first data processing system may be 2o coalesced with the obtained policies and/or the obtained user preferences so as to define a content tailoring distribution for the first data processing system.
In a fiu-ther embodiment of the present invention, client content tailoring information may be incorporated into the tailored content to be provided to the first data processing system. The content provided to the first data processing system is then tailored at the first data processing system 25 based on the client content tailoring information. Furthermore, the client content tailoring information may specify a software program associated with the tailoring of content by the first data processing system. The first data processing system may then obtain the software program specified by the client content tailoring information and execute the software program at the first data processing system to further tailor the content.
In a particularly preferred embodiment of the present invention, the first data processing system is a pervasive computing device.
As will be appreciated by those of skill in the art, the present invention may be provided as a method, system or apparatus, and/or computer program product.
Brief Description of the Drawings Figure 1 is a diagram of a system which may utilize the present invention;
Figure 2 is a block diagram of a particular embodiment of the present invention utilizing proxies;
1o Figure 3 is a flowchart illustrating operations of a client in transmitting requests to a server according to one embodiment of the present invention;
Figure 4 is a flowchart illustrating operations of a server according to one embodiment of the present invention; and Figure 5 is a flow chart illustrating operations of a client in receiving a reply according to 15 one embodiment of the present invention.
Detailed Description of the Invention The present invention now is described more fully hereinafter with reference to the accompanying drawings, in which preferred embodiments of the invention are shown. This invention 2o may, however, be embodied in many different forms and should not be construed as limited to the embodiments set forth herein; rather, these embodiments are provided so that this disclosure will be thorough and complete, and will fully convey the scope of the invention to those skilled in the art.
Like numbers refer to like elements throughout.
As will be appreciated by one of skill in the art, the present invention may be embodied as 25 a method, data processing system, or computer program product. Accordingly, the present invention may take the form of an entirely hardware embodiment, an entirely software embodiment or an embodiment combining software and hardware aspects. Furthermore, the present invention may take the form of a computer program product on a computer-usable storage medium having computer-usable program code means embodied in the medium. Any suitable computer readable medium may be utilized including hard disks, CD-ROMs, optical storage devices, or magnetic storage devices.
Computer program code for carrying out operations of the present invention is preferably written in an object oriented programming language such as Java~, Smalltalk or C++. However, the computer program code for carrying out operations of the present invention may also be written in conventional procedural programming languages, such as the "C" programming language. The program code may execute entirely on the user's computer, partly on the user's computer, as a stand-alone software package, partly on the user's computer and partly on a remote computer or entirely on the remote computer. In the latter scenario, the remote computer may be connected to the user's computer through a local area network (LAN) or a wide area network (WAN), or the connection may 1o be made to an external computer (for example, through the Internet using an Internet Service Provider).
The present invention is described below with reference to flowchart illustrations of methods, apparatus (systems) and computer program products according to an embodiment of the invention.
It will be understood that each block of the flowchart illustrations, and combinations of blocks in the 15 flowchart illustrations, can be implemented by computer program instructions. These computer program instructions may be provided to a processor of a general purpose computer, special purpose computer, or other programmable data processing apparatus to produce a machine, such that the instructions, which execute via the processor ofthe computer or other programmable data processing apparatus, create means for implementing the functions specified in the flowchart block or blocks.
2o These computer program instructions may also be stored in a computer-readable memory that can direct a computer or other programmable data processing apparatus to function in a particular manner, such that the instructions stored in the computer-readable memory produce an article of manufacture including instruction means which implement the function specified in the flowchart block or blocks.
25 The computer program instructions may also be loaded onto a computer or other programmable data processing apparatus to cause a series of operational steps to be performed on the computer or other programmable apparatus to produce a computer implemented process such that the instructions which execute on the computer or other programmable apparatus provide steps for implementing the functions specified in the flowchart block or blocks.
As is described in more detail below, the present invention allows for the distribution of content tailoring functions between a first processor such as a pervasive computing device and other processors based on policies and information about the session of the first processor. As used herein, the term session refers to a period of time where the operating environment of a remote processor connected to a network or server is not expected to change. Thus, for example, if the policies controlling the distribution of content tailoring functions for a session relate to the network connection of the session and the type of hardware device connected to the session, then the session may be considered to start with connection to the network and end with disconnect. Similarly, if the control of the distribution of content tailoring functions for a session utilizes policies further based on the user identification of a user logged on to the network or server, then the session may be considered to start when the user logs on and end when the user logs off. In an even finer granularity, if the policies controlling the distribution of content tailoring functions for a session are further based on the characteristics of an application, then the session may be considered to start when the application is invoked and end when the application is terminated.
Thus, as can be seen from the above discussion, the concept of a session may vary depending on the particular policies or rules utilized and, further, multiple sessions may concurrently occur if multiple policies control differing aspects of user activity with respect to the network or server.
The present invention utilizes policies or rules to control the distribution of content tailoring functions between the mobile or pervasive computing device and devices to which the pervasive 2o computing device is connected. Thus, for differing sessions of the pervasive computing device the processing system which performs all or some portion of the content modification for the pervasive computing device may be varied so as to take advantage of the particular characteristics of the session. The types of information typically utilized to control a session may include the type of network connection (e.g. ethernet, modem, modem speed, duration of connection, connection cost, etc), the type of device connected (e.g. laptop computer, PDA, pen based system, cellular telephone, voiced based systems, etc), characteristics of the device connected (e.g.
display type, operating system, processing power, memory, etc), the application being executed or requested and the user identification of the user. Collectively, this information makes up the operating environment of a user session. Based on all or part of the information about a user's operating environment, a centrally administered set of rules may be applied to customize the distribution of content modification functions so as to take advantage of the particular operating environment of a session.
For example, according to the present invention, policies may be established regarding network usage that the transmission of images may be limited to conserve network bandwidth, especially on slow and/or costly communication links. Alternatively, a policy could be established that images will be provided irrespective of network bandwidth usage. Along similar lines, policies could be established regarding preprocessing of data for differing device types, such as image transformations, and storage of such transformations at a server. Similarly, policies could be established regarding security, such that a document or a portion of a document may be marked as 1 o sensitive and the content could be sent based on the user's security classification. A policy could also be established regarding the distribution of business information over unsecured links, such as unencrypted wireless links. A policy could also be established regarding priorities, for example, an override policy could be established for certain users, such as executives or customers, such that requested content would be provided on a best efforts basis irrespective of other operating environment parameters.
In addition to determining the distribution of content tailoring based upon policies, rules may also be established, for example, for particular operating environment conditions. Thus, rules may be established such as removing images from content provided to devices with less than a 120 X 150 pixel display. Images may be transformed to black and white only if the connection to a device is 2o through a wireless connection. Similarly, rules can be based on the type of message. For example, if a message is an e-mail do not modify the content. If the message is sent to a PDA then only display heading lines and enclose text with XML/HTML "special" tags.
As will be appreciated by those of skill in the art, the number of rules and policies will vary from organization to organization and may be customized based on a particular organization's requirements. Accordingly, while several examples of rules and policies have been provided herein to illustrate the present invention, the present invention should not be construed as limited to any particular set of rules or policies.
Figure 1 illustrates a system 10 in which the present invention may be beneficially utilized.
As seen in Figure 1, a server 20 may be accessed from a number of differing data processing systems such as portable computers 22 and 22', desktop computer 23, PDA 24, pen based computer 26, cellular telephone 28, which may be smartphone or screenphone and satellite telephone 28' which may be a smartphone, screenphone or voice only telephone. These differing data processing systems 22, 22', 23, 24, 26, 28 and 28' may each have differing processing capabilities, data presentation capabilities, operating systems and/or applications which request information from server 20.
Furthermore,. each of these differing data processing systems 22, 22', 23, 24, 26, 28 and 28' may be utilized by different users with different preferences associated with the users. As will be appreciated by those of skill in the art, other types of processing systems may also benefit from utilization of the present invention.
1o The differing data processing systems 22, 22', 23, 24, 26, 28 and 28' may also utilize different communication techniques for communicating with server 20. For example, portable computer 22 and desktop computer 23 may utilize a network interface card to communicate with server 20 over a direct network connection such as the Ethernet 38 illustrated in Figure 1. Portable computer 22' may communicate directly with server 20 through modem 32 and modem 32'. PDA
24 is illustrated as communicating with server 20 through desktop computer 23.
Similarly, pen based computer 26 may communicate through a modem 32" connection to the Internet or intranet 40.
Cellular telephone 28 may communicate with server 20 through a cellular connection 36 and the Internet or intranet 40. Finally, telephone 28' may communicate with server 20 through a satellite connection 34 and the Internet or intranet 40.
2o Furthermore, as will be appreciated by those of skill in the art, the type of connection may change from session to session. Thus, for example, while portable computer 22' is illustrated as using a modem to modem direct connection to communicate with server 20, in a subsequent session, portable computer 22' could communicate with server 20 through a network connection, by for example, connection to Ethernet 38. As is seen from the examples in Figure 1, data processing systems may communicate with a server using a wide variety of connection types with differing connection characteristics. Some connection types may be high speed, low cost, connections, such a the Ethernet connection 38, while others may be lower speed, higher cost, connections, such as the cellular connection 36 or lower speed, lower cost, connections such as through a modem 32.
As is further illustrated in Figure 1, server 20 has access to a policy and rule repository 30.
The policy and rule repository 30 may be incorporated in server 20 or may be accessible through a network or other communication connection. The policy and rule repository 30 may also be periodically downloaded or otherwise provided to server 20 and a copy of the policy and rule repository 30 maintained by server 20. The policy and rule repository 30 preferably includes policies and rules which define the distribution of content tailoring functions between the server 20 and a - client such as the data processing systems 22, 22', 23 , 24, 26, and 28 illustrated in Figure 1. The policy and rule repository 30 may also include user preference information which may be used in determining a distribution of content tailoring functions between the server 20 and a client. While the policy and rule repository 30 is illustrated and described in the present application as a single io database, as will be appreciated by those of skill in the art, multiple databases may be utilized.
In general, in a system according to the present invention, when an application executing on a client data processing system, such as one of data processing systems 22, 22', 23 , 24, 26 and 28, initially establishes a connection or requests information from server 20, the client provides session specific information to server 20. Server 20 accesses the policy and rule repository 30 and, based on the policies and rules and the session specific information determines where any content modification or tailoring for the client should take place; in the client, in the server, in some other processor or in some combination. The server 20 then provides the requested information content to the client data processing system tailored as specified by the policies and rules and the session specific information. If any further tailoring is to be performed by the client data processing system, 2o this tailoring of the content may be performed and the final tailored content may be utilized by the application executing on the client data processing system.
Thus, the present invention provides for the dynamic assignment of content tailoring functions between processing systems based on particular characteristics of a session. Such a dynamic assignment may provide higher efficiency in the utilization of resources in tailoring content to be provided to a client. As used herein, content tailoring refers to modifications to the form or substance of content provided to a client based on characteristics of a session with the client. For example, content provided to a smartphone with a limited viewing area and display resolution may be tailored by eliminating graphics and providing only text. As another example, content provided to a client with limited processing power may be tailored by decompressing compressed files prior to providing the file to the client. As a further example, content may be tailored based on the speed or cost of the communication connection with the client. Thus, the server may pass along compressed information to a client during a session where the connection is through a wireless connection such that the client would decompress the information, but the server would decompress the information if the connection is through a direct network connection.
Similarly, image transformations, text content tailoring and translation of content to a voice markup language are further examples of content tailoring which may be utilized with the present invention.
Furthermore, because the connection type may change from session to session, the distribution of content tailoring may change from session to session. Thus, when PDA 24 is 1o connected through satellite 34 the content tailoring may be distributed in a different manner than when PDA 24 is connected through Ethernet 38. Similarly, if a user utilizes both a portable computer, such as portable computer 22, and a PDA 24, then the distribution of content tailoring functions may differ when the user uses portable computer 22 or PDA 24.
Figure 2 illustrates one embodiment of the present invention where the application executing on the client data processing system 50 is a browser application 52. In order to facilitate utilizing conventional browser applications, a client-side proxy 54 may be utilized to incorporate session specific information into requests sent to server data processing system 60.
The client side proxy may be a stand alone program or may be an applet, "plug-in" or other program which is downloaded to the client data processing system 50 upon connection to a server data processing system 60 or has 2o previously been cached or otherwise stored at the client data processing system. Furthermore, as will be appreciated by those of skill in the art, the operations described herein as carried out by the client-side proxy 54 may be incorporated into browser 52.
As is further seen in Figure 2, the client-side proxy communicates with a server-side proxy 64 which may control the distribution of tailoring functions based on user preferences, policies and/or rules which may be maintained in the central repository 30. The server-side proxy 64 also obtains content to be provided to the client data processing system 50 from server application 62.
As will be appreciated by those of skill in the art, the illustrated system of Figure 2 is simplified for illustration purposes. Thus, for example, the content requested by the client data processing system 50 may be obtained from multiple servers on multiple server data processing systems. Furthermore, the connection between client data processing system 50 and server data processing system 60 need not be direct as is illustrated in Figure 2.
The operations which occur at the client data processing system 50, which may be carried out by the client-side proxy 54 and the operations which occur at the server data processing system 60 which may be carried out by the server-side proxy 64 will now be described with respect to Figures 3 through 5. As seen in Figure 3, when the browser 52 transmits a request, the client-side proxy 54 receives the request and determines if it is the first request for the current session (block 100). If the request is the first request, then it is determined if the client data processing system is capable of and has a preference for performing the content transformation or "tailoring" (i.
e. should content tailoring 1 o occur at the client data processing system 50 or at another data processing system)(block 102). This information, along with other information about the client data processing system 50 and the session, such as for example, data processing capability, available memory, display type and size, resource availability, connection type, priorities for requested information, connection duration, or the like, is incorporated into the request (block 104). Client preferences and other session information (blocks 102 and 104) may reside at the client data processing system 50 or they may be obtained from a server during device initialization, at user logon or with each session. A
user identification, such as a userid, may also be included in the request (block 106). The information added or otherwise contained in the request may collectively be referred to as "session specific information." After incorporating the session specific information in the request, the request is sent to the server-side proxy 64 (block 108).
Returning to block 100 of Figure 3, if the request from the browser 52 is not the first request, then, if the server side stores the previously transmitted session specific information, the only information which would need to be inserted into the request is the user identification and a session identifier to indicate that the previously transmitted session specific information remains valid (block 106). The request with the inserted user identification would then be sent to the server-side proxy (block 108). However, if the server-side proxy 64 does not store information, the session specific information may be added to and sent with each request.
When the request is received from the client data processing system the operations of Figure 4 may be carried out. As is seen in Figure 4, when the request is received, the server-side proxy 64 determines if it is the first request received for the session from the client-side proxy 54 (block 202).
If it is the first request received, then the received parameters (i.e. the session specific information) contained in the request is stored and associated with the user identification in the request (block 204). The server-side proxy 64 also accesses the central repository 30 to retrieve any user preferences associated with the user identification received in the request (block 206). Such user preferences may include, for example, preferences for content, such as the display of images, a home page and home page content, or the like, as well as formatting preferences, such as fonts, limiting displays to an initial screen or only displaying headings. These preferences are then coalesced with any parameters received from the client-side proxy 54 (block 208). The process of coalescing the 1o preferences and received session specific information may involve determining any inconsistencies and selecting a particular preference if inconsistencies do arise. Otherwise, the process may involve determining a single set of preferences from the received session specific information and the obtained preferences.
Server-side proxy 64 also retrieves rules and/or policies for content modification from the central repository 30 (block 210). These rules and/or policies may be retrieved at the same time as the preferences are obtained or they may be retrieved before or after retrieving any preferences. The rules and/or policies and the preferences are stored by the server-side proxy 64 so as to avoid the necessity of retrieving the rules andJor policies and preferences for subsequent requests from the client during the same session (block 208 and block 210).
2o The server-side proxy 64 may then determine if the request should be modified or the server otherwise requested so that the server application 62 provides modified content in response to the request and provides the request to the server 62 (block 200). For example, the server-side proxy 64 could determine that text only responses are appropriate for the request and could modify the request or other server parameters such that the reply from the server was in text only format. It is then determined if the content to be provided to the client has been received by the server-side proxy 64 from the server 62 (block 214). If the reply to the request has not been received, then the server-side proxy 64 waits for the reply (block 214). However, if the reply has been received, then the server-side proxy 64 determines if content modification by the server has been specified by the policies, rules and/or the preferences (block 216). If content modification is specified to be carried out at the server, then the content is modified based on the coalesced preferences/received session specific information and the policies or rules for the user identification of the request (block 218).
Irrespective of whether content modification is to be performed at the server, the server-side proxy 64 also determines if content tailoring or modification is to be performed at the client (block 220). If content modification is to be performed at the client, then the server-side proxy 64 incorporates any information necessary for such modification, such as programs required, etc..., into the response to be provided to the client (block 222). The response is then sent to the client (block 224).
Returning to block 202, if the request is not the first request from the client, then it is determined if more rules are required for the specific request (block 212).
More rules may be required if, for example, rules are associated with specific content requested or with changing operating environment conditions. If more rules are required, then the rules are retrieved and operations continue from block 210 as described above. However, if no more rules are required, then operations continue from block 200 as described above.
When the client-side proxy 54 receives the reply from the server-side proxy 64, the operations of Figure 5 are carried out. The client-side proxy 54 determines if content modification is to be carried out by the client (block 300). Such a determination may be made by inspecting the reply to determine if content modification information has been included with the reply. If no client modification of the content is required then the reply is provided to the browser 52 (block 308).
2o However, if client modification is required by the client, then the client-side proxy 54 determines if additional software programs are required for the content modification (block 302). If additional software programs are required, then the software programs may be downloaded or otherwise acquired by the client-side proxy 54 (block 304). Irrespective of whether additional software programs are required, the client-side proxy modifies the content as specified by the content modification information in the reply to provide final tailored content for the browser 52 (block 306).
This final tailored content is then provided to the browser 52 (block 308).
Thus, the present invention allows for the distribution of content modification (tailoring functions) between the client and the server. These distributions may be based on the predefined policies or rules, user preferences, as well as session specific information.
While the present invention has been described with respect to the addition of session specific information to requests initiated by a client, as will be appreciated by those of skill in the art, if such information is otherwise available, or if the information is not necessary to make decisions with respect to the policies or rules then such information need not be incorporated in requests.
Furthermore, if a client does not have the ability to participate in distributed content tailoring, then the-server side proxy.may make inferences about the client device and perform all the content tailoring that it determines is necessary. Alternatively, requests received by the server-side proxy from such clients could be passed through to the server and conventional content tailoring performed.
While the description of Figures 3 through 5 describes the coalescing of preferences, as will 1o be appreciated by those of skill in the art, the preferences, the policies and/or rules, and the session specific information may be coalesced to provide a single definition for the distribution of content tailoring. Furthermore, while the operations illustrated in Figures 3 through 5 are illustrated in a particular sequence, as will be appreciated by those of skill in the art, the sequence of operations may be varied while still benefiting from the teachings of the present invention.
Accordingly, the present 15 invention should not be construed as limited to the particular sequence or sequences of operations illustrated in the flowchart illustrations.
Furthermore, while the present invention has generally been described with respect to static content, as will be appreciated by those of skill in the art, the present invention may be equally applicable to dynamic web content such as content created by server-side programs interfacing with 2o backend databases and/or applications.
The foregoing is illustrative of the present invention and is not to be construed as limiting thereof. Although a few exemplary embodiments of this invention have been described, those skilled in the art will readily appreciate that many modifications are possible in the exemplary embodiments without materially departing from the novel teachings and advantages of this invention. Accordingly, 25 all such modifications are intended to be included within the scope of this invention as defined in the claims. In the claims, means-plus-function clauses are intended to cover the structures described herein as performing the recited function and not only structural equivalents but also equivalent structures. Therefore, it is to be understood that the foregoing is illustrative of the present invention and is not to be construed as limited to the specific embodiments disclosed, and that modifications to the disclosed embodiments, as well as other embodiments, are intended to be included within the scope of the appended claims. The invention is defined by the following claims, with equivalents of the claims to be included therein.
PLACEMENT OF WEB CONTENT TAILORING
Field of the Invention The present invention relates generally to web content and, more particularly, to the transfer and presentation of web content among data processing systems.
Background of the Invention The Internet is a worldwide decentralized network of computers having the ability to communicate with each other. The Internet has gained broad recognition as a viable medium for communicating and interacting across multiple networks. The World Wide Web (Web) was created in the early 1990's, and is composed of server-hosting computers (web servers) connected to the 1o Internet that have hypertext documents or web pages stored therewithin. Web pages are accessible by client programs (i.e., web browsers) utilizing the Hypertext Transfer Protocol (HTTP) via a Transmission Control Protocol/Internet Protocol (TCP/IP) connection between a client-hosting device and a server-hosting device.
An intranet is a private computer network conventionally contained within an enterprise and that conventionally includes one or more servers in communication with multiple user computers.
An intranet may be composed of interlinked local area networks and may also use leased lines in a wide-area network. An intranet may or may not include connections to the outside Internet. Intranets conventionally utilize various Internet protocols and, in general, often look like private versions of the Internet. An intranet user conventionally accesses an intranet server via a web browser running locally on his/her computer.
Exemplary web browsers for both Internet and intranet use include Netscape Navigator (Netscape Communications Corporation, Mountain View, CA) and Internet Explorer (Microsoft Corporation, Redmond, WA). Web browsers typically provide a graphical user interface for retrieving and viewing information, applications and other resources hosted by Internet/intranet servers (hereinafter collectively referred to as "web servers" or "web sites").
Web content including, but not limited to, information, applications, applets and other video and audio resources (collectively referred to herein as "files") are conventionally delivered from a web server to a web browser on a user's computer in the form of web pages. As is known to those skilled in this art, a web page is conventionally formatted via a standard page description language such as HyperText Markup Language (HTML) or Extensible Markup Language (XML), and typically.displays text and graphics, and can play sound, animation, and video data. HTML and XML
provide basic document formatting and allow a web content provider to specify hypertext links (typically manifested as highlighted text) to other servers and files. When a user selects a particular hypertext link, a web browser reads and interprets the address, called a Uniform Resource Locator (URL) associated with the link, connects the web browser with the web server at that address, and makes an HTTP request for the file identified in the link. The web server then sends the requested file to the client in the format of the requested file (e.g. HTML, XML, GIF, JPEG, etc) which the browser interprets and displays to the user.
With the increasing mobility of today's society, the demand for mobile computing capabilities has also increased. Many workers and professionals are downsizing their laptop computers to smaller palm-top or hand-held devices, such as personal digital assistants (PDAs). In addition, many people now utilize cellular telephones to access the Internet and to perform various other computing functions. Hand-held computing devices including, but not limited to, PDAs, cellular telephones, and computing devices utilized within appliances and automobiles, are often collectively referred to as "pervasive" computing devices. Many hand-held computing devices utilize the Microsoft Windows CE and 3Com Palm Computing platforms as well as web browsers such as HandWeb from SmartCode, Inc. and the Pocket Internet Explorer from Microsoft, Inc.
Unfortunately, hand-held computing devices may have limited functionality in comparison to desktop computers for which much web content has been developed. For example, hand-held devices may be voice only, may have limited processing capabilities, limited memory, black and white displays or may have displays that are small in size compared with desktop computer displays.
As a result, images and text otherwise displayable on a desktop computer display may not be displayable on a hand-held computing device display or may be impractical or otherwise undesirable to display on a hand-held computing device. For example, a desktop computer display having an array of 1024 pixels by 768 pixels may be able to display a large (e.g., 2 megabit), 24 bit per pixel image. A hand-held computing device with a display having an array of 120 pixels by 120 pixels and with the ability to display only a few bits per pixel, may ignore much of the image data. As a result the image may not be displayed properly, if at all, via the hand-held computing device display.
Furthermore, text within a file may have a particular font or size that can hinder the display thereof within a hand-held computing.device display.
Files that may not be displayable via a hand-held computing device display can typically be transformed into a format that is displayable within a hand-held computing device display. For example, large, high resolution, color images can be transformed into small, black and white images 1 o that can be displayed within small, low resolution displays. Furthermore, because some web servers can recognize the type of client device requesting a file, files in the proper format for display via the requesting client device can be provided.
Furthermore, these pervasive computing devices may be connected to a network, such as the Internet or an intranet, through different communication methods. For example, the same pervasive computing device may be connected to a network via a direct Local Area Network (LAN) connection such as through a network interface card (NIC) during one session and then in a subsequent session be connected over a wireless communication link, such as over a cellular telephone. These differing connection methods may have substantially differing properties which may impact on the form of content provided to the pervasive computing device. Thus, the LAN connection provide low cost 2o and short delays for acquiring and rendering information while the wireless communication link may be at a higher cost with longer delays. Thus, a form of content which may be acceptable for the LAN
connection may be unacceptable for the wireless communication link.
Similarly, other performance issues, which may change from session to session or during a session, may also impact on the transformation or "tailoring" of content for pervasive computing devices. Thus, for example, the expected duration of the connection, congestion on the communication link or network or the content provided to the pervasive computing device may all impact on the type of tailoring of content to be performed.
Conventionally, this tailoring of content has been performed either at the server providing the content to the pervasive computing device or at the pervasive computing device. See for example, ProxiWeb browser and proxy from Proxinet, Inc., and U.S. Patent No.
5,764,235.
However, such an arbitrary allocation of tailoring functions may result in performance degradation to the server, the pervasive computing device or the network through which these devices communicate. Thus, a need exists for improvements in the tailoring of content for pervasive computing devices to better exploit the resources available to such devices.
Summary of the Invention In view of the above discussion, it is an object of the present invention to provide improved tailoring of content for data processing systems, such as pervasive computing devices.
1o A further object of the present invention is to provide for the improved tailoring of content without requiring modification of existing browsers or servers.
Still another object of the present invention is to provide content tailoring without requiring user intervention in each instance.
These and other objects of the present invention are provided by methods, systems and computer program products for tailoring content for a session (i.e. a period of t ime where the operating environment of a data processing is not expected to change ) of a first data processing system (such as a client) communicating with a second data processing system (such as a server or proxy) by obtaining session specific information from the first data processing system and distributing tailoring functions between the first data processing system 2o and the second data processing system based upon the obtained session specific information. In particular, policies which control the distribution of tailoring functions between data processing systems based on session specific information may be obtained from a repository and tailoring functions distributed between the first data processing system and the second data processing system according to the obtained policies and the session specific information.
An ability to modify the location of content tailoring dynamically allows for the ability to respond to changes in server availability, network conditions, connection types, information presentation characteristics, device types, user preferences and organizational policies. By distributing the tailoring of content provided to a data processing system, such as a pervasive computing device, based on session specific information, the location of the content tailoring may be established based on particular characteristics of a session. The location of content tailoring may be determined to take advantage of the characteristics of a session to provide improvement in the tailoring of content. By basing the distribution of the content tailoring functions on session specific information and established policies, both the concerns of a particular user as well as the overall concerns of network management may be taken into account in tailoring content to be provided to a data processing system. Thus, in a particular instance, the location of content tailoring functions may be divided so as to provide improved tailoring performance to an individual user while maintaining network performance for other users.
In particular embodiment of the present invention, the policies which control the distribution 1 o of tailoring functions between data processing systems are defined and stored in a policy repository accessible to the second data processing system. In such a case, the policies are obtained from the policy repository.
In a further embodiment of the present invention, user preferences associated with the distribution of content tailoring functions between the first data processing system and data processing systems other than the first data processing system are stored in a preferences repository accessible to the second data processing system. The stored user preferences associated with a user of the first data processing system are obtained from the preferences repository and the session information, the obtained policies and the obtained user preferences are coalesced so as to define a content tailoring distribution for the session. The tailoring functions are then distributed between 2o the first data processing system and the second data processing system according to the defined content tailoring distribution for the session.
By providing the policies and user preferences in repositories, the policies and user preferences become "portable" in that a user who has access to the second data processing system may take advantage of the policy based distribution of tailoring functions irrespective of the physical location of the user and the particular device being used by the user.
Furthermore, by coalescing the information, preferences may be tailored for a particular session, thus providing further portability of content tailoring distribution from device to device and session to session. A user may have defined user default preferences which are stored in the repository and are overridden based on the particular characteristics of a device being used by the user. For example, a user may have preferences established for a desktop workstation which are overridden when the user logs on using a PDA. Thus, the present invention may provide flexibility without requiring user intervention on a case by case basis.
In yet another embodiment of the present invention, the session specific information may include information associated with a preference of the first data processing system as to the allocation of content tailoring functions between the first data processing system and data processing systems other than the first data processing system. The session specific information may also include an identification associated with a user of the first data processing system, hardware configuration information associated with the first data processing system, application information associated with an application executing on the first data processing system and/or operating system information associated with an operating system executing on the first data processing system.
In yet another embodiment of the present invention, content to be provided to the first data processing system is tailored at the second data processing system according to a first content tailoring function specified by the obtained policies and the session specific information so as to provide first tailored content. The first tailored content is then provided to the first data processing system. The first tailored content provided to the first data processing system may be fiirther tailored at the first data processing system according to a second content tailoring function specified by the obtained policies and the session specific information so as to provide final tailored content for data presentation.
2o In another embodiment of the present invention, content provided to a first data processing system communicating with a second data processing system is tailored by transmitting a request for content from the first data processing system to the second data processing system. The request for content provides information associated with the tailoring of content to be provided to the first data processing system. In response to receiving the request from the first data processing system at the second data processing system, policies associated with the tailoring of content provided to the first data processing system are obtained. The policies are associated with defining the distribution of fimctions for tailoring content to be provided to the first data processing system between the first data processing system and at least one data processing system other than the first data processing system.
The content requested by the received request is obtained and tailored utilizing a first tailoring operation at the data processing system other than the first data processing system. The first tailoring operation is based on the obtained policies and the information provided by the request. The tailored content is provided to the first data processing system and further tailored at the first data processing system based on the obtained policies and the information provided in the request.
By making the distribution of content tailoring functions responsive to requests from the first data processing system, particular embodiments of the present invention allow for a client-server paradigm. In such a paradigm, the present invention may take the form of a proxy or proxies which may be transparent to the application or users initially generating the requests and to the server or servers responding to the requests. Thus, the present invention provides for the distribution of l0 content tailoring functions without requiring modifications to existing applications.
In a further embodiment of the present invention, the information associated with the tailoring of content includes a user identification associated with a user of the first data processing system.
User preferences associated with the distribution of content tailoring functions between the first data processing system and data processing systems other than the first data processing system are stored 15 in a preferences repository accessible to the second data processing system. The stored user preferences associated with the user of the first data processing system are then obtained from the preferences repository and the obtained content tailored utilizing a first tailoring operation based on the obtained policies, the obtained stored user preferences and the information provided by the request. Furthermore, the user preferences received from the first data processing system may be 2o coalesced with the obtained policies and/or the obtained user preferences so as to define a content tailoring distribution for the first data processing system.
In a fiu-ther embodiment of the present invention, client content tailoring information may be incorporated into the tailored content to be provided to the first data processing system. The content provided to the first data processing system is then tailored at the first data processing system 25 based on the client content tailoring information. Furthermore, the client content tailoring information may specify a software program associated with the tailoring of content by the first data processing system. The first data processing system may then obtain the software program specified by the client content tailoring information and execute the software program at the first data processing system to further tailor the content.
In a particularly preferred embodiment of the present invention, the first data processing system is a pervasive computing device.
As will be appreciated by those of skill in the art, the present invention may be provided as a method, system or apparatus, and/or computer program product.
Brief Description of the Drawings Figure 1 is a diagram of a system which may utilize the present invention;
Figure 2 is a block diagram of a particular embodiment of the present invention utilizing proxies;
1o Figure 3 is a flowchart illustrating operations of a client in transmitting requests to a server according to one embodiment of the present invention;
Figure 4 is a flowchart illustrating operations of a server according to one embodiment of the present invention; and Figure 5 is a flow chart illustrating operations of a client in receiving a reply according to 15 one embodiment of the present invention.
Detailed Description of the Invention The present invention now is described more fully hereinafter with reference to the accompanying drawings, in which preferred embodiments of the invention are shown. This invention 2o may, however, be embodied in many different forms and should not be construed as limited to the embodiments set forth herein; rather, these embodiments are provided so that this disclosure will be thorough and complete, and will fully convey the scope of the invention to those skilled in the art.
Like numbers refer to like elements throughout.
As will be appreciated by one of skill in the art, the present invention may be embodied as 25 a method, data processing system, or computer program product. Accordingly, the present invention may take the form of an entirely hardware embodiment, an entirely software embodiment or an embodiment combining software and hardware aspects. Furthermore, the present invention may take the form of a computer program product on a computer-usable storage medium having computer-usable program code means embodied in the medium. Any suitable computer readable medium may be utilized including hard disks, CD-ROMs, optical storage devices, or magnetic storage devices.
Computer program code for carrying out operations of the present invention is preferably written in an object oriented programming language such as Java~, Smalltalk or C++. However, the computer program code for carrying out operations of the present invention may also be written in conventional procedural programming languages, such as the "C" programming language. The program code may execute entirely on the user's computer, partly on the user's computer, as a stand-alone software package, partly on the user's computer and partly on a remote computer or entirely on the remote computer. In the latter scenario, the remote computer may be connected to the user's computer through a local area network (LAN) or a wide area network (WAN), or the connection may 1o be made to an external computer (for example, through the Internet using an Internet Service Provider).
The present invention is described below with reference to flowchart illustrations of methods, apparatus (systems) and computer program products according to an embodiment of the invention.
It will be understood that each block of the flowchart illustrations, and combinations of blocks in the 15 flowchart illustrations, can be implemented by computer program instructions. These computer program instructions may be provided to a processor of a general purpose computer, special purpose computer, or other programmable data processing apparatus to produce a machine, such that the instructions, which execute via the processor ofthe computer or other programmable data processing apparatus, create means for implementing the functions specified in the flowchart block or blocks.
2o These computer program instructions may also be stored in a computer-readable memory that can direct a computer or other programmable data processing apparatus to function in a particular manner, such that the instructions stored in the computer-readable memory produce an article of manufacture including instruction means which implement the function specified in the flowchart block or blocks.
25 The computer program instructions may also be loaded onto a computer or other programmable data processing apparatus to cause a series of operational steps to be performed on the computer or other programmable apparatus to produce a computer implemented process such that the instructions which execute on the computer or other programmable apparatus provide steps for implementing the functions specified in the flowchart block or blocks.
As is described in more detail below, the present invention allows for the distribution of content tailoring functions between a first processor such as a pervasive computing device and other processors based on policies and information about the session of the first processor. As used herein, the term session refers to a period of time where the operating environment of a remote processor connected to a network or server is not expected to change. Thus, for example, if the policies controlling the distribution of content tailoring functions for a session relate to the network connection of the session and the type of hardware device connected to the session, then the session may be considered to start with connection to the network and end with disconnect. Similarly, if the control of the distribution of content tailoring functions for a session utilizes policies further based on the user identification of a user logged on to the network or server, then the session may be considered to start when the user logs on and end when the user logs off. In an even finer granularity, if the policies controlling the distribution of content tailoring functions for a session are further based on the characteristics of an application, then the session may be considered to start when the application is invoked and end when the application is terminated.
Thus, as can be seen from the above discussion, the concept of a session may vary depending on the particular policies or rules utilized and, further, multiple sessions may concurrently occur if multiple policies control differing aspects of user activity with respect to the network or server.
The present invention utilizes policies or rules to control the distribution of content tailoring functions between the mobile or pervasive computing device and devices to which the pervasive 2o computing device is connected. Thus, for differing sessions of the pervasive computing device the processing system which performs all or some portion of the content modification for the pervasive computing device may be varied so as to take advantage of the particular characteristics of the session. The types of information typically utilized to control a session may include the type of network connection (e.g. ethernet, modem, modem speed, duration of connection, connection cost, etc), the type of device connected (e.g. laptop computer, PDA, pen based system, cellular telephone, voiced based systems, etc), characteristics of the device connected (e.g.
display type, operating system, processing power, memory, etc), the application being executed or requested and the user identification of the user. Collectively, this information makes up the operating environment of a user session. Based on all or part of the information about a user's operating environment, a centrally administered set of rules may be applied to customize the distribution of content modification functions so as to take advantage of the particular operating environment of a session.
For example, according to the present invention, policies may be established regarding network usage that the transmission of images may be limited to conserve network bandwidth, especially on slow and/or costly communication links. Alternatively, a policy could be established that images will be provided irrespective of network bandwidth usage. Along similar lines, policies could be established regarding preprocessing of data for differing device types, such as image transformations, and storage of such transformations at a server. Similarly, policies could be established regarding security, such that a document or a portion of a document may be marked as 1 o sensitive and the content could be sent based on the user's security classification. A policy could also be established regarding the distribution of business information over unsecured links, such as unencrypted wireless links. A policy could also be established regarding priorities, for example, an override policy could be established for certain users, such as executives or customers, such that requested content would be provided on a best efforts basis irrespective of other operating environment parameters.
In addition to determining the distribution of content tailoring based upon policies, rules may also be established, for example, for particular operating environment conditions. Thus, rules may be established such as removing images from content provided to devices with less than a 120 X 150 pixel display. Images may be transformed to black and white only if the connection to a device is 2o through a wireless connection. Similarly, rules can be based on the type of message. For example, if a message is an e-mail do not modify the content. If the message is sent to a PDA then only display heading lines and enclose text with XML/HTML "special" tags.
As will be appreciated by those of skill in the art, the number of rules and policies will vary from organization to organization and may be customized based on a particular organization's requirements. Accordingly, while several examples of rules and policies have been provided herein to illustrate the present invention, the present invention should not be construed as limited to any particular set of rules or policies.
Figure 1 illustrates a system 10 in which the present invention may be beneficially utilized.
As seen in Figure 1, a server 20 may be accessed from a number of differing data processing systems such as portable computers 22 and 22', desktop computer 23, PDA 24, pen based computer 26, cellular telephone 28, which may be smartphone or screenphone and satellite telephone 28' which may be a smartphone, screenphone or voice only telephone. These differing data processing systems 22, 22', 23, 24, 26, 28 and 28' may each have differing processing capabilities, data presentation capabilities, operating systems and/or applications which request information from server 20.
Furthermore,. each of these differing data processing systems 22, 22', 23, 24, 26, 28 and 28' may be utilized by different users with different preferences associated with the users. As will be appreciated by those of skill in the art, other types of processing systems may also benefit from utilization of the present invention.
1o The differing data processing systems 22, 22', 23, 24, 26, 28 and 28' may also utilize different communication techniques for communicating with server 20. For example, portable computer 22 and desktop computer 23 may utilize a network interface card to communicate with server 20 over a direct network connection such as the Ethernet 38 illustrated in Figure 1. Portable computer 22' may communicate directly with server 20 through modem 32 and modem 32'. PDA
24 is illustrated as communicating with server 20 through desktop computer 23.
Similarly, pen based computer 26 may communicate through a modem 32" connection to the Internet or intranet 40.
Cellular telephone 28 may communicate with server 20 through a cellular connection 36 and the Internet or intranet 40. Finally, telephone 28' may communicate with server 20 through a satellite connection 34 and the Internet or intranet 40.
2o Furthermore, as will be appreciated by those of skill in the art, the type of connection may change from session to session. Thus, for example, while portable computer 22' is illustrated as using a modem to modem direct connection to communicate with server 20, in a subsequent session, portable computer 22' could communicate with server 20 through a network connection, by for example, connection to Ethernet 38. As is seen from the examples in Figure 1, data processing systems may communicate with a server using a wide variety of connection types with differing connection characteristics. Some connection types may be high speed, low cost, connections, such a the Ethernet connection 38, while others may be lower speed, higher cost, connections, such as the cellular connection 36 or lower speed, lower cost, connections such as through a modem 32.
As is further illustrated in Figure 1, server 20 has access to a policy and rule repository 30.
The policy and rule repository 30 may be incorporated in server 20 or may be accessible through a network or other communication connection. The policy and rule repository 30 may also be periodically downloaded or otherwise provided to server 20 and a copy of the policy and rule repository 30 maintained by server 20. The policy and rule repository 30 preferably includes policies and rules which define the distribution of content tailoring functions between the server 20 and a - client such as the data processing systems 22, 22', 23 , 24, 26, and 28 illustrated in Figure 1. The policy and rule repository 30 may also include user preference information which may be used in determining a distribution of content tailoring functions between the server 20 and a client. While the policy and rule repository 30 is illustrated and described in the present application as a single io database, as will be appreciated by those of skill in the art, multiple databases may be utilized.
In general, in a system according to the present invention, when an application executing on a client data processing system, such as one of data processing systems 22, 22', 23 , 24, 26 and 28, initially establishes a connection or requests information from server 20, the client provides session specific information to server 20. Server 20 accesses the policy and rule repository 30 and, based on the policies and rules and the session specific information determines where any content modification or tailoring for the client should take place; in the client, in the server, in some other processor or in some combination. The server 20 then provides the requested information content to the client data processing system tailored as specified by the policies and rules and the session specific information. If any further tailoring is to be performed by the client data processing system, 2o this tailoring of the content may be performed and the final tailored content may be utilized by the application executing on the client data processing system.
Thus, the present invention provides for the dynamic assignment of content tailoring functions between processing systems based on particular characteristics of a session. Such a dynamic assignment may provide higher efficiency in the utilization of resources in tailoring content to be provided to a client. As used herein, content tailoring refers to modifications to the form or substance of content provided to a client based on characteristics of a session with the client. For example, content provided to a smartphone with a limited viewing area and display resolution may be tailored by eliminating graphics and providing only text. As another example, content provided to a client with limited processing power may be tailored by decompressing compressed files prior to providing the file to the client. As a further example, content may be tailored based on the speed or cost of the communication connection with the client. Thus, the server may pass along compressed information to a client during a session where the connection is through a wireless connection such that the client would decompress the information, but the server would decompress the information if the connection is through a direct network connection.
Similarly, image transformations, text content tailoring and translation of content to a voice markup language are further examples of content tailoring which may be utilized with the present invention.
Furthermore, because the connection type may change from session to session, the distribution of content tailoring may change from session to session. Thus, when PDA 24 is 1o connected through satellite 34 the content tailoring may be distributed in a different manner than when PDA 24 is connected through Ethernet 38. Similarly, if a user utilizes both a portable computer, such as portable computer 22, and a PDA 24, then the distribution of content tailoring functions may differ when the user uses portable computer 22 or PDA 24.
Figure 2 illustrates one embodiment of the present invention where the application executing on the client data processing system 50 is a browser application 52. In order to facilitate utilizing conventional browser applications, a client-side proxy 54 may be utilized to incorporate session specific information into requests sent to server data processing system 60.
The client side proxy may be a stand alone program or may be an applet, "plug-in" or other program which is downloaded to the client data processing system 50 upon connection to a server data processing system 60 or has 2o previously been cached or otherwise stored at the client data processing system. Furthermore, as will be appreciated by those of skill in the art, the operations described herein as carried out by the client-side proxy 54 may be incorporated into browser 52.
As is further seen in Figure 2, the client-side proxy communicates with a server-side proxy 64 which may control the distribution of tailoring functions based on user preferences, policies and/or rules which may be maintained in the central repository 30. The server-side proxy 64 also obtains content to be provided to the client data processing system 50 from server application 62.
As will be appreciated by those of skill in the art, the illustrated system of Figure 2 is simplified for illustration purposes. Thus, for example, the content requested by the client data processing system 50 may be obtained from multiple servers on multiple server data processing systems. Furthermore, the connection between client data processing system 50 and server data processing system 60 need not be direct as is illustrated in Figure 2.
The operations which occur at the client data processing system 50, which may be carried out by the client-side proxy 54 and the operations which occur at the server data processing system 60 which may be carried out by the server-side proxy 64 will now be described with respect to Figures 3 through 5. As seen in Figure 3, when the browser 52 transmits a request, the client-side proxy 54 receives the request and determines if it is the first request for the current session (block 100). If the request is the first request, then it is determined if the client data processing system is capable of and has a preference for performing the content transformation or "tailoring" (i.
e. should content tailoring 1 o occur at the client data processing system 50 or at another data processing system)(block 102). This information, along with other information about the client data processing system 50 and the session, such as for example, data processing capability, available memory, display type and size, resource availability, connection type, priorities for requested information, connection duration, or the like, is incorporated into the request (block 104). Client preferences and other session information (blocks 102 and 104) may reside at the client data processing system 50 or they may be obtained from a server during device initialization, at user logon or with each session. A
user identification, such as a userid, may also be included in the request (block 106). The information added or otherwise contained in the request may collectively be referred to as "session specific information." After incorporating the session specific information in the request, the request is sent to the server-side proxy 64 (block 108).
Returning to block 100 of Figure 3, if the request from the browser 52 is not the first request, then, if the server side stores the previously transmitted session specific information, the only information which would need to be inserted into the request is the user identification and a session identifier to indicate that the previously transmitted session specific information remains valid (block 106). The request with the inserted user identification would then be sent to the server-side proxy (block 108). However, if the server-side proxy 64 does not store information, the session specific information may be added to and sent with each request.
When the request is received from the client data processing system the operations of Figure 4 may be carried out. As is seen in Figure 4, when the request is received, the server-side proxy 64 determines if it is the first request received for the session from the client-side proxy 54 (block 202).
If it is the first request received, then the received parameters (i.e. the session specific information) contained in the request is stored and associated with the user identification in the request (block 204). The server-side proxy 64 also accesses the central repository 30 to retrieve any user preferences associated with the user identification received in the request (block 206). Such user preferences may include, for example, preferences for content, such as the display of images, a home page and home page content, or the like, as well as formatting preferences, such as fonts, limiting displays to an initial screen or only displaying headings. These preferences are then coalesced with any parameters received from the client-side proxy 54 (block 208). The process of coalescing the 1o preferences and received session specific information may involve determining any inconsistencies and selecting a particular preference if inconsistencies do arise. Otherwise, the process may involve determining a single set of preferences from the received session specific information and the obtained preferences.
Server-side proxy 64 also retrieves rules and/or policies for content modification from the central repository 30 (block 210). These rules and/or policies may be retrieved at the same time as the preferences are obtained or they may be retrieved before or after retrieving any preferences. The rules and/or policies and the preferences are stored by the server-side proxy 64 so as to avoid the necessity of retrieving the rules andJor policies and preferences for subsequent requests from the client during the same session (block 208 and block 210).
2o The server-side proxy 64 may then determine if the request should be modified or the server otherwise requested so that the server application 62 provides modified content in response to the request and provides the request to the server 62 (block 200). For example, the server-side proxy 64 could determine that text only responses are appropriate for the request and could modify the request or other server parameters such that the reply from the server was in text only format. It is then determined if the content to be provided to the client has been received by the server-side proxy 64 from the server 62 (block 214). If the reply to the request has not been received, then the server-side proxy 64 waits for the reply (block 214). However, if the reply has been received, then the server-side proxy 64 determines if content modification by the server has been specified by the policies, rules and/or the preferences (block 216). If content modification is specified to be carried out at the server, then the content is modified based on the coalesced preferences/received session specific information and the policies or rules for the user identification of the request (block 218).
Irrespective of whether content modification is to be performed at the server, the server-side proxy 64 also determines if content tailoring or modification is to be performed at the client (block 220). If content modification is to be performed at the client, then the server-side proxy 64 incorporates any information necessary for such modification, such as programs required, etc..., into the response to be provided to the client (block 222). The response is then sent to the client (block 224).
Returning to block 202, if the request is not the first request from the client, then it is determined if more rules are required for the specific request (block 212).
More rules may be required if, for example, rules are associated with specific content requested or with changing operating environment conditions. If more rules are required, then the rules are retrieved and operations continue from block 210 as described above. However, if no more rules are required, then operations continue from block 200 as described above.
When the client-side proxy 54 receives the reply from the server-side proxy 64, the operations of Figure 5 are carried out. The client-side proxy 54 determines if content modification is to be carried out by the client (block 300). Such a determination may be made by inspecting the reply to determine if content modification information has been included with the reply. If no client modification of the content is required then the reply is provided to the browser 52 (block 308).
2o However, if client modification is required by the client, then the client-side proxy 54 determines if additional software programs are required for the content modification (block 302). If additional software programs are required, then the software programs may be downloaded or otherwise acquired by the client-side proxy 54 (block 304). Irrespective of whether additional software programs are required, the client-side proxy modifies the content as specified by the content modification information in the reply to provide final tailored content for the browser 52 (block 306).
This final tailored content is then provided to the browser 52 (block 308).
Thus, the present invention allows for the distribution of content modification (tailoring functions) between the client and the server. These distributions may be based on the predefined policies or rules, user preferences, as well as session specific information.
While the present invention has been described with respect to the addition of session specific information to requests initiated by a client, as will be appreciated by those of skill in the art, if such information is otherwise available, or if the information is not necessary to make decisions with respect to the policies or rules then such information need not be incorporated in requests.
Furthermore, if a client does not have the ability to participate in distributed content tailoring, then the-server side proxy.may make inferences about the client device and perform all the content tailoring that it determines is necessary. Alternatively, requests received by the server-side proxy from such clients could be passed through to the server and conventional content tailoring performed.
While the description of Figures 3 through 5 describes the coalescing of preferences, as will 1o be appreciated by those of skill in the art, the preferences, the policies and/or rules, and the session specific information may be coalesced to provide a single definition for the distribution of content tailoring. Furthermore, while the operations illustrated in Figures 3 through 5 are illustrated in a particular sequence, as will be appreciated by those of skill in the art, the sequence of operations may be varied while still benefiting from the teachings of the present invention.
Accordingly, the present 15 invention should not be construed as limited to the particular sequence or sequences of operations illustrated in the flowchart illustrations.
Furthermore, while the present invention has generally been described with respect to static content, as will be appreciated by those of skill in the art, the present invention may be equally applicable to dynamic web content such as content created by server-side programs interfacing with 2o backend databases and/or applications.
The foregoing is illustrative of the present invention and is not to be construed as limiting thereof. Although a few exemplary embodiments of this invention have been described, those skilled in the art will readily appreciate that many modifications are possible in the exemplary embodiments without materially departing from the novel teachings and advantages of this invention. Accordingly, 25 all such modifications are intended to be included within the scope of this invention as defined in the claims. In the claims, means-plus-function clauses are intended to cover the structures described herein as performing the recited function and not only structural equivalents but also equivalent structures. Therefore, it is to be understood that the foregoing is illustrative of the present invention and is not to be construed as limited to the specific embodiments disclosed, and that modifications to the disclosed embodiments, as well as other embodiments, are intended to be included within the scope of the appended claims. The invention is defined by the following claims, with equivalents of the claims to be included therein.
Claims (49)
1. A method of tailoring content for a session of a first data processing system communicating with a second data processing system, comprising the steps of:
obtaining session specific information from the first data processing system;
and distributing tailoring functions between the first data processing system and the second data processing systems based upon the obtained session specific information.
obtaining session specific information from the first data processing system;
and distributing tailoring functions between the first data processing system and the second data processing systems based upon the obtained session specific information.
2. A method according to Claim 1, wherein the distributing step comprises the steps of:
obtaining policies which control the distribution of tailoring functions between data processing systems based on the session specific information;
distributing tailoring functions between the first data processing system and the second data processing system according to the obtained policies and the session specific information.
obtaining policies which control the distribution of tailoring functions between data processing systems based on the session specific information;
distributing tailoring functions between the first data processing system and the second data processing system according to the obtained policies and the session specific information.
3. A method according to Claim 2, further comprising the steps of:
defining the policies which control the distribution of tailoring functions between data processing systems;
storing the defined policies in a policy repository accessible to the second data processing system; and wherein the step of obtaining policies comprises the step of obtaining policies from the policy repository.
defining the policies which control the distribution of tailoring functions between data processing systems;
storing the defined policies in a policy repository accessible to the second data processing system; and wherein the step of obtaining policies comprises the step of obtaining policies from the policy repository.
4. A method according to Claim 3, further comprising the steps of:
storing user preferences associated with the distribution of content tailoring functions between the first data processing system and data processing systems other than the first data processing system in a preferences repository accessible to the second data processing system;
obtaining the stored user preferences associated with a user of the first data processing system from the preferences repository;
coalescing the session information, the obtained policies and the obtained user preferences so as to define a content tailoring distribution for the session; and wherein the step of distributing tailoring functions between the first data processing system and the second data processing system according to the obtained policies and the session specific information comprises distributing tailoring functions between the first data processing system and the second data processing system according to the defined content tailoring distribution for the session.
storing user preferences associated with the distribution of content tailoring functions between the first data processing system and data processing systems other than the first data processing system in a preferences repository accessible to the second data processing system;
obtaining the stored user preferences associated with a user of the first data processing system from the preferences repository;
coalescing the session information, the obtained policies and the obtained user preferences so as to define a content tailoring distribution for the session; and wherein the step of distributing tailoring functions between the first data processing system and the second data processing system according to the obtained policies and the session specific information comprises distributing tailoring functions between the first data processing system and the second data processing system according to the defined content tailoring distribution for the session.
5. ~A method according to Claim 3, wherein the session specific information comprises information associated with a preference of the first data processing system as to the allocation of content tailoring functions between the first data processing system and data processing systems other than the first data processing system.
6. ~A method according to Claim 3, wherein the session specific information comprises at least one of an identification associated with a user of the first data processing system, hardware configuration information associated with the first data processing system, application information associated with an application executing on the first data processing system and operating system information associated with an operating system executing on the first data processing system.
7. ~A method according to Claim 3, further comprising the steps of:
tailoring content to be provided to the first data processing system, at the second data processing system according to a first content tailoring function specified by the obtained policies and the session specific information so as to provide first tailored content;
and providing the first tailored content to the first data processing system.
tailoring content to be provided to the first data processing system, at the second data processing system according to a first content tailoring function specified by the obtained policies and the session specific information so as to provide first tailored content;
and providing the first tailored content to the first data processing system.
8. ~A method according to Claim 7, further comprising the step of tailoring the first tailored content provided to the first data processing system, at the first data processing system, according to a second content tailoring function specified by the obtained policies and the session specific information so as to provide final tailored content.
9. A method according to Claim 1, further comprising the steps of:
tailoring content to be provided to the first data processing system, at the second data processing system according to a first content tailoring function specified by the obtained session specific information so as to provide first tailored content; and providing the first tailored content to the first data processing system.
tailoring content to be provided to the first data processing system, at the second data processing system according to a first content tailoring function specified by the obtained session specific information so as to provide first tailored content; and providing the first tailored content to the first data processing system.
10. A method of tailoring content provided to a first data processing system communicating with a second data processing system, the method comprising the steps of:
transmitting a request for content from the first data processing system to the second data processing system, wherein the request for content provides information associated with the tailoring of content to be provided to the first data processing system;
obtaining, in response to receiving the request from the first data processing system at the second data processing system, policies associated with the tailoring of content provided to the first data processing system, wherein the policies are further associated with defining the distribution of functions for tailoring content to be provided to the first data processing system between the first data processing system and at least one data processing system other than the first data processing system;
obtaining the content requested by the received request;
tailoring the obtained content utilizing a first tailoring operation, at the at least one data processing system other than the first data processing system, wherein the first tailoring operation is based on the obtained policies and the information provided by the request;
providing the tailored content to the first data processing system; and tailoring the content provided to the first data processing system at the first data processing system based on the obtained policies and the information provided in the request.
transmitting a request for content from the first data processing system to the second data processing system, wherein the request for content provides information associated with the tailoring of content to be provided to the first data processing system;
obtaining, in response to receiving the request from the first data processing system at the second data processing system, policies associated with the tailoring of content provided to the first data processing system, wherein the policies are further associated with defining the distribution of functions for tailoring content to be provided to the first data processing system between the first data processing system and at least one data processing system other than the first data processing system;
obtaining the content requested by the received request;
tailoring the obtained content utilizing a first tailoring operation, at the at least one data processing system other than the first data processing system, wherein the first tailoring operation is based on the obtained policies and the information provided by the request;
providing the tailored content to the first data processing system; and tailoring the content provided to the first data processing system at the first data processing system based on the obtained policies and the information provided in the request.
11. A method according to Claim 10, wherein the information associated with the tailoring of content includes a user identification associated with a user or the first data processing system, the method further comprising the steps of:
storing user preferences associated with the distribution of content tailoring functions between the first data processing system and data processing systems other than the first data processing system in a preferences repository accessible to the second data processing system;
obtaining the stored user preferences associated with the user of the first data processing system from the preferences repository; and wherein the step of tailoring the obtained content utilizing a first tailoring operation, comprises the first tailoring operation based on the obtained policies, the obtained stored user preferences and the information provided by the request.
storing user preferences associated with the distribution of content tailoring functions between the first data processing system and data processing systems other than the first data processing system in a preferences repository accessible to the second data processing system;
obtaining the stored user preferences associated with the user of the first data processing system from the preferences repository; and wherein the step of tailoring the obtained content utilizing a first tailoring operation, comprises the first tailoring operation based on the obtained policies, the obtained stored user preferences and the information provided by the request.
12. The method according to Claim 11, further comprising the step of coalescing user preferences received from the first data processing system with at least one of the obtained policies and the obtained user preferences so as to define a content tailoring distribution for the first data processing system.
13. A method according to Claim 10, further comprising the steps of:
incorporating client content tailoring information into the tailored content to be provided to the first data processing system;
wherein the step of providing the tailored content to the first data processing system, comprises the step of providing the tailored content with the incorporated client content tailoring information to the first data processing system; and wherein the step of tailoring the content provided to the first data processing system at the first data processing system based on the obtained policies and the information provided in the request, comprises the step of tailoring the content provided to the first data processing system at the first data processing system based on the client content tailoring information.
incorporating client content tailoring information into the tailored content to be provided to the first data processing system;
wherein the step of providing the tailored content to the first data processing system, comprises the step of providing the tailored content with the incorporated client content tailoring information to the first data processing system; and wherein the step of tailoring the content provided to the first data processing system at the first data processing system based on the obtained policies and the information provided in the request, comprises the step of tailoring the content provided to the first data processing system at the first data processing system based on the client content tailoring information.
14. A method according to Claim 13, wherein the client content tailoring information specifies a software program associated with the tailoring of content by the first data processing system, the method further comprising the steps of:
obtaining at the first data processing system the software program specified by the client content tailoring information; and executing the software program at the first data processing system.
obtaining at the first data processing system the software program specified by the client content tailoring information; and executing the software program at the first data processing system.
15. ~A method according to Claim 10, wherein the first data processing system is a pervasive computing device.
16. ~A method according to Claim 10, wherein the first data processing system is selected from the group comprising portable computers and desktop computers.
17. ~A method according to Claim 10, wherein the information associated with the tailoring of content comprises at least one of an identification associated with a user of the first data processing system, hardware configuration information associated with the first data processing system, application information associated with an application executing on the first data processing system and operating system information associated with an operating system executing on the first data processing system.
18. ~A system for tailoring content for a session of a first data processing system communicating with a second data processing system, comprising:
means for obtaining session specific information from the first data processing system; and means for distributing tailoring functions between the first data processing system and the second data processing systems based upon the obtained session specific information.
means for obtaining session specific information from the first data processing system; and means for distributing tailoring functions between the first data processing system and the second data processing systems based upon the obtained session specific information.
19. ~A system according to Claim 18, wherein the means for distributing comprises:
means for obtaining policies which control the distribution of tailoring functions between data processing systems based on session specific information;
means for distributing tailoring functions between the first data processing system and the second data processing system according to the obtained policies and the session specific information.
means for obtaining policies which control the distribution of tailoring functions between data processing systems based on session specific information;
means for distributing tailoring functions between the first data processing system and the second data processing system according to the obtained policies and the session specific information.
20. A system according to Claim 19, further comprising:
means for defining the policies which control the distribution of tailoring functions between data processing systems;
means for storing the defined policies in a policy repository accessible to the second data processing system; and wherein the means for obtaining policies comprises means for obtaining policies from the policy repository.
means for defining the policies which control the distribution of tailoring functions between data processing systems;
means for storing the defined policies in a policy repository accessible to the second data processing system; and wherein the means for obtaining policies comprises means for obtaining policies from the policy repository.
21. A system according to Claim 20, further comprising:
means for storing user preferences associated with the distribution of content tailoring functions between the first data processing system and data processing systems other than the first data processing system in a preferences repository accessible to the second data processing system;
means for obtaining the stored user preferences associated with a user of the first data processing system from the preferences repository;
means for coalescing the session information, the obtained policies and the obtained user preferences so as to define a content tailoring distribution for the session;
and wherein the means for distributing tailoring functions between the first data processing system and the second data processing system according to the obtained policies and the session specific information comprises means for distributing tailoring functions between the first data processing system and the second data processing system according to the defined content tailoring distribution for the session.
means for storing user preferences associated with the distribution of content tailoring functions between the first data processing system and data processing systems other than the first data processing system in a preferences repository accessible to the second data processing system;
means for obtaining the stored user preferences associated with a user of the first data processing system from the preferences repository;
means for coalescing the session information, the obtained policies and the obtained user preferences so as to define a content tailoring distribution for the session;
and wherein the means for distributing tailoring functions between the first data processing system and the second data processing system according to the obtained policies and the session specific information comprises means for distributing tailoring functions between the first data processing system and the second data processing system according to the defined content tailoring distribution for the session.
22. A system according to Claim 20, wherein the session specific information comprises information associated with a preference of the first data processing system as to the allocation of content tailoring functions between the first data processing system and data processing systems other than the first data processing system.
23. A system according to Claim 20, wherein the session specific information comprises at least one of an identification associated with a user of the first data processing system, hardware configuration information associated with the first data processing system, application information associated with an application executing on the first data processing system and operating system information associated with an operating system executing on the first data processing system.
24. A system according to Claim 20, further comprising:
means for tailoring content to be provided to the first data processing system, at the second data processing system according to a first content tailoring function specified by the obtained policies and the session specific information so as to provide first tailored content; and means for providing the first tailored content to the first data processing system.
means for tailoring content to be provided to the first data processing system, at the second data processing system according to a first content tailoring function specified by the obtained policies and the session specific information so as to provide first tailored content; and means for providing the first tailored content to the first data processing system.
25. A system according to Claim 24, further comprising means for tailoring the first tailored content provided to the first data processing system, at the first data processing system, according to a second content tailoring function specified by the obtained policies and the session specific information so as to provide final tailored content.
26. A system according to Claim 18, further comprising:
means for tailoring content to be provided to the first data processing system, at the second data processing system according to a first content tailoring function specified by the obtained session specific information so as to provide first tailored content; and means for providing the first tailored content to the first data processing system.
means for tailoring content to be provided to the first data processing system, at the second data processing system according to a first content tailoring function specified by the obtained session specific information so as to provide first tailored content; and means for providing the first tailored content to the first data processing system.
27. A system for tailoring content provided to a first data processing system communicating with a second data processing system, comprising:
means for transmitting a request for content from the first data processing system to the second data processing system, wherein the request for content provides information associated with the tailoring of content to be provided to the first data processing system;
means for obtaining, in response to receiving the request from the first data processing system at the second data processing system, policies associated with the tailoring of content provided to the first data processing system, wherein the policies are further associated with defining the distribution of functions for tailoring content to be provided to the first data processing system between the first data processing system and at least one data processing system other than the first data processing system;
means for obtaining the content requested by the received request;
means for tailoring the obtained content utilizing a first tailoring operation, at the at least one data processing system other than the first data processing system, wherein the first tailoring operation is based on the obtained policies and the information provided by the request;
means for providing the tailored content to the first data processing system;
and means for tailoring the content provided to the first data processing system at the first data processing system based on the obtained policies and the information provided in the request.
means for transmitting a request for content from the first data processing system to the second data processing system, wherein the request for content provides information associated with the tailoring of content to be provided to the first data processing system;
means for obtaining, in response to receiving the request from the first data processing system at the second data processing system, policies associated with the tailoring of content provided to the first data processing system, wherein the policies are further associated with defining the distribution of functions for tailoring content to be provided to the first data processing system between the first data processing system and at least one data processing system other than the first data processing system;
means for obtaining the content requested by the received request;
means for tailoring the obtained content utilizing a first tailoring operation, at the at least one data processing system other than the first data processing system, wherein the first tailoring operation is based on the obtained policies and the information provided by the request;
means for providing the tailored content to the first data processing system;
and means for tailoring the content provided to the first data processing system at the first data processing system based on the obtained policies and the information provided in the request.
28. A system according to Claim 27, wherein the information associated with the tailoring of content includes a user identification associated with a user or the first data processing system, the system further comprising:
means for storing user preferences associated with the distribution of content tailoring functions between the first data processing system and data processing systems other than the first data processing system in a preferences repository accessible to the second data processing system;
means for obtaining the stored user preferences associated with the user of the first data processing system from the preferences repository; and wherein the means for tailoring the obtained content utilizing a first tailoring operation, comprises the first tailoring operation based on the obtained policies, the obtained stored user preferences and the information provided by the request.
means for storing user preferences associated with the distribution of content tailoring functions between the first data processing system and data processing systems other than the first data processing system in a preferences repository accessible to the second data processing system;
means for obtaining the stored user preferences associated with the user of the first data processing system from the preferences repository; and wherein the means for tailoring the obtained content utilizing a first tailoring operation, comprises the first tailoring operation based on the obtained policies, the obtained stored user preferences and the information provided by the request.
29. The system according to Claim 28, further comprising means for coalescing user preferences received from the first data processing system with at least one of the obtained policies and the obtained user preferences so as to define a content tailoring distribution for the first data processing system.
30. A system according to Claim 27, further comprising:
means for incorporating client content tailoring information into the tailored content to be provided to the first data processing system;
wherein the means for providing the tailored content to the first data processing system, comprises means for providing the tailored content with the incorporated client content tailoring information to the first data processing system; and wherein the means for tailoring the content provided to the first data processing system at the first data processing system based on the obtained policies and the information provided in the request, comprises means for tailoring the content provided to the first data processing system at the first data processing system based on the client content tailoring information.
means for incorporating client content tailoring information into the tailored content to be provided to the first data processing system;
wherein the means for providing the tailored content to the first data processing system, comprises means for providing the tailored content with the incorporated client content tailoring information to the first data processing system; and wherein the means for tailoring the content provided to the first data processing system at the first data processing system based on the obtained policies and the information provided in the request, comprises means for tailoring the content provided to the first data processing system at the first data processing system based on the client content tailoring information.
31. A system according to Claim 30, wherein the client content tailoring information specifies a software program associated with the tailoring of content by the first data processing system, the system further comprising:
means for obtaining at the first data processing system the software program specified by the client content tailoring information; and means for executing the software program at the first data processing system.
means for obtaining at the first data processing system the software program specified by the client content tailoring information; and means for executing the software program at the first data processing system.
32. A system according to Claim 27, wherein the first data processing system is a pervasive computing device.
33. A system according to Claim 27, wherein the first data processing system is selected from the group comprising portable computers and desktop computers.
34. A system according to Claim 27, wherein the information associated with the tailoring of content comprises at least one of an identification associated with a user of the first data processing system, hardware configuration information associated with the first data processing system, application information associated with an application executing on the first data processing system and operating system information associated with an operating system executing on the first data processing system.
35. A computer program product for tailoring content for a session of a first data processing system communicating with a second data processing system, comprising:
a computer readable storage medium having computer readable program code means embodied in said medium, said computer readable program code means comprising:
computer-readable program code means for obtaining session specific information from the first data processing system; and computer-readable program code means for distributing tailoring functions between the first data processing system and the second data processing systems based upon the obtained session specific information.
a computer readable storage medium having computer readable program code means embodied in said medium, said computer readable program code means comprising:
computer-readable program code means for obtaining session specific information from the first data processing system; and computer-readable program code means for distributing tailoring functions between the first data processing system and the second data processing systems based upon the obtained session specific information.
36. A computer program product according to Claim 3 5, wherein the computer-readable program code means for distributing comprises:
computer-readable program code means for obtaining policies which control the distribution of tailoring functions between data processing systems based on session specific information;
computer-readable program code means for distributing tailoring functions between the first data processing system and the second data processing system according to the obtained policies and the session specific information.
computer-readable program code means for obtaining policies which control the distribution of tailoring functions between data processing systems based on session specific information;
computer-readable program code means for distributing tailoring functions between the first data processing system and the second data processing system according to the obtained policies and the session specific information.
37. A computer program product according to Claim 36, further comprising:
computer-readable program code means for defining the policies which control the distribution of tailoring functions between data processing systems;
computer-readable program code means for storing the defined policies in a policy repository accessible to the second data processing system; and wherein the computer-readable program code means for obtaining policies comprises computer-readable program code means for obtaining policies from the policy repository.
computer-readable program code means for defining the policies which control the distribution of tailoring functions between data processing systems;
computer-readable program code means for storing the defined policies in a policy repository accessible to the second data processing system; and wherein the computer-readable program code means for obtaining policies comprises computer-readable program code means for obtaining policies from the policy repository.
38. A computer program product according to Claim 37, further comprising:
computer-readable program code means for storing user preferences associated with the distribution of content tailoring functions between the first data processing system and data processing systems other than the first data processing system in a preferences repository accessible to the second data processing system;
computer-readable program code means for obtaining the stored user preferences associated with a user of the first data processing system from the preferences repository;
computer-readable program code means for coalescing the session information, the obtained policies and the obtained user preferences so as to define a content tailoring distribution for the session; and wherein the computer-readable program code means for distributing tailoring functions between the first data processing system and the second data processing system according to the obtained policies and the session specific information comprises computer-readable program code means for distributing tailoring functions between the first data processing system and the second data processing system according to the defined content tailoring distribution for the session.
computer-readable program code means for storing user preferences associated with the distribution of content tailoring functions between the first data processing system and data processing systems other than the first data processing system in a preferences repository accessible to the second data processing system;
computer-readable program code means for obtaining the stored user preferences associated with a user of the first data processing system from the preferences repository;
computer-readable program code means for coalescing the session information, the obtained policies and the obtained user preferences so as to define a content tailoring distribution for the session; and wherein the computer-readable program code means for distributing tailoring functions between the first data processing system and the second data processing system according to the obtained policies and the session specific information comprises computer-readable program code means for distributing tailoring functions between the first data processing system and the second data processing system according to the defined content tailoring distribution for the session.
39. A computer program product according to Claim 37, wherein the session specific information comprises information associated with a preference of the first data processing system as to the allocation of content tailoring functions between the first data processing system and data processing systems other than the first data processing system.
40. A computer program product according to Claim 37, wherein the session specific information comprises at least one of an identification associated with a user of the first data processing system, hardware configuration information associated with the first data processing system, application information associated with an application executing on the first data processing system and operating system information associated with an operating system executing on the first data processing system.
41. A computer program product according to Claim 37, further comprising:
computer-readable program code means for tailoring content to be provided to the first data processing system, at the second data processing system according to a first content tailoring function specified by the obtained policies and the session specific information so as to provide first tailored content; and computer-readable program code means for providing the first tailored content to the first data processing system.
computer-readable program code means for tailoring content to be provided to the first data processing system, at the second data processing system according to a first content tailoring function specified by the obtained policies and the session specific information so as to provide first tailored content; and computer-readable program code means for providing the first tailored content to the first data processing system.
42. A computer program product according to Claim 41, further comprising computer-readable program code means for tailoring the first tailored content provided to the first data processing system, at the first data processing system, according to a second content tailoring function specified by the obtained policies and the session specific information so as to provide final tailored content.
43. A computer program product according to Claim 35, further comprising:
computer-readable program code means for tailoring content to be provided to the first data processing system, at the second data processing system according to a first content tailoring function specified by the obtained session specific information so as to provide first tailored content;
and computer-readable program code means for providing the first tailored content to the first data processing system.
computer-readable program code means for tailoring content to be provided to the first data processing system, at the second data processing system according to a first content tailoring function specified by the obtained session specific information so as to provide first tailored content;
and computer-readable program code means for providing the first tailored content to the first data processing system.
44. A computer program product for tailoring content provided to a first data processing system communicating with a second data processing system, comprising:
a computer readable storage medium having computer readable program code means embodied in said medium, said computer readable program code means comprising:
computer-readable program code means for transmitting a request for content from the first data processing system to the second data processing system, wherein the request for content provides information associated with the tailoring of content to be provided to the first data processing system;
computer-readable program code means for obtaining, in response to receiving the request from the first data processing system at the second data processing system, policies associated with the tailoring of content provided to the first data processing system, wherein the policies are further associated with defining the distribution of functions for tailoring content to be provided to the first data processing system between the first data processing system and at least one data processing system other than the first data processing system;
computer-readable program code means for obtaining the content requested by the received request;
computer-readable program code means for tailoring the obtained content utilizing a first tailoring operation, at the at least one data processing system other than the first data processing system, wherein the first tailoring operation is based on the obtained policies and the information provided by the request;
computer-readable program code means for providing the tailored content to the first data processing system; and computer-readable program code means for tailoring the content provided to the first data processing system at the first data processing system based on the obtained policies and the information provided in the request.
a computer readable storage medium having computer readable program code means embodied in said medium, said computer readable program code means comprising:
computer-readable program code means for transmitting a request for content from the first data processing system to the second data processing system, wherein the request for content provides information associated with the tailoring of content to be provided to the first data processing system;
computer-readable program code means for obtaining, in response to receiving the request from the first data processing system at the second data processing system, policies associated with the tailoring of content provided to the first data processing system, wherein the policies are further associated with defining the distribution of functions for tailoring content to be provided to the first data processing system between the first data processing system and at least one data processing system other than the first data processing system;
computer-readable program code means for obtaining the content requested by the received request;
computer-readable program code means for tailoring the obtained content utilizing a first tailoring operation, at the at least one data processing system other than the first data processing system, wherein the first tailoring operation is based on the obtained policies and the information provided by the request;
computer-readable program code means for providing the tailored content to the first data processing system; and computer-readable program code means for tailoring the content provided to the first data processing system at the first data processing system based on the obtained policies and the information provided in the request.
45. A computer program product according to Claim 44, wherein the information associated with the tailoring of content includes a user identification associated with a user or the first data processing system, the computer program product further comprising:
computer-readable program code means for storing user preferences associated with the distribution of content tailoring functions between the first data processing system and data processing systems other than the first data processing system in a preferences repository accessible to the second data processing system;
computer-readable program code means for obtaining the stored user preferences associated with the user of the first data processing system from the preferences repository; and wherein the computer-readable program code means for tailoring the obtained content utilizing a first tailoring operation, comprises computer-readable program code means for tailoring the obtained content utilizing a first tailoring operation, wherein the first tailoring operation is based on the obtained policies, the obtained stored user preferences and the information provided by the request.
computer-readable program code means for storing user preferences associated with the distribution of content tailoring functions between the first data processing system and data processing systems other than the first data processing system in a preferences repository accessible to the second data processing system;
computer-readable program code means for obtaining the stored user preferences associated with the user of the first data processing system from the preferences repository; and wherein the computer-readable program code means for tailoring the obtained content utilizing a first tailoring operation, comprises computer-readable program code means for tailoring the obtained content utilizing a first tailoring operation, wherein the first tailoring operation is based on the obtained policies, the obtained stored user preferences and the information provided by the request.
46. The computer program product according to Claim 45, further comprising computer-readable program code means for coalescing user preferences received from the first data processing system with at least one of the obtained policies and the obtained user preferences so as to define a content tailoring distribution for the first data processing system.
47. A computer program product according to Claim 44, further comprising:
computer-readable program code means for incorporating client content tailoring information into the tailored content to be provided to the first data processing system;
wherein the computer-readable program code means for providing the tailored content to the first data processing system, comprises computer-readable program code means for providing the tailored content with the incorporated client content tailoring information to the first data processing system; and wherein the computer-readable program code means for tailoring the content provided to the first data processing system at the first data processing system based on the obtained policies and the information provided in the request, comprises computer-readable program code means for tailoring the content provided to the first data processing system at the first data processing system based on the client content tailoring information.
computer-readable program code means for incorporating client content tailoring information into the tailored content to be provided to the first data processing system;
wherein the computer-readable program code means for providing the tailored content to the first data processing system, comprises computer-readable program code means for providing the tailored content with the incorporated client content tailoring information to the first data processing system; and wherein the computer-readable program code means for tailoring the content provided to the first data processing system at the first data processing system based on the obtained policies and the information provided in the request, comprises computer-readable program code means for tailoring the content provided to the first data processing system at the first data processing system based on the client content tailoring information.
48. A computer program product according to Claim 47, wherein the client content tailoring information specifies a software program associated with the tailoring of content by the first data processing system, the computer program product further comprising:
computer-readable program code means for obtaining at the first data processing system the software program specified by the client content tailoring information; and computer-readable program code means for executing the software program at the first data processing system.
computer-readable program code means for obtaining at the first data processing system the software program specified by the client content tailoring information; and computer-readable program code means for executing the software program at the first data processing system.
49. A computer program product according to Claim 44, wherein the information associated with the tailoring of content comprises at least one of an identification associated with a user of the first data processing system, hardware configuration information associated with the first data processing system, application information associated with an application executing on the first data processing system and operating system information associated with an operating system executing on the first data processing system.
Applications Claiming Priority (2)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
US09/237,544 US6654814B1 (en) | 1999-01-26 | 1999-01-26 | Systems, methods and computer program products for dynamic placement of web content tailoring |
US09/237,544 | 1999-01-26 |
Publications (2)
Publication Number | Publication Date |
---|---|
CA2292327A1 CA2292327A1 (en) | 2000-07-26 |
CA2292327C true CA2292327C (en) | 2005-09-27 |
Family
ID=22894190
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
CA002292327A Expired - Fee Related CA2292327C (en) | 1999-01-26 | 1999-12-16 | Systems, methods and computer program products for dynamic placement of web content tailoring |
Country Status (5)
Country | Link |
---|---|
US (1) | US6654814B1 (en) |
JP (1) | JP2000222274A (en) |
KR (1) | KR20000053468A (en) |
CA (1) | CA2292327C (en) |
GB (1) | GB2348525B (en) |
Families Citing this family (145)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US6775264B1 (en) | 1997-03-03 | 2004-08-10 | Webley Systems, Inc. | Computer, internet and telecommunications based network |
WO2001018597A1 (en) * | 1999-09-07 | 2001-03-15 | Hitachi, Ltd | Liquid crystal display device |
US6687745B1 (en) | 1999-09-14 | 2004-02-03 | Droplet, Inc | System and method for delivering a graphical user interface of remote applications over a thin bandwidth connection |
WO2001029727A2 (en) * | 1999-10-21 | 2001-04-26 | Adfluence, Inc. | Network methods for interactive advertising and direct marketing |
JP2001188835A (en) * | 1999-12-28 | 2001-07-10 | Hitachi Ltd | Service providing system |
AU2001234620A1 (en) * | 2000-01-28 | 2001-08-07 | Ibeam Broadcasting Corporation | Method and apparatus for client-side authentication and stream selection in a content distribution system |
US6633314B1 (en) * | 2000-02-02 | 2003-10-14 | Raja Tuli | Portable high speed internet device integrating cellular telephone and palm top computer |
US8046795B2 (en) * | 2000-02-03 | 2011-10-25 | Sony Corporation | Method and system for directing the generation of a video media event in a generation system based on a media event protocol file such that the video media event remains visible at a predetermined location in a second web page while a user navigates from a first web page to the second web page which does not refer to the video media event |
US6721705B2 (en) | 2000-02-04 | 2004-04-13 | Webley Systems, Inc. | Robust voice browser system and voice activated device controller |
US7516190B2 (en) | 2000-02-04 | 2009-04-07 | Parus Holdings, Inc. | Personal voice-based information retrieval system |
FR2805651B1 (en) * | 2000-02-24 | 2002-09-13 | Eastman Kodak Co | METHOD AND DEVICE FOR PRESENTING DIGITAL IMAGES ON A LOW DEFINITION SCREEN |
US7032011B2 (en) | 2000-03-29 | 2006-04-18 | Symantec Corporation | Server based extraction, transfer, storage and processing of remote settings, files and data |
US6963908B1 (en) | 2000-03-29 | 2005-11-08 | Symantec Corporation | System for transferring customized hardware and software settings from one computer to another computer to provide personalized operating environments |
US20020032754A1 (en) * | 2000-04-05 | 2002-03-14 | Gary Logston | Method and apparatus for profiling in a distributed application environment |
US20020123334A1 (en) * | 2000-05-09 | 2002-09-05 | Dana Borger | Systems, methods and computer program products for dynamically inserting content into web documents for display by client devices |
US7177904B1 (en) | 2000-05-18 | 2007-02-13 | Stratify, Inc. | Techniques for sharing content information with members of a virtual user group in a network environment without compromising user privacy |
EP1172722A3 (en) * | 2000-07-12 | 2003-08-06 | Matsushita Electric Industrial Co., Ltd. | Display device |
AU2001265319A1 (en) * | 2000-09-13 | 2002-03-26 | Smartserv Online, Inc. | Method and apparatus for providing device-specific formatted data to a plurality of browser-enabled devices |
US7774455B1 (en) | 2000-09-26 | 2010-08-10 | Juniper Networks, Inc. | Method and system for providing secure access to private networks |
US7210100B2 (en) * | 2000-09-27 | 2007-04-24 | Eizel Technologies, Inc. | Configurable transformation of electronic documents |
US8676921B1 (en) * | 2000-10-03 | 2014-03-18 | Nokia Corporation | Contextual mapping based learning by converting information |
US7093017B1 (en) | 2000-10-24 | 2006-08-15 | Litepoint, Corp. | System, method and article of manufacture for facilitating user interface roaming in an interface roaming network framework |
US6970939B2 (en) * | 2000-10-26 | 2005-11-29 | Intel Corporation | Method and apparatus for large payload distribution in a network |
US7620719B2 (en) | 2002-06-06 | 2009-11-17 | Juniper Networks, Inc. | Method and system for providing secure access to private networks |
US20020059463A1 (en) * | 2000-11-10 | 2002-05-16 | Leonid Goldstein | Method and system for accelerating internet access through data compression |
US20020065920A1 (en) * | 2000-11-30 | 2002-05-30 | Siegel Brian M. | Host site based internet traffic meter |
US20020073235A1 (en) * | 2000-12-11 | 2002-06-13 | Chen Steve X. | System and method for content distillation |
US20020111972A1 (en) * | 2000-12-15 | 2002-08-15 | Virtual Access Networks. Inc. | Virtual access |
SE518751C2 (en) * | 2001-01-03 | 2002-11-19 | Microsoft Corp | Method and system where an external server receives information on individual mobile terminals' radio transmission capacity |
US7221370B1 (en) | 2001-01-26 | 2007-05-22 | Palmsource, Inc. | Adaptive content delivery |
WO2002063495A1 (en) * | 2001-02-06 | 2002-08-15 | Airclic, Inc. | Device-independent content acquisition and presentation |
US8392586B2 (en) * | 2001-05-15 | 2013-03-05 | Hewlett-Packard Development Company, L.P. | Method and apparatus to manage transactions at a network storage device |
JP4390405B2 (en) * | 2001-05-31 | 2009-12-24 | 富士通株式会社 | Computer system, service layer, policy cache function unit, and policy management device |
US8010702B2 (en) * | 2001-06-14 | 2011-08-30 | Nokia Corporation | Feature-based device description and content annotation |
JP3880337B2 (en) * | 2001-07-03 | 2007-02-14 | 富士通株式会社 | Content conversion method and converted content acquisition method |
US8301503B2 (en) * | 2001-07-17 | 2012-10-30 | Incucomm, Inc. | System and method for providing requested information to thin clients |
US20030063122A1 (en) * | 2001-07-27 | 2003-04-03 | Cichowlas Bruce William | Method, system, and computer program product for developing and using stateful web applications |
JP2003069559A (en) * | 2001-08-23 | 2003-03-07 | Sony Corp | Content protection system |
US7171624B2 (en) * | 2001-10-05 | 2007-01-30 | International Business Machines Corporation | User interface architecture for storage area network |
US7325237B2 (en) * | 2001-12-29 | 2008-01-29 | Hewlett-Packard Development Company, L.P. | System having customization modules to provide customizations |
JP2004014943A (en) | 2002-06-10 | 2004-01-15 | Sony Corp | Multibeam semiconductor laser, semiconductor light emitting device, and semiconductor device |
US7278117B2 (en) * | 2002-07-02 | 2007-10-02 | Hewlett-Packard Development Company, L.P. | Image segmentation and warping for specialized display viewing |
US20040006638A1 (en) * | 2002-07-08 | 2004-01-08 | Lewis Oberlander | Method and apparatus for communication control using adaptive throttling |
US20040012627A1 (en) * | 2002-07-17 | 2004-01-22 | Sany Zakharia | Configurable browser for adapting content to diverse display types |
US8417678B2 (en) * | 2002-07-30 | 2013-04-09 | Storediq, Inc. | System, method and apparatus for enterprise policy management |
US8612404B2 (en) * | 2002-07-30 | 2013-12-17 | Stored Iq, Inc. | Harvesting file system metsdata |
US7801894B1 (en) | 2004-10-28 | 2010-09-21 | Stored IQ | Method and apparatus for harvesting file system metadata |
WO2004012379A2 (en) * | 2002-07-30 | 2004-02-05 | Deepfile Corporation | Method and apparatus for managing file systems and file-based data storage |
US7761505B2 (en) * | 2002-11-18 | 2010-07-20 | Openpeak Inc. | System, method and computer program product for concurrent performance of video teleconference and delivery of multimedia presentation and archiving of same |
US8176428B2 (en) | 2002-12-03 | 2012-05-08 | Datawind Net Access Corporation | Portable internet access device back page cache |
WO2004068873A2 (en) * | 2003-01-27 | 2004-08-12 | Tailwind Solutions, Inc. | Distributed application infrastructure |
US7202684B2 (en) * | 2003-03-13 | 2007-04-10 | Intel Corporation | Thermal stratification test apparatus and method providing cyclical and steady-state stratified environments |
KR20050026673A (en) * | 2003-09-09 | 2005-03-15 | 삼성전자주식회사 | System for downloading contents via network |
US7716372B2 (en) * | 2003-06-30 | 2010-05-11 | At&T Intellectual Property, I, L.P. | Method, system and storage medium for providing services based on user preferences |
US20050015365A1 (en) * | 2003-07-16 | 2005-01-20 | Kavacheri Sathyanarayanan N. | Hierarchical configuration attribute storage and retrieval |
US7895523B2 (en) * | 2003-09-04 | 2011-02-22 | International Business Machines Corporation | Method, system and program product for obscuring supplemental web content |
US7844582B1 (en) | 2004-10-28 | 2010-11-30 | Stored IQ | System and method for involving users in object management |
US8510331B1 (en) | 2004-10-28 | 2013-08-13 | Storediq, Inc. | System and method for a desktop agent for use in managing file systems |
EP1703451A1 (en) * | 2005-03-18 | 2006-09-20 | Sap Ag | A data processing system and method of calculating a distribution |
US8291095B2 (en) * | 2005-04-20 | 2012-10-16 | Limelight Networks, Inc. | Methods and systems for content insertion |
US8738787B2 (en) | 2005-04-20 | 2014-05-27 | Limelight Networks, Inc. | Ad server integration |
CN1855095A (en) * | 2005-04-27 | 2006-11-01 | 国际商业机器公司 | System, method and engine for playing multimedia content based on SMIL |
US20060288015A1 (en) * | 2005-06-15 | 2006-12-21 | Schirripa Steven R | Electronic content classification |
US9092928B2 (en) | 2005-07-01 | 2015-07-28 | The Invention Science Fund I, Llc | Implementing group content substitution in media works |
US9065979B2 (en) | 2005-07-01 | 2015-06-23 | The Invention Science Fund I, Llc | Promotional placement in media works |
US8203609B2 (en) | 2007-01-31 | 2012-06-19 | The Invention Science Fund I, Llc | Anonymization pursuant to a broadcasted policy |
US20080028422A1 (en) * | 2005-07-01 | 2008-01-31 | Searete Llc, A Limited Liability Corporation Of The State Of Delaware | Implementation of media content alteration |
US9583141B2 (en) | 2005-07-01 | 2017-02-28 | Invention Science Fund I, Llc | Implementing audio substitution options in media works |
US8910033B2 (en) | 2005-07-01 | 2014-12-09 | The Invention Science Fund I, Llc | Implementing group content substitution in media works |
US7860342B2 (en) | 2005-07-01 | 2010-12-28 | The Invention Science Fund I, Llc | Modifying restricted images |
US9426387B2 (en) | 2005-07-01 | 2016-08-23 | Invention Science Fund I, Llc | Image anonymization |
US9230601B2 (en) | 2005-07-01 | 2016-01-05 | Invention Science Fund I, Llc | Media markup system for content alteration in derivative works |
US8732087B2 (en) | 2005-07-01 | 2014-05-20 | The Invention Science Fund I, Llc | Authorization for media content alteration |
US8380855B2 (en) * | 2005-12-12 | 2013-02-19 | Answer Financial, Inc. | HTTP header intermediary for enabling session-based dynamic site searches |
US20070256019A1 (en) * | 2006-04-14 | 2007-11-01 | Hirsave Praveen P K | Display Sharing Preference System |
US8498497B2 (en) * | 2006-11-17 | 2013-07-30 | Microsoft Corporation | Swarm imaging |
US7913264B2 (en) * | 2007-02-22 | 2011-03-22 | Amadeus Sas | Remote customisation module and system comprising said module |
US9215512B2 (en) | 2007-04-27 | 2015-12-15 | Invention Science Fund I, Llc | Implementation of media content alteration |
US9043935B2 (en) * | 2007-05-18 | 2015-05-26 | Novell, Inc. | Techniques for personalizing content |
US8850029B2 (en) * | 2008-02-14 | 2014-09-30 | Mcafee, Inc. | System, method, and computer program product for managing at least one aspect of a connection based on application behavior |
US8275830B2 (en) | 2009-01-28 | 2012-09-25 | Headwater Partners I Llc | Device assisted CDR creation, aggregation, mediation and billing |
US8725123B2 (en) | 2008-06-05 | 2014-05-13 | Headwater Partners I Llc | Communications device with secure data path processing agents |
US8391834B2 (en) | 2009-01-28 | 2013-03-05 | Headwater Partners I Llc | Security techniques for device assisted services |
US8924543B2 (en) | 2009-01-28 | 2014-12-30 | Headwater Partners I Llc | Service design center for device assisted services |
US8898293B2 (en) | 2009-01-28 | 2014-11-25 | Headwater Partners I Llc | Service offer set publishing to device agent with on-device service selection |
US8340634B2 (en) | 2009-01-28 | 2012-12-25 | Headwater Partners I, Llc | Enhanced roaming services and converged carrier networks with device assisted services and a proxy |
US8402111B2 (en) | 2009-01-28 | 2013-03-19 | Headwater Partners I, Llc | Device assisted services install |
US8589541B2 (en) | 2009-01-28 | 2013-11-19 | Headwater Partners I Llc | Device-assisted services for protecting network capacity |
US8548428B2 (en) | 2009-01-28 | 2013-10-01 | Headwater Partners I Llc | Device group partitions and settlement platform |
US8626115B2 (en) | 2009-01-28 | 2014-01-07 | Headwater Partners I Llc | Wireless network service interfaces |
US8406748B2 (en) | 2009-01-28 | 2013-03-26 | Headwater Partners I Llc | Adaptive ambient services |
US8924469B2 (en) | 2008-06-05 | 2014-12-30 | Headwater Partners I Llc | Enterprise access control and accounting allocation for access networks |
US8346225B2 (en) | 2009-01-28 | 2013-01-01 | Headwater Partners I, Llc | Quality of service for device assisted services |
US8331901B2 (en) | 2009-01-28 | 2012-12-11 | Headwater Partners I, Llc | Device assisted ambient services |
US8635335B2 (en) | 2009-01-28 | 2014-01-21 | Headwater Partners I Llc | System and method for wireless network offloading |
US8832777B2 (en) | 2009-03-02 | 2014-09-09 | Headwater Partners I Llc | Adapting network policies based on device service processor configuration |
US20100057830A1 (en) * | 2008-08-26 | 2010-03-04 | Nokia Corporation | Controlling Client-Server Communications |
US8051110B2 (en) * | 2008-11-10 | 2011-11-01 | International Business Machines Corporation | Identifying screen flows to support multiple entities and their diverse rules with a single application instance |
US11218854B2 (en) | 2009-01-28 | 2022-01-04 | Headwater Research Llc | Service plan design, user interfaces, application programming interfaces, and device management |
US8893009B2 (en) | 2009-01-28 | 2014-11-18 | Headwater Partners I Llc | End user device that secures an association of application to service policy with an application certificate check |
US9572019B2 (en) | 2009-01-28 | 2017-02-14 | Headwater Partners LLC | Service selection set published to device agent with on-device service selection |
US9571559B2 (en) | 2009-01-28 | 2017-02-14 | Headwater Partners I Llc | Enhanced curfew and protection associated with a device group |
US10237757B2 (en) | 2009-01-28 | 2019-03-19 | Headwater Research Llc | System and method for wireless network offloading |
US10798252B2 (en) | 2009-01-28 | 2020-10-06 | Headwater Research Llc | System and method for providing user notifications |
US9647918B2 (en) | 2009-01-28 | 2017-05-09 | Headwater Research Llc | Mobile device and method attributing media services network usage to requesting application |
US9565707B2 (en) | 2009-01-28 | 2017-02-07 | Headwater Partners I Llc | Wireless end-user device with wireless data attribution to multiple personas |
US9955332B2 (en) | 2009-01-28 | 2018-04-24 | Headwater Research Llc | Method for child wireless device activation to subscriber account of a master wireless device |
US10200541B2 (en) | 2009-01-28 | 2019-02-05 | Headwater Research Llc | Wireless end-user device with divided user space/kernel space traffic policy system |
US10326800B2 (en) | 2009-01-28 | 2019-06-18 | Headwater Research Llc | Wireless network service interfaces |
US10057775B2 (en) | 2009-01-28 | 2018-08-21 | Headwater Research Llc | Virtualized policy and charging system |
US10484858B2 (en) | 2009-01-28 | 2019-11-19 | Headwater Research Llc | Enhanced roaming services and converged carrier networks with device assisted services and a proxy |
US9557889B2 (en) | 2009-01-28 | 2017-01-31 | Headwater Partners I Llc | Service plan design, user interfaces, application programming interfaces, and device management |
US9980146B2 (en) | 2009-01-28 | 2018-05-22 | Headwater Research Llc | Communications device with secure data path processing agents |
US9578182B2 (en) | 2009-01-28 | 2017-02-21 | Headwater Partners I Llc | Mobile device and service management |
US9351193B2 (en) | 2009-01-28 | 2016-05-24 | Headwater Partners I Llc | Intermediate networking devices |
US10783581B2 (en) | 2009-01-28 | 2020-09-22 | Headwater Research Llc | Wireless end-user device providing ambient or sponsored services |
US10064055B2 (en) | 2009-01-28 | 2018-08-28 | Headwater Research Llc | Security, fraud detection, and fraud mitigation in device-assisted services systems |
US9253663B2 (en) | 2009-01-28 | 2016-02-02 | Headwater Partners I Llc | Controlling mobile device communications on a roaming network based on device state |
US9392462B2 (en) | 2009-01-28 | 2016-07-12 | Headwater Partners I Llc | Mobile end-user device with agent limiting wireless data communication for specified background applications based on a stored policy |
US9858559B2 (en) | 2009-01-28 | 2018-01-02 | Headwater Research Llc | Network service plan design |
US10248996B2 (en) | 2009-01-28 | 2019-04-02 | Headwater Research Llc | Method for operating a wireless end-user device mobile payment agent |
US9706061B2 (en) | 2009-01-28 | 2017-07-11 | Headwater Partners I Llc | Service design center for device assisted services |
US10715342B2 (en) | 2009-01-28 | 2020-07-14 | Headwater Research Llc | Managing service user discovery and service launch object placement on a device |
US9755842B2 (en) | 2009-01-28 | 2017-09-05 | Headwater Research Llc | Managing service user discovery and service launch object placement on a device |
US9270559B2 (en) | 2009-01-28 | 2016-02-23 | Headwater Partners I Llc | Service policy implementation for an end-user device having a control application or a proxy agent for routing an application traffic flow |
US10264138B2 (en) | 2009-01-28 | 2019-04-16 | Headwater Research Llc | Mobile device and service management |
US8793758B2 (en) | 2009-01-28 | 2014-07-29 | Headwater Partners I Llc | Security, fraud detection, and fraud mitigation in device-assisted services systems |
US10492102B2 (en) | 2009-01-28 | 2019-11-26 | Headwater Research Llc | Intermediate networking devices |
US8606911B2 (en) | 2009-03-02 | 2013-12-10 | Headwater Partners I Llc | Flow tagging for service policy implementation |
US10841839B2 (en) | 2009-01-28 | 2020-11-17 | Headwater Research Llc | Security, fraud detection, and fraud mitigation in device-assisted services systems |
US10779177B2 (en) | 2009-01-28 | 2020-09-15 | Headwater Research Llc | Device group partitions and settlement platform |
US8745191B2 (en) | 2009-01-28 | 2014-06-03 | Headwater Partners I Llc | System and method for providing user notifications |
US9954975B2 (en) | 2009-01-28 | 2018-04-24 | Headwater Research Llc | Enhanced curfew and protection associated with a device group |
CN101996093A (en) * | 2009-08-10 | 2011-03-30 | 日电(中国)有限公司 | Method and system for converting desktop application to network application |
US20110154225A1 (en) * | 2009-12-21 | 2011-06-23 | Research In Motion Limited | Method and device to modify an electronic document from a mobile environment with server assistance |
US8880594B2 (en) * | 2010-11-29 | 2014-11-04 | Hughes Network Systems, Llc | Computer networking system and method with Javascript execution for pre-fetching content from dynamically-generated URL |
US9154826B2 (en) | 2011-04-06 | 2015-10-06 | Headwater Partners Ii Llc | Distributing content and service launch objects to mobile devices |
US9594846B2 (en) * | 2011-08-11 | 2017-03-14 | Helwett-Packard Development Company, L.P. | Client side caching |
US20130339334A1 (en) * | 2012-06-15 | 2013-12-19 | Microsoft Corporation | Personalized search engine results |
WO2014159862A1 (en) | 2013-03-14 | 2014-10-02 | Headwater Partners I Llc | Automated credential porting for mobile devices |
KR102067276B1 (en) * | 2013-05-30 | 2020-02-11 | 삼성전자주식회사 | Apparatus and method for executing application |
US20150046419A1 (en) * | 2013-08-12 | 2015-02-12 | Vidmind Ltd. | Method of sorting search results by recommendation engine |
US11602656B2 (en) | 2017-05-02 | 2023-03-14 | Kyndryl, Inc. | Cognitive solution to enhance firefighting capabilities |
US10867005B1 (en) * | 2018-12-10 | 2020-12-15 | Amazon Technologies, Inc. | Dynamic content caching and rendering system |
US10924534B2 (en) | 2019-03-01 | 2021-02-16 | Akamai Technologies, Inc. | Dynamic placement of computing tasks in a distributed computing environment |
Family Cites Families (47)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
JPH02143762A (en) * | 1988-11-25 | 1990-06-01 | Nec Corp | Image data transfer system |
JPH07152668A (en) * | 1993-11-26 | 1995-06-16 | Canon Inc | Information processor and communication method |
US5717923A (en) * | 1994-11-03 | 1998-02-10 | Intel Corporation | Method and apparatus for dynamically customizing electronic information to individual end users |
US5737592A (en) | 1995-06-19 | 1998-04-07 | International Business Machines Corporation | Accessing a relational database over the Internet using macro language files |
US5706434A (en) * | 1995-07-06 | 1998-01-06 | Electric Classifieds, Inc. | Integrated request-response system and method generating responses to request objects formatted according to various communication protocols |
JP3885236B2 (en) | 1995-10-11 | 2007-02-21 | ソニー株式会社 | Portable communication terminal |
US5740430A (en) * | 1995-11-06 | 1998-04-14 | C/Net, Inc. | Method and apparatus for server-independent caching of dynamically-generated customized pages |
GB2309558A (en) | 1996-01-26 | 1997-07-30 | Ibm | Load balancing across the processors of a server computer |
US5727159A (en) * | 1996-04-10 | 1998-03-10 | Kikinis; Dan | System in which a Proxy-Server translates information received from the Internet into a form/format readily usable by low power portable computers |
JPH09237233A (en) | 1996-02-29 | 1997-09-09 | Toshiba Corp | Communication system and data communication method |
US5764235A (en) * | 1996-03-25 | 1998-06-09 | Insight Development Corporation | Computer implemented method and system for transmitting graphical images from server to client at user selectable resolution |
US5754772A (en) | 1996-03-26 | 1998-05-19 | Unisys Corporation | Transaction service independent HTTP server-to-transaction gateway |
US5835712A (en) | 1996-05-03 | 1998-11-10 | Webmate Technologies, Inc. | Client-server system using embedded hypertext tags for application and database development |
JP3861318B2 (en) | 1996-05-14 | 2006-12-20 | 株式会社日立製作所 | Information provision method |
JP3471523B2 (en) | 1996-05-21 | 2003-12-02 | インターナショナル・ビジネス・マシーンズ・コーポレーション | Communication method and communication terminal |
US5727950A (en) | 1996-05-22 | 1998-03-17 | Netsage Corporation | Agent based instruction system and method |
JP3576317B2 (en) | 1996-07-05 | 2004-10-13 | 株式会社エヌ・ティ・ティ・データ | Communication method and apparatus, communication system |
FI102923B (en) * | 1996-08-08 | 1999-03-15 | Nokia Mobile Phones Ltd | Information printing system, procedure for printing information and terminals for printing information |
JPH1074137A (en) * | 1996-08-30 | 1998-03-17 | Hitachi Ltd | Graphic user interface change system |
TW347498B (en) | 1996-09-30 | 1998-12-11 | Casio Computer Co Ltd | Information supply system |
JPH10124518A (en) | 1996-10-17 | 1998-05-15 | Nec Corp | Preferential access web blousing processor |
JP3683051B2 (en) * | 1996-10-18 | 2005-08-17 | 三菱電機株式会社 | Data transmission method |
US5790790A (en) | 1996-10-24 | 1998-08-04 | Tumbleweed Software Corporation | Electronic document delivery system in which notification of said electronic document is sent to a recipient thereof |
JPH10133973A (en) | 1996-10-31 | 1998-05-22 | Hitachi Ltd | Html information providing method |
JPH10171822A (en) | 1996-12-09 | 1998-06-26 | Nippon Telegr & Teleph Corp <Ntt> | Media adapted information sharing device |
US6065059A (en) * | 1996-12-10 | 2000-05-16 | International Business Machines Corporation | Filtered utilization of internet data transfers to reduce delay and increase user control |
JPH10171731A (en) | 1996-12-13 | 1998-06-26 | Mitsubishi Electric Corp | Information perusing system and its method |
US5848415A (en) * | 1996-12-18 | 1998-12-08 | Unisys Corporation | Selective multiple protocol transport and dynamic format conversion in a multi-user network |
US5911776A (en) * | 1996-12-18 | 1999-06-15 | Unisys Corporation | Automatic format conversion system and publishing methodology for multi-user network |
US6185625B1 (en) * | 1996-12-20 | 2001-02-06 | Intel Corporation | Scaling proxy server sending to the client a graphical user interface for establishing object encoding preferences after receiving the client's request for the object |
US6212550B1 (en) * | 1997-01-21 | 2001-04-03 | Motorola, Inc. | Method and system in a client-server for automatically converting messages from a first format to a second format compatible with a message retrieving device |
US6128663A (en) * | 1997-02-11 | 2000-10-03 | Invention Depot, Inc. | Method and apparatus for customization of information content provided to a requestor over a network using demographic information yet the user remains anonymous to the server |
US5908469A (en) | 1997-02-14 | 1999-06-01 | International Business Machines Corporation | Generic user authentication for network computers |
JPH10243048A (en) | 1997-02-27 | 1998-09-11 | Nippon Telegr & Teleph Corp <Ntt> | Information transmission method and system therefor |
JPH10327200A (en) | 1997-03-03 | 1998-12-08 | Toshiba Corp | Distributed network computing system, information exchange method used for the system, storage medium storing this method and information exchange |
US6035339A (en) * | 1997-03-13 | 2000-03-07 | At&T Corporation | Network information delivery system for delivering information based on end user terminal requirements |
JPH10269160A (en) | 1997-03-28 | 1998-10-09 | Matsushita Electric Ind Co Ltd | Data distribution display device |
JPH1173398A (en) * | 1997-06-03 | 1999-03-16 | Toshiba Corp | Distributed network computing system, information exchanging device used for its system, information exchanging method having security function used for its system and computer readable storage medium storing its method |
US6317795B1 (en) * | 1997-07-22 | 2001-11-13 | International Business Machines Corporation | Dynamic modification of multimedia content |
US6429879B1 (en) * | 1997-09-30 | 2002-08-06 | Compaq Computer Corporation | Customization schemes for content presentation in a device with converged functionality |
JP3873405B2 (en) * | 1997-10-21 | 2007-01-24 | ソニー株式会社 | Data distribution system and data distribution apparatus |
US6243761B1 (en) * | 1998-03-26 | 2001-06-05 | Digital Equipment Corporation | Method for dynamically adjusting multimedia content of a web page by a server in accordance to network path characteristics between client and server |
US6105063A (en) * | 1998-05-05 | 2000-08-15 | International Business Machines Corp. | Client-server system for maintaining application preferences in a hierarchical data structure according to user and user group or terminal and terminal group contexts |
US6310601B1 (en) * | 1998-05-12 | 2001-10-30 | International Business Machines Corporation | Resizing images to improve network throughput |
US6490624B1 (en) * | 1998-07-10 | 2002-12-03 | Entrust, Inc. | Session management in a stateless network system |
US6286043B1 (en) * | 1998-08-26 | 2001-09-04 | International Business Machines Corp. | User profile management in the presence of dynamic pages using content templates |
US6493704B1 (en) * | 1999-09-13 | 2002-12-10 | Oracle Corporation | Method and apparatus for using metadata to dynamically generate a display page to solicit input from a user |
-
1999
- 1999-01-26 US US09/237,544 patent/US6654814B1/en not_active Expired - Lifetime
- 1999-12-16 CA CA002292327A patent/CA2292327C/en not_active Expired - Fee Related
- 1999-12-17 GB GB9929750A patent/GB2348525B/en not_active Expired - Lifetime
-
2000
- 2000-01-11 JP JP2000002123A patent/JP2000222274A/en active Pending
- 2000-01-13 KR KR1020000001453A patent/KR20000053468A/en active Search and Examination
Also Published As
Publication number | Publication date |
---|---|
US6654814B1 (en) | 2003-11-25 |
GB2348525A (en) | 2000-10-04 |
GB2348525B (en) | 2003-11-12 |
JP2000222274A (en) | 2000-08-11 |
GB9929750D0 (en) | 2000-02-09 |
KR20000053468A (en) | 2000-08-25 |
CA2292327A1 (en) | 2000-07-26 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
CA2292327C (en) | Systems, methods and computer program products for dynamic placement of web content tailoring | |
US8103738B2 (en) | Micro-client for internet appliance | |
US10462247B2 (en) | Web content customization via adaptation web services | |
US7254786B2 (en) | System for transmitting and displaying icon resources group associated with remote application to a local computing system to facilitate virtualization of the remote application | |
EP1649662B1 (en) | Method, system and program product for asynchronously processing requests | |
US6457030B1 (en) | Systems, methods and computer program products for modifying web content for display via pervasive computing devices | |
US6417873B1 (en) | Systems, methods and computer program products for identifying computer file characteristics that can hinder display via hand-held computing devices | |
US8271689B2 (en) | System and method for partial data compression and data transfer | |
US9621641B2 (en) | Predictive rendering of current content versions | |
US8839098B2 (en) | System and method for rapid document conversion | |
US6564250B1 (en) | Miniclient for internet appliance | |
US20050015772A1 (en) | Method and system for device specific application optimization via a portal server | |
US20020123334A1 (en) | Systems, methods and computer program products for dynamically inserting content into web documents for display by client devices | |
US20040080533A1 (en) | Accessing rendered graphics over the internet | |
CA2518672A1 (en) | Method for scaling images for usage on a mobile communication device | |
WO1998043177A1 (en) | System for dynamically transcoding data transmitted between computers | |
US20030191814A1 (en) | Personalization in a wireless portal server | |
WO2004068723A2 (en) | Method of adaptive data transmission | |
KR20020003856A (en) | A system and method for content analysis and minimization | |
US20050015500A1 (en) | Method and system for response buffering in a portal server for client devices | |
EP1012733B1 (en) | System, method and program for dynamically transcoding data transmitted between computers | |
EP1679844A1 (en) | System and method for filtering pushed content | |
US20030191819A1 (en) | Client aware notification in a wireless portal server | |
Ibrahim et al. | Video Adaptation Algorithm for Mobile Learning Environment | |
WO2001097049A1 (en) | Split frame interstitial document display |
Legal Events
Date | Code | Title | Description |
---|---|---|---|
EEER | Examination request | ||
MKLA | Lapsed |