The present invention is related to an application entitled Method and Apparatus for Transmitting Locale Objects, Ser. No. 10/610,240, filed even date hereof, assigned to the same assignee, and incorporated herein by reference.
1. Technical Field
The present invention relates generally to an improved data processing system and in particular, to a method and apparatus for processing data. Still more particularly, the present invention relates to a method, apparatus, and computer instructions for transmitting accessibility information from a client to a server.
2. Description of Related Art
The Internet, also referred to as an “internetwork”, is a set of computer networks, possibly dissimilar, joined together by means of gateways that handle data transfer and the conversion of messages from a protocol of the sending network to a protocol used by the receiving network. When capitalized, the term “Internet” refers to the collection of networks and gateways that use the TCP/IP suite of protocols.
The Internet has become a cultural fixture as a source of both information and entertainment. Many businesses are creating Internet sites as an integral part of their marketing efforts, informing consumers of the products or services offered by the business or providing other information seeking to engender brand loyalty. Many federal, state, and local government agencies are also employing Internet sites for informational purposes, particularly agencies which must interact with virtually all segments of society such as the Internal Revenue Service and secretaries of state. Providing informational guides and/or searchable databases of online public records may reduce operating costs. Further, the Internet is becoming increasingly popular as a medium for commercial transactions.
Currently, the most commonly employed method of transferring data over the Internet is to employ the World Wide Web environment, also called simply “the Web”. Other Internet resources exist for transferring information, such as File Transfer Protocol (FTP) and Gopher, but have not achieved the popularity of the Web. In the Web environment, servers and clients effect data transaction using the Hypertext Transfer Protocol (HTTP), a known protocol for handling the transfer of various data files (e.g., text, still graphic images, audio, motion video, etc.). The information in various data files is formatted for presentation to a user by a standard page description language, the Hypertext Markup Language (HTML). In addition to basic presentation formatting, HTML allows developers to specify “links” to other Web resources identified by a Uniform Resource Locator (URL). A URL is a special syntax identifier defining a communications path to specific information. Each logical block of information accessible to a client, called a “page” or a “Web page”, is identified by a URL. The URL provides a universal, consistent method for finding and accessing this information, not necessarily for the user, but mostly for the user's Web “browser”. A browser is a program capable of submitting a request for information identified by an identifier, such as, for example, a URL. A user may enter a domain name through a graphical user interface (GUI) for the browser to access a source of content. The domain name is automatically converted to the Internet Protocol (IP) address by a domain name system (DNS), which is a service that translates the symbolic name entered by the user into an IP address by looking up the domain name in a database.
The Internet also is widely used to transfer applications to users using browsers. With respect to commerce on the Web, individual consumers and business use the Web to purchase various goods and services. In offering goods and services, some companies offer goods and services solely on the Web while others use the Web to extend their reach.
Users exploring the Web have discovered that the content supported by the HTML document format on the Web was too limited. Users desire an ability to access applications and programs, but applications were targeted towards specific types of platforms. As a result, not everyone could access applications or programs. This deficiency has been minimized though the introduction and use of programs known as “applets”, which may be embedded as objects in HTML documents on the Web. Applets are Java programs that may be transparently downloaded into a browser supporting Java along with HTML pages in which they appear. These Java programs are network and platform independent. Applets run the same way regardless of where they originate or what data processing system onto which they are loaded.
Java servlets and Enterprise Java Beans (EJB) are Java programs that are run on a server. These programs are generally accessed by clients via a Web browser. Typically, when servlets and EJBs generate or format information, the usability needs of a client user should be honored.
For example, if a user is blind, the user's client computer is typically speech enabled. If the user has a slight vision impairment, the user may configure the operating system to use large fonts or certain types of contrasts to increase the readability of text. Currently, such accessibility information is available only at the operating system level of the client computer.
Currently, a user must be explicitly asked or prompted for accessibility needs before a web server can generate and send content to the user. For example, the user may be presented with a form or pop-up window in which the user may select accessibility options. This information is then transmitted back to the Web server. Such a system, however, requires active user input. Further, in some cases the user may be unable to view the form depending on the particular accessibility requirements. This type of system is burdensome and requires user attention.
As a result, it would be advantageous to have an improved method, apparatus, and computer instructions for transmitting accessibility information from a client to a server for use in providing the appropriate formatting of documents.
The present invention provides a method, apparatus, and computer instructions for transmitting accessibility requirements. Content is received from a computer at a data processing system. The content is parsed for a selected indicator. The data processing system is queried to identify accessibility requirements in response to the selected indicator being present. The identified accessibility requirements are sent to the computer. These accessibility requirements are used by the computer to generate content for the data processing system.
The novel features believed characteristic of the invention are set forth in the appended claims. The invention itself, however, as well as a preferred mode of use, further objectives and advantages thereof, will best be understood by reference to the following detailed description of an illustrative embodiment when read in conjunction with the accompanying drawings, wherein:
With reference now to the figures,
In the depicted example, server 104 is connected to network 102 along with storage unit 106. In addition, clients 108, 110, and 112 are connected to network 102. These clients 108, 110, and 112 may be, for example, personal computers or network computers. In the depicted example, server 104 provides data, such as boot files, operating system images, and applications to clients 108-112. Clients 108, 110, and 112 are clients to server 104. Network data processing system 100 may include additional servers, clients, and other devices not shown. In the depicted example, network data processing system 100 is the Internet with network 102 representing a worldwide collection of networks and gateways that use the Transmission Control Protocol/Internet Protocol (TCP/IP) suite of protocols to communicate with one another. At the heart of the Internet is a backbone of high-speed data communication lines between major nodes or host computers, consisting of thousands of commercial, government, educational and other computer systems that route data and messages. Of course, network data processing system 100 also may be implemented as a number of different types of networks, such as for example, an intranet, a local area network (LAN), or a wide area network (WAN).
Referring to
Peripheral component interconnect (PCI) bus bridge 214 connected to I/O bus 212 provides an interface to PCI local bus 216. A number of modems may be connected to PCI local bus 216. Typical PCI bus implementations will support four PCI expansion slots or add-in connectors. Communications links to clients 108-112 in
Additional PCI bus bridges 222 and 224 provide interfaces for additional PCI local buses 226 and 228, from which additional modems or network adapters may be supported. In this manner, data processing system 200 allows connections to multiple network computers. A memory-mapped graphics adapter 230 and hard disk 232 may also be connected to I/O bus 212 as depicted, either directly or indirectly.
Those of ordinary skill in the art will appreciate that the hardware depicted in
The data processing system depicted in
With reference now to
An operating system runs on processor 302 and is used to coordinate and provide control of various components within data processing system 300 in
Those of ordinary skill in the art will appreciate that the hardware in
As another example, data processing system 300 may be a stand-alone system configured to be bootable without relying on some type of network communication interfaces. As a further example, data processing system 300 may be a personal digital assistant (PDA) device, which is configured with ROM and/or flash ROM in order to provide non-volatile memory for storing operating system files and/or user-generated data.
The depicted example in
The present invention provides a method, apparatus, and computer instructions for transmitting accessibility requirements or information from a client to a server. The mechanism of the present invention employs the use of an application, such as a plug-in that is activated whenever a particular indicator is received in a Web page. In these examples, the indicator takes the form of a multi-purpose Internet mail extension (MIME) object type that is included within the Web page. This indicator causes the application or process to query the client for accessibility information. The accessibility information is obtained by reading accessibility settings present at run-time on the client. Then, this information is sent to the server. In the depicted example, the information is sent to a server in the form of a data object, such as an extensible markup language (XML) document. Further, other types of indicators, such as other types of tags may be used.
Turning next to
The generation of Web page 406 may occur through the use of Java servlet 410 or Enterprise Java Bean (EJB) 412. Additionally, Web page 406 may be generated using other mechanisms such as a servlet or server process. As illustrated, indicator 414 is included within Web page 406 by context server 416. In these examples, context server 416 is a server process that is used to include indicator 414 as well as process return accessibility information for use by other server processes. Web page 406 is received by browser 404 at client 400.
Upon receiving Web page 406, browser 404 processes the Web page. The presence of indicator 414 causes plug-in 418 to be activated. As shown, indicator 414 is an object type that takes the form of a multi-purpose Internet mail extension (MIME) type, which is a file identification system based on the MIME encoding system. This MIME type is associated with plug-in 418 and causes plug-in 418 to be activated when the MIME type is detected within Web page 406. In this example, the MIME type is accessibility. This MIME type is used to indicate a particular type of server, such as WebSphere. WebSphere applications are available from International Business Machines Corporation. In addition, the indicator may be located in other types of content other than Web pages. For example, an indicator might be included in a message, a file, or other forms of inter-server process communications.
Plug-in 418 obtains accessibility information, such as the client's font type, font size, whether a speech interface is enabled, enablement of visual warning for generated sounds, and a high contrast display. This information may be obtained by querying the operating system through native calls, such as APIs 422. In response to using APIs 422, accessibility information 424 is obtained from client 400. As illustrated, accessibility information may include information, such as, show sounds, screen reader, and high contrast. Show sounds is used to initiate an application programming interface (API) to provide sounds for users that are hearing impaired. Screen reader is an accessibility feature that provides a text-to-voice translation of text displayed on the screen. High contrast is an accessibility feature used to increase the font size on the display.
With this accessibility information, plug-in 418 returns this information to server 402 by constructing and sending extensible markup language (XML) document 426. This document contains information describing the font size and font type in this example. XML document 426 is sent to server 402 using a POST command. A POST command is an HTTP command used to send text to a Web server for processing. The POST method is widely implemented in HTML files for sending typed-in forms to the server. In these examples, this command is used to transmit the XML document to accessibility server 416. A post command is used in these examples, but other commands, such as a GET command, also may be employed to send the XML document 426 to accessibility server 416.
When XML document 426 is received by accessibility server 416, accessibility server 416 may create a session object, such as accessibility object 428 for tracking purposes. Accessibility object 428 allows for the accessibility information to be recalled for a particular session with client 400. Currently, this kind of information is not accessible by processes on a server.
With the present invention, such a request for accessibility information returns the accessibility information stored in accessibility object 428. No changes or modifications are required to server processes to obtain this type of accessibility information for client 400. Session objects are described in the Java 2 Enterprise Edition (J2EE) architecture by Sun Microsystems, Inc.
Alternatively, instead of maintaining a session object, accessibility server 416 may generate HTML content containing an indicator, such as indicator 414 to retrieve accessibility information from client 400 each time the information is needed. This type of content generation is performed each time Java servlet 410 or EJB 412 instantiates a default data object for a client, such as client 400.
With reference now to
Turning now to
With reference now to
In this manner, the present invention provides an improved method, apparatus, and computer instructions for automatically obtaining accessibility information from a client without requiring user input. The mechanism of the present invention employs a process, such as a plug-in, at the client. This plug-in identifies accessibility information from the client when an indicator, such as a MIME type, is identified or present in content received from a server. This information is returned to the server in a document, such as an XML document using a POST command. This accessibility information is then used by processes on the server to provide appropriate formatting of information for the client.
With reference now to
The process begins by receiving a request for a Web page (step 800). This request is received from a browser at a client, such as browser 404 in
In response, an XML document is received from the client (step 808). As described above, this XML document is received from the client using a POST command. A session object is created from the XML document (step 810) with the process terminating thereafter. This session object is maintained during the session with the client in these examples. Alternatively, these steps in
Turning now to
The process begins by receiving a Web page (step 900). The web page is processed (step 902). In processing the Web page, the different HTML lines in the Web page are parsed to determine whether an indicator is present. Specifically, a determination is made as to whether an accessibility MIME type is present (step 904). If an accessibility MIME type is present, a determination is made as to whether a plug-in is present (step 906). The determination in step 906 may be made by examining a set of MIME type associations in which different extensions are associated with different plug-ins.
If the plug-in for the accessibility MIME type is present, the plug-in is activated (step 908). The description of the processes performed by the plug-in are described in more detail in
With reference again to step 906, if the plug-in is not present, the process proceeds to step 910 as described above. Returning again to step 904, if a accessibility MIME type is absent, the process also proceeds to step 910 as described above.
With reference now to
The process begins by making calls to the operating system for accessibility information (step 1000). In these examples, the calls are API calls for the operating system. These types of API calls are commonly available for use in obtaining accessibility information from the operating system environment. For example, these types of calls are described in Microsoft Windows software development kit available from the Microsoft Corporation. In these examples, the accessibility information includes settings present at run-time as maintained by the operating system. As described above, these accessibility settings include, for example, a font type, a font size, enablement of a speech interface, and settings for contrast on a display. The accessibility information is received from the operating system (step 1002).
After the accessibility information is obtained, an XML document containing accessibility information is generated (step 1004). This XML document is posted to the Web server (step 1006) and the process terminates thereafter.
Thus, the present invention provides an improved method, apparatus, and computer instructions for automatically obtaining accessibility information from a client for use by a server process. The mechanism of the present invention includes an indicator, such as a MIME type, in the content sent to a client. This indicator results in a process, such as a browser plug-in, to be activated when the content is received by the client. This plug-in queries the client to identify accessibility information.
The accessibility information is then returned to the server by the plug-in for use in providing formatting of content for the client by server processes. In this manner, accessibility information may be automatically obtained from the client without requiring changes to existing servlets or EJBs to take advantage of this feature. The accessibility information obtained from the client is placed in a location or format for use by the existing servlets or EJBs.
It is important to note that while the present invention has been described in the context of a fully functioning data processing system, those of ordinary skill in the art will appreciate that the processes of the present invention are capable of being distributed in the form of a computer readable medium of instructions and a variety of forms and that the present invention applies equally regardless of the particular type of signal bearing media actually used to carry out the distribution. Examples of computer readable media include recordable-type media, such as a floppy disk, a hard disk drive, a RAM, CD-ROMs, DVD-ROMs, and transmission-type media, such as digital and analog communications links, wired or wireless communications links using transmission forms, such as, for example, radio frequency and light wave transmissions. The computer readable media may take the form of coded formats that are decoded for actual use in a particular data processing system.
The description of the present invention has been presented for purposes of illustration and description, and is not intended to be exhaustive or limited to the invention in the form disclosed. Many modifications and variations will be apparent to those of ordinary skill in the art. For example, the illustrations show a server and client exchange of cultural context information. This process may be applied to other types of communications, such as peer-to-peer communications between computers. In such a case, a computer may take various forms, such as, for example, a PDA, a cell phone, a laptop computer, a desktop computer, a workstation, a kiosk, or a server computer. The embodiment was chosen and described in order to best explain the principles of the invention, the practical application, and to enable others of ordinary skill in the art to understand the invention for various embodiments with various modifications as are suited to the particular use contemplated.
Number | Name | Date | Kind |
---|---|---|---|
5551055 | Matheny et al. | Aug 1996 | A |
5652884 | Palevich | Jul 1997 | A |
5687366 | Harvey, III et al. | Nov 1997 | A |
5732218 | Bland et al. | Mar 1998 | A |
5734597 | Molnar et al. | Mar 1998 | A |
5778356 | Heiny | Jul 1998 | A |
5812964 | Finger | Sep 1998 | A |
5835768 | Miller et al. | Nov 1998 | A |
5900871 | Atkin et al. | May 1999 | A |
5907326 | Atkin et al. | May 1999 | A |
6026440 | Shrader et al. | Feb 2000 | A |
6073090 | Fortune et al. | Jun 2000 | A |
6141010 | Hoyle | Oct 2000 | A |
6147693 | Yunker | Nov 2000 | A |
6167441 | Himmel | Dec 2000 | A |
6321348 | Kobata | Nov 2001 | B1 |
6324511 | Kiraly et al. | Nov 2001 | B1 |
6339755 | Hetherington et al. | Jan 2002 | B1 |
6412008 | Fields et al. | Jun 2002 | B1 |
6469713 | Hetherington et al. | Oct 2002 | B2 |
6470378 | Tracton et al. | Oct 2002 | B1 |
6490547 | Atkin et al. | Dec 2002 | B1 |
6492995 | Atkin et al. | Dec 2002 | B1 |
6553410 | Kikinis | Apr 2003 | B2 |
6738951 | Weiss et al. | May 2004 | B1 |
6757740 | Parekh et al. | Jun 2004 | B1 |
6775687 | Binding et al. | Aug 2004 | B1 |
6836799 | Philyaw et al. | Dec 2004 | B1 |
6862624 | Colby et al. | Mar 2005 | B2 |
6976220 | Lapstun et al. | Dec 2005 | B1 |
6981246 | Dunn | Dec 2005 | B2 |
6981262 | DeMello et al. | Dec 2005 | B1 |
6988240 | Grober et al. | Jan 2006 | B2 |
7000189 | Dutta et al. | Feb 2006 | B2 |
7010587 | Shiimori | Mar 2006 | B1 |
7069508 | Bever et al. | Jun 2006 | B1 |
7181692 | Siegel | Feb 2007 | B2 |
20020016818 | Kirani et al. | Feb 2002 | A1 |
20020054097 | Hetherington et al. | May 2002 | A1 |
20020077805 | Hecht et al. | Jun 2002 | A1 |
20020083100 | Sakai | Jun 2002 | A1 |
20020103914 | Dutta et al. | Aug 2002 | A1 |
20020111919 | Weller et al. | Aug 2002 | A1 |
20020120645 | Adapathya et al. | Aug 2002 | A1 |
20020120721 | Eilers et al. | Aug 2002 | A1 |
20020174100 | Daray et al. | Nov 2002 | A1 |
20020174421 | Zhao et al. | Nov 2002 | A1 |
20020178007 | Slotznick et al. | Nov 2002 | A1 |
20020184308 | Levy et al. | Dec 2002 | A1 |
20030051059 | Zondervan et al. | Mar 2003 | A1 |
20030204461 | Magary et al. | Oct 2003 | A1 |
20040034521 | Kawakura et al. | Feb 2004 | A1 |
20040087299 | Vallinen et al. | May 2004 | A1 |
20040148568 | Springer | Jul 2004 | A1 |
20050027709 | White et al. | Feb 2005 | A1 |
20050210102 | Johnson et al. | Sep 2005 | A1 |
20060041639 | Lamkin et al. | Feb 2006 | A1 |
20070055938 | Herring et al. | Mar 2007 | A1 |
Number | Date | Country | |
---|---|---|---|
20040268360 A1 | Dec 2004 | US |