US20100017464A1 - Web page content translator - Google Patents

Web page content translator Download PDF

Info

Publication number
US20100017464A1
US20100017464A1 US12/458,153 US45815309A US2010017464A1 US 20100017464 A1 US20100017464 A1 US 20100017464A1 US 45815309 A US45815309 A US 45815309A US 2010017464 A1 US2010017464 A1 US 2010017464A1
Authority
US
United States
Prior art keywords
web page
mobile device
page content
proxy server
requested web
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.)
Abandoned
Application number
US12/458,153
Inventor
Yin Cheng
Wilfredo Padin
Rongli Jiang
Andrew Fedorchek
Current Assignee (The listed assignees may be inaccurate. Google has not performed a legal analysis and makes no representation or warranty as to the accuracy of the list.)
CRFD Research Inc
Original Assignee
Individual
Priority date (The priority date is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the date listed.)
Filing date
Publication date
Family has litigation
First worldwide family litigation filed litigation Critical https://patents.darts-ip.com/?family=40934387&utm_source=google_patent&utm_medium=platform_link&utm_campaign=public_patent_search&patent=US20100017464(A1) "Global patent litigation dataset” by Darts-ip is licensed under a Creative Commons Attribution 4.0 International License.
Application filed by Individual filed Critical Individual
Priority to US12/458,153 priority Critical patent/US20100017464A1/en
Assigned to TELECOMMUNICATION SYSTEMS, INC. reassignment TELECOMMUNICATION SYSTEMS, INC. ASSIGNMENT OF ASSIGNORS INTEREST (SEE DOCUMENT FOR DETAILS). Assignors: CHENG, Yin, FEDORCHEK, ANDREW, JIANG, RONGLI, WILFREDO, PADIN
Publication of US20100017464A1 publication Critical patent/US20100017464A1/en
Assigned to SILICON VALLEY BANK, AGENT reassignment SILICON VALLEY BANK, AGENT SECURITY AGREEMENT Assignors: LONGHORN ACQUISITION, LLC, NETWORKS IN MOTION, INC., QUASAR ACQUISITION, LLC, SOLVERN INNOVATIONS, INC., TELECOMMUNICATION SYSTEMS, INC.
Assigned to MICRODATA, LLC, MICRODATA GIS, INC., SOLVERN INNOVATIONS, INC., TELECOMMUNICATION SYSTEMS, INC., NEXTGEN COMMUNICATIONS, INC., NETWORKS IN MOTION, INC. reassignment MICRODATA, LLC RELEASE Assignors: SILICON VALLEY BANK
Assigned to CRFD RESEARCH, INC. reassignment CRFD RESEARCH, INC. ASSIGNMENT OF ASSIGNORS INTEREST (SEE DOCUMENT FOR DETAILS). Assignors: TELECOMMUNICATION SYSTEMS, INC.
Assigned to DBD CREDIT FUNDING, LLC reassignment DBD CREDIT FUNDING, LLC SECURITY INTEREST (SEE DOCUMENT FOR DETAILS). Assignors: CRFD RESEARCH, INC., MARATHON PATENT GROUP, INC.
Assigned to LONGHORN ACQUISITION, LLC, TELECOMMUNICATION SYSTEMS, INC., SOLVEM INNOVATIONS, INC., QUASAR ACQUISITION, LLC, NETWORKS IN MOTION, INC. reassignment LONGHORN ACQUISITION, LLC RELEASE BY SECURED PARTY (SEE DOCUMENT FOR DETAILS). Assignors: SILICON VALLEY BANK
Assigned to CITIBANK, N.A. reassignment CITIBANK, N.A. SECURITY INTEREST (SEE DOCUMENT FOR DETAILS). Assignors: ANGELS ACQUISITION CORP., ARMER COMMUNICATIONS ENGINEERING SERVICES, INC., COMTECH AEROASTRO, INC., COMTECH ANTENNA SYSTEMS, INC., COMTECH COMMUNICATIONS CORP., COMTECH COMSTREAM, INC., COMTECH CPI ELECTRON DEVICES CORP., COMTECH CPI MICROWAVE CORP., COMTECH EF DATA CORP., COMTECH MOBILE DATACOM CORPORATION, COMTECH PST CORP., COMTECH SYSTEMS INTERNATIONAL, INC., COMTECH SYSTEMS, INC., COMTECH TELECOMMUNICATIONS CORP., COMTECH TOLT TECHNOLOGIES, INC., COMTECH XICOM TECHNOLOGY, INC., MAPLE ACQUISITION LLC, MICRODATA GIS, INC., MICRODATA, LLC, NETWORKS IN MOTION, INC., NEXTGEN COMMUNICATIONS, INC., A CORPORATION OF MARYLAND, NEXTGEN COMMUNICATIONS, INC., A CORPORATION OF VIRGINIA, OLIVE ACQUISITION LLC, SOLVERN INNOVATIONS, INC., TELECOMMUNICATION SYSTEMS, INC., TIERNAN RADYNE COMSTREAM, INC.
Abandoned legal-status Critical Current

Links

Images

Classifications

    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F40/00Handling natural language data
    • G06F40/10Text processing
    • G06F40/12Use of codes for handling textual entities
    • G06F40/14Tree-structured documents
    • G06F40/143Markup, e.g. Standard Generalized Markup Language [SGML] or Document Type Definition [DTD]
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F16/00Information retrieval; Database structures therefor; File system structures therefor
    • G06F16/90Details of database functions independent of the retrieved data types
    • G06F16/95Retrieval from the web
    • G06F16/957Browsing optimisation, e.g. caching or content distillation
    • G06F16/9577Optimising the visualization of content, e.g. distillation of HTML documents
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06QINFORMATION AND COMMUNICATION TECHNOLOGY [ICT] SPECIALLY ADAPTED FOR ADMINISTRATIVE, COMMERCIAL, FINANCIAL, MANAGERIAL OR SUPERVISORY PURPOSES; SYSTEMS OR METHODS SPECIALLY ADAPTED FOR ADMINISTRATIVE, COMMERCIAL, FINANCIAL, MANAGERIAL OR SUPERVISORY PURPOSES, NOT OTHERWISE PROVIDED FOR
    • G06Q10/00Administration; Management
    • G06Q10/10Office automation; Time management
    • G06Q10/107Computer-aided management of electronic mailing [e-mailing]
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L67/00Network arrangements or protocols for supporting network services or applications
    • H04L67/01Protocols
    • H04L67/02Protocols based on web technology, e.g. hypertext transfer protocol [HTTP]
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L69/00Network arrangements, protocols or services independent of the application payload and not provided for in the other groups of this subclass
    • H04L69/30Definitions, standards or architectural aspects of layered protocol stacks
    • H04L69/32Architecture of open systems interconnection [OSI] 7-layer type protocol stacks, e.g. the interfaces between the data link level and the physical level
    • H04L69/322Intralayer communication protocols among peer entities or protocol data unit [PDU] definitions
    • H04L69/329Intralayer communication protocols among peer entities or protocol data unit [PDU] definitions in the application layer [OSI layer 7]
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L9/00Cryptographic mechanisms or cryptographic arrangements for secret or secure communications; Network security protocols
    • H04L9/40Network security protocols
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F16/00Information retrieval; Database structures therefor; File system structures therefor
    • G06F16/40Information retrieval; Database structures therefor; File system structures therefor of multimedia data, e.g. slideshows comprising image and additional audio data
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F40/00Handling natural language data
    • G06F40/10Text processing
    • G06F40/166Editing, e.g. inserting or deleting
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06QINFORMATION AND COMMUNICATION TECHNOLOGY [ICT] SPECIALLY ADAPTED FOR ADMINISTRATIVE, COMMERCIAL, FINANCIAL, MANAGERIAL OR SUPERVISORY PURPOSES; SYSTEMS OR METHODS SPECIALLY ADAPTED FOR ADMINISTRATIVE, COMMERCIAL, FINANCIAL, MANAGERIAL OR SUPERVISORY PURPOSES, NOT OTHERWISE PROVIDED FOR
    • G06Q10/00Administration; Management
    • G06Q10/10Office automation; Time management
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L67/00Network arrangements or protocols for supporting network services or applications
    • H04L67/01Protocols
    • H04L67/10Protocols in which an application is distributed across nodes in the network
    • H04L67/1095Replication or mirroring of data, e.g. scheduling or transport for data synchronisation between network nodes

Definitions

  • the present invention relates generally to dynamically extracting and reformatting existing web page content and, more particularly, to dynamically extracting a portion of content from a web page and reformatting the extracted content for viewing on a mobile device.
  • a client e.g., a Wireless Access Protocol (WAP) gateway
  • WAP Wireless Access Protocol
  • the present invention provides a system, method, and medium that extracts a portion of web page content and reformats the extracted content for delivery to one or more wireless devices.
  • Embodiments of the present invention contemplate that web-based content can be created one time, whereafter at least a portion thereof is extracted, reformatted, and transmitted to, for example, one or more handheld device browsers (e.g., the Palm Web Clipping Browser from Palm, Inc., Santa Clara, Calif., Pocket Internet Explorer from Microsoft Corp, Redmond, Wash., and Wireless Access Protocol (WAP) on smart phones, etc.).
  • handheld device browsers e.g., the Palm Web Clipping Browser from Palm, Inc., Santa Clara, Calif., Pocket Internet Explorer from Microsoft Corp, Redmond, Wash., and Wireless Access Protocol (WAP) on smart phones, etc.
  • a user generates a request, from a mobile device to a proxy server.
  • the proxy server then forwards the user request to an origin web server (having a first file format), whereafter the requested web page is returned to the proxy server.
  • the appropriate components e.g., tags, etc.
  • WML Wireless Markup Language
  • the reformatted web page is then transmitted from the proxy server to the requesting mobile device.
  • The may be done for at least one of groups of devices, individual devices, web site-specific conversions, or for all web sites.
  • the method of the present invention also provides a secure connection via a decorated URL between a mobile device and/or client (e.g., a WAP gateway) which forwards a secure request from the mobile device, a proxy server that reformats original web page content, and a web page server.
  • a mobile device and/or client e.g., a WAP gateway
  • FIG. 1 is a representative simplified block diagram of a mobile device, a proxy server, and a content server which also illustrates an overview of the method according to the present invention
  • FIG. 2 is a schematically simplified flow diagram of the conversion workflow for HTML mobile devices
  • FIG. 3 is a flow diagram illustrating a process of creating a device profile
  • FIG. 4 is a representative screen display wherein a device profile can be created
  • FIG. 5 is a site-mining workflow diagram
  • FIG. 6 is a diagram of the Document Object Model (DOM).
  • FIG. 7 is a flow diagram illustrating a process of creating conversions for a group of mobile devices
  • FIG. 8 is an exemplary screen display wherein conversions are defined for a group of mobile devices
  • FIG. 9 is a flow diagram illustrating a process of creating conversions for particular mobile devices.
  • FIG. 10 is a flow diagram illustrating a process of creating conversions for all web sites
  • FIG. 11 illustrates one example of a central processing unit for implementing a computer process in accordance with a computer implemented stand-alone embodiment of the present invention.
  • FIG. 12 illustrates one example of a block diagram of internal hardware of the central processing unit of FIG. 11 .
  • FIG. 1 illustrates an architecture 100 as contemplated of the present invention (and environments thereof).
  • a proxy server 110 reformats/converts web content 104 on an origin web server 102 into a format 122 readable on any mobile device 108 (which can be any number of different mobile device types). Details of the architecture of the present invention, the order in which conversions are processed, and how mobile devices 108 are connected to proxy server 110 through the present invention are explained herein.
  • the proxy server 110 of the present invention “sits” between the clients (e.g., the mobile device(s) 108 ) and the origin web server(s) 102 that provide Web content 104 . If necessary, a gateway 109 may optionally be provided that interfaces between, for example, the mobile device 108 and the proxy server 110 .
  • an origin web server 102 is a web server that contains the original web page 104 . It is different from, for example, the proxy server 110 because the original web server 102 is maintained and updated by the individual(s) and/or organization(s) that hosts the web site for the web page 104 .
  • the present invention obtains the code (e.g., HTML) of the user requested web page 104 , and modifies it at the proxy server 110 (once obtained) in accordance with at least one novel method described herein.
  • Embodiments contemplated by the present invention also envision reformatting and/or converting an entire web site or request specific Web content that is needed from the origin web server 102 .
  • architecture 100 comprises one or more servers 102 having web content (in the form of at least one web page 104 ), a proxy server 110 , at least one mobile device 108 , and at least one network 114 .
  • web content in the form of at least one web page 104
  • proxy server 110 at least one mobile device 108
  • network 114 at least one network 114 .
  • FIG. 1 only one of each of the mobile device 108 , server 102 , and network 114 are shown in FIG. 1 , although in general the system 100 may comprise multiples of each. It is envisioned that each instance of web content 104 each have associated therewith a URL.
  • a request 106 from a mobile device 108 for a given web page 104 typically made through a HyperText Transport Protocol (HTTP) from the resident mobile device, or HyperText Transport Protocol Secure (HTTPS) request from the resident mobile device 108 browser
  • HTTP HyperText Transport Protocol
  • HTTPS HyperText Transport Protocol Secure
  • the gateway 109 will receive such a HTTP or HTTPS request if a gateway 109 is used.
  • the proxy server 110 makes a request 112 for the page. As shown, the proxy server 110 and the server 102 are connected via a network 114 such as the Internet.
  • the server 102 responsively returns 116 , via the network 114 , the requested web page 104 to the proxy server 110 .
  • the web page 104 is typically an HTML file with references to any component .wav, .mov, and/or Joint Photographic Experts Group (JPEG) files, which together comprise the web page 104 .
  • JPEG Joint Photographic Experts Group
  • other file formats e.g., .gif (graphics interchange format)
  • web page components e.g., Java applets
  • the conversion engine 118 retrieves and/or accesses the stored web page 104 , and accesses a predefined extraction and conversion file associated with the mobile device 108 and/or web page 104 , preferably via the extraction and conversion file database 120 .
  • Extraction and conversion files may, for example, contain the following information:
  • Mobile devices 108 generally come in a variety of different sizes and have a variety of different screen interfaces. As will be discussed in further detail herein, the present invention provides the ability to uniquely tailor web page 104 content for specific mobile devices 108 .
  • a particular organization may know that its users will always be retrieving web pages using, for example, Palm operating system devices (e.g., Palm III, X, VIIs, etc.). Formatting rules may be set up that apply to the group of Palm operating system devices generally, as well as, for example, the Palm VII in particular.
  • Palm operating system devices e.g., Palm III, X, VIIs, etc.
  • Formatting rules may be set up that apply to the group of Palm operating system devices generally, as well as, for example, the Palm VII in particular.
  • To create a device profile both the specific version of a mobile device 108 and its web browser (e.g., a Palm V with browser A, etc.) are needed.
  • device profiles are registered with the proxy server 110 by using HTTP request headers, as will be explained
  • device profiles can also be created for a group of mobile devices 108 , as well as all mobile devices 108 .
  • an organization's mobile device 108 users will often be visiting graphic-intensive web sites, and that the users will be viewing these sites on, say, smart phones (i.e., a cellular telephone that provides voice, limited Internet access, e-mail, pager and/or facsimile service, and typically has a small screen and little memory).
  • a global extraction and conversion file can be created that, for example, instructs the conversion engine 118 to replace all graphics with text links. This conversion would affect all web content that is delivered to all mobile device 108 users. Users can therefore access web sites they need without the inconvenience of waiting online for graphics to download onto their mobile devices 108 .
  • the conversion engine 118 uses the expressions defined therein, and performs the designated operations upon, for example, the HTML code contained in the web page 104 .
  • the designated HTML content of the retrieved web page 104 is extracted, subsequently and/or converted, and transmitted as a reformatted web page 122 to the mobile device 108 .
  • web page 104 can optionally be cached in a local cache 124 on the proxy server 110 .
  • Caching enables web pages 104 to be processed faster, thereby reducing the time mobile device 108 users spend online.
  • the proxy server 110 receives a web page 104 over, say, the Internet 114
  • the conversion engine 118 can convert and store the web page 122 in a web page 122 specific cache.
  • the conversion engine 118 retrieves it from the cache 124 , which reduces online time.
  • the proxy server 110 can also cache unconverted web page 104 content.
  • Unconverted web page 104 content is content received from the server 102 , which has not yet been converted and/or extracted by the conversion engine 118 .
  • Cache settings can therefore be configured to meet specific needs (e.g., when caching will begin, the length of time pages will be kept in cache, and the amount of disk space and memory that will be allocated to caching).
  • the proxy server 110 envisions the use of various types of security to ensure that the transmission of information is secure (e.g., that unauthorized parties cannot intercept and/or access the information).
  • An example envisioned by embodiments of the present invention provides the ability to support the secure socket layer (SSL) protocol developed by Netscape Corp. (now merged with America Online, Inc., Dulles, Va.). When this feature is utilized, users can make secure connections (from, for example, a mobile device 108 to the proxy server 108 and from the proxy server 108 to the origin web server 102 and back), as well as partially secure connections.
  • the proxy server will the proxy server will load an SSL library, which includes, for example, SSL 2.0 and SSL 3.X protocol specification modules.
  • a digital certificate from a certificate authority (e.g., VeriSign) must be obtained.
  • the digital certificate is sent to a client (e.g., a mobile device 108 or a gateway 109 ) to authenticate the proxy server 110 , in order to establish a secure connection between the client and the proxy server 110 ).
  • Embodiments of the present invention contemplate that there are at least four types of SSL settings that can be configured for the proxy server 110 , including, for example:
  • the SSL settings in, for example, the proxy server 110 .ini file do not have to be configured.
  • Embodiments of the present invention contemplate that in the event that a particular mobile device 108 does not enable a proxy server 110 to be used, the present invention enables mobile devices to be redirected to proxy through the proxy server 110 by typing (or in some way, entering or implementing) the proxy server 110 address (location) and the URL of the desired web site 104 in, for example, an address field of the mobile device 108 browser.
  • This type of address is commonly referred to as a “decorated URL”.
  • a decorated URL contains, for example, the proxy server 110 host name and port number, and the web address of the web site 104 that is to be accessed.
  • the above-identified URL decoration can be used to make an un-secure (http://) request or a secure (https://) request.
  • the proxy server retrieves the desired web page 104 .
  • the proxy server automatically re-writes all of the other links within the site that are initially proxied to via the decorated URL. That is, if one or more links are embedded within a first web site, and a user clicks on one of the links, the link that the user clicks on will also be “rewritten” in decorated form in accordance with the invention.
  • the proxy server 110 automatically re-decorates the URL, to provide the secure connection. Therefore, a user only has to type the decorated URL once each time a new Web site is accessed.
  • a decorated URL contains the proxy server 110 host name and port number, and the web address of the site that is to be accessed.
  • a decorated URL for the Aether Software Web (www.aethersystems.com) site may look like:
  • Secure requests made either to and/or from the proxy server 110 can be done by using a decorated URL. If a decorated URL is being used, there are three options. First, a completely secure connection can be made from the mobile device 108 , and optionally forwarded by the gateway 109 (if one is used), to proxy server 110 , and from the proxy server 110 to the origin web server 102 (i.e., the user makes a secure request to the proxy server 110 and a secure request to the web page 104 . The origin server 102 then encrypts the user request and the web page 104 that is returned to the mobile device.).
  • This type of connection provides end-to-end security and is useful, for example, for e-commerce sites or for secure Web-based applications.
  • This type of decorated URL may look as follows:
  • a secure connection can be made between the mobile device 108 , including the gateway 109 (if one is used), and the proxy server 110 .
  • a Z business or content provider for example, that uses the proxy server at the bridge of a firewall may want users to make a secure connection to the proxy server 110 .
  • This embodiment contemplates a secure connection between, for example, at least a gateway to which the mobile device 108 interfaces, and the proxy server 110 .
  • This type of decorated URL may look, for example, as follows:
  • a secure connection can be made between the proxy server 110 and the origin web server 102 .
  • a wireless ISP may want to have users make a regular un-secure request in order to access the proxy server 110 , and then make a secure connection between the proxy server 110 and the origin server 102 .
  • the decorated URL may look, for example, as follows:
  • the menus that a user will need to access on the mobile device to set up the decorated URL will vary.
  • the HandWeb icon in the applications launcher can be tapped to display the last page accessed.
  • the menu button can be tapped to display the Options menu, in which the Open Location menu item may be tapped.
  • the decorated URL may then be typed in the URL field, and the web site corresponding to the URL is then accessed.
  • FIG. 2 is a simplified flow diagram of a conversion workflow for HTML-based mobile devices, as contemplated by the present invention.
  • step 201 a device profile is created for each type mobile device 108 in accordance with the HTTP. It is envisioned that each mobile device 108 is registered with the proxy server 110 to indicate which conversions for the device 108 are desired. Then, when conversion engine 110 receives a request 106 , it compares the headers in the request 106 with the headers in an extraction and conversion file associated with the requesting mobile device 108 to determine which conversions to perform.
  • step 302 user-agent (UA) information (i.e., mobile device 108 information) is provided to the proxy server 110 that uniquely identifies a type of mobile device 108 (e.g., by make and/or model) and the Web browser used on that device.
  • the user-agent information is stored in either the device profile information on the proxy server 110 or, for example, in a global file that stores such information for all devices 108 .
  • UA-color information is provided via a header that specifies, for example, the screen color of the mobile device 108 .
  • the conversion engine 110 performs color reduction automatically taking into consideration, for example, the screen color of the mobile device 108 . If the mobile device does not send the UA-color header, a color reduction conversion for the mobile device 108 can be configured. If the mobile device 108 does send a UA-color header, the value sent in the header can optionally be overridden to improve device performance by, for example, reducing colors to a level lower than the device's maximum capability.
  • the UA-connection type (e.g., HTTP or HTTPS) between the mobile device 108 and the proxy server 110 , and/or the proxy server 110 and the origin web server 102 is specified in step 306 .
  • the UA-connection is used to specify the type of connection that the mobile device 108 connects to.
  • the UA-CPU is specified. This information is used to specify the CPU (e.g., the manufacturer, model, and/or clock speed) of the mobile device 108 .
  • the UA display field is used to specify the display type of the user agent.
  • the UA-HTML field is used to specify the version of HTML of the mobile device 108 .
  • the UA-input field 414 is used to specify the types of input fields (e.g., password field, text box, image, file, etc.) of the mobile device 108 screen display.
  • the UA-language field is used to specify the language of the mobile device 108 (e.g., English, Spanish, etc.).
  • other fields, such as UA-operating system can be used to specify, e.g., the operating system of the mobile device 108 , as well as other items of information. It will be recognized that not all of the above-identified steps will be applicable to every type of mobile device 108 .
  • FIG. 4 shows a representative screen display that may be used to enter the data of FIG. 3 .
  • the UA field 402 , UA-color field 404 field, UA-connection field 406 , UA-CPU field 408 , UA-display field 410 , UA-HTML field 412 , UA-input field 414 , and UA-language field 416 are shown.
  • other input fields such as, for example, the UA operating system, may also be provided.
  • Mobile device 108 profiles can comprise a series of device headers based on fields 402 , 402 , 406 , 408 , 410 , 414 , 416 (e.g., HTTP request headers).
  • HTTP request headers e.g., HTTP request headers.
  • a mobile device 108 is generally defined by both the hardware and browser. The device headers thus serve to identify the mobile device 108 to the proxy server 110 .
  • step 202 site-mining is performed, where web page content is extracted from a web page 104 .
  • the site-mining 202 process as contemplated by embodiments of the present invention is shown in FIG. 5 .
  • the desired web page 104 is retrieved by the proxy server 110 .
  • the retrieved document is envisioned to be a HTML-based or similar document (e.g., a WML document).
  • a Document Object Model (DOM) shown at 600 in FIG. 6 ) corresponding to the retrieved web page 104 is created.
  • DOM Document Object Model
  • the DOM 600 as proposed by the World Wide Web Consortium (W3C), is a standard internal representation of the document structure and attempts to make it easier for programmers to access components and delete, add or edit their content, attributes and style. In essence, the DOM 600 makes it possible for programmers to write applications which work properly on all browsers and servers, and on all platforms. While programmers may need to use different programming languages, they do not need to change their programming model.
  • the W3C's DOM 600 thus offers programmers a platform- and language-neutral program interface which will enable programming across platforms with languages such as, for example, Java and ECMAScript.
  • the DOM 600 shown therein is an exemplary representation of an HTML document in which all elements are treated as objects.
  • the DOM is a platform-neutral and language neutral interface allowing dynamic access and updating of content, structure, and style of documents.
  • a single DOM object can represent an element (e.g., the text in an element or an attribute value), the entire document (e.g., web page 104 ) or a collection of objects.
  • the DOM 600 object hierarchy is a series of nested objects, where each object contains either data or additional objects.
  • the topmost object is the HTML document 602 (e.g., web page 104 ) itself.
  • W3C's DOM Level 1 Specification dated Oct. 1, 1998, which is incorporated herein by reference.
  • step 506 objects are extracted from the web page 104 in accordance with the DOM 600 .
  • the name of the tag the content resides in must be determined (e.g., table), as well as the tag number (e.g., is it the first table? Second?).
  • the tag number e.g., is it the first table? Second?.
  • whether the content is in a sub-tag or child of a parent tag should be determined. If so, what number is it? (e.g., if it is a table row that is desired, then what number is it?)
  • step 508 the site-mining expressions, contained in an extraction and conversion file 512 , are performed on the extracted object(s) of step 506 .
  • Embodiments of the present invention contemplate that one or more methods having the functionality of the methods provided in, for example, the Exemplary Site Mining Methods section will be used to extract the desired content.
  • one or more of the conversion methods shown in the Site-Mining Expressions Examples section is used to convert/reformat one or more of the extracted objects to facilitate display on one or more mobile devices 108 .
  • step 510 after applying the operations contained in the extraction and conversion file 512 to the web page 104 , the transformed web page 122 is provided and transmitted to one or more mobile devices 108 . (However, prior to the transmission to one or more mobile devices, other types of conversions can also be performed, as indicated in FIG. 2 ).
  • the expressions utilize methods defined in, for example, the Exemplary Site-Mining Methods section.
  • a site-mining expression specifies a path to an object (HTML element) from the DOM (e.g., web page 104 ) using methods defined in the site-mining expression language as shown in the Exemplary Site-Mining Methods section.
  • Each of the methods contained in the Exemplary Site-Mining Methods section performs an action on a collection of objects in the object hierarchy.
  • Each method returns a list of one or more objects.
  • group conversions can be optionally performed.
  • Group conversions are conversion rules that are applied to a group of similar mobile devices. For example, a group conversion can be applied to all Palm operating system devices. After such group conversion rules have been created, these rules can be applied to every new version of a Palm operating system device that is added to the system. Using group conversions saves time, for example, because it saves from having to keep reentering the same conversion rule(s) for all versions of a device (e.g., Palm 3x, Palm VII, etc.). Thus, e.g., one or more predefined conversions can be applied to any device(s) using a given operating system (e.g., Palm OS).
  • a given operating system e.g., Palm OS
  • step 702 an individual can define whether images are to be replaced with, for example, a text link field 602 .
  • an individual can optionally scale images and image maps. In general, the user can type the percentage as an integer between, for example, 1 and 100.
  • step 708 the resolution of the graphics in the web page 104 being converted can be reduced.
  • the percentage can be entered as an integer between 1 and 100.
  • interpolation can optionally be used to improve image quality. This feature allows tuning of the quality of the scaled images. For example, an individual can select “yes” if he or she is scaling images and wants to improve quality.
  • the file format of images can be selected (e.g., .gif or JPEG).
  • step 714 the quality of JPEG conversion is specified.
  • an individual can enter, for example, an integer between 0 and 100, where 100 indicates the highest quality.
  • images larger than a prespecified size can optionally be removed (i.e., from being sent to a mobile device 108 ).
  • An individual can, for example, enter the number of the maximum file size to be sent to a mobile device 108 in kilobytes.
  • an “always send converted image” feature can optionally be invoked. This will send a converted image even, for example, if the file size is larger than that specified in step 716 .
  • the conversion engine 110 can be directed to send an error message to the corresponding mobile device 108 if an image conversion fails.
  • the conversion engine can be directed to remove comments (e.g., either in ⁇ COMMENT> tags or in ⁇ !--comment--> format) from the content. An individual can select “Yes”, for example, to remove all comments, or “No”, for example, to leave them in the content.
  • FIG. 8 A representative screen display corresponding to the method shown in FIG. 7 is provided in FIG. 8 .
  • field 802 enables images to be replaced with text links.
  • Other fields are also shown corresponding to the steps shown in and discussed with regard to FIG. 7 .
  • device conversions can be optionally performed.
  • Device conversions are rules that change or format Web content according to, for example, the specific version of a device and its web browser.
  • a group conversion can be set up that is applicable to, say, Palm operating system devices.
  • the method of performing a number of recommended conversions for specific mobile devices 108 is provided.
  • step 902 conversions are performed for mobile devices 108 that, for example, support Java scripts or applets.
  • step 904 conversions for gray-scale devices are made. Potential conversions include, for example, removing the ⁇ U> tag, encoding images as GIF, and converting any color header images to gray scale.
  • step 906 conversions can be created for color devices. Such conversions for color devices will depend, for example, on goals. If the goal is to optimize the performance of the server 102 , then either reducing images to gray scale by specifying a color depth (e.g., mono8 or lower), or reducing the resolution to decrease file size (e.g., enter 90 percent or lower) is generally recommended.
  • step 908 the effect of removing background images can be considered. Many web pages 104 use light text and a dark background. If the background images or color are removed, the light text becomes unreadable. Therefore, a conversion to remove the color attribute of the ⁇ FONT> tag can be provided. However, in one embodiment, it is not recommended that the width and height attributes of the ⁇ IMG> tag be removed.
  • site-specific conversions can be optionally performed.
  • Site-specific conversions are rules that change or format web page 104 content for a specific web page 104 , or for those web pages within a given directory, or site (or portion thereof).
  • the number of possible conversions is virtually infinite, and may include any of the appropriate combinations of methods and transforms.
  • global conversions can be optionally performed.
  • Global conversions are rules that change or format web content on all web pages 104 for either one type of device or all devices.
  • One possible method of performing global conversions is indicated in FIG. 10 .
  • the conversion does not have an effect on the content the user sees, but decreases the amount of data sent, thus providing a faster download experience for any user.
  • FIG. 10 is illustrative only, and that the invention enables numerous other operations to be performed on web pages depending on, for example, the needs and/or types of mobile devices 108 that a particular organization may utilize.
  • step 1004 HTML comments are first removed.
  • the largest file size for converted images is specified. That is, the largest amount of image data that is to be transmitted to a mobile device 108 is specified. The amount can be based at least on the type of Internet connection the mobile device 108 uses. For example, if the mobile device 108 has a slow connection, the conversion engine 118 can be configured to omit images over a specified size. If the mobile device 108 has a faster connection, larger file size value can be specified.
  • step 1006 HTML tags that the browser does not support are removed. A list of unsupported HTML tags can be obtained from, for example, the manufacturer of the browser on the mobile device 108 .
  • the conversion engine 118 can then be configured to remove and/or replace them. In general, it is typically more efficient, and therefore preferable, for the conversion engine 118 to remove such tags rather than sending information to the mobile device 108 which cannot be used.
  • attributes should be scaled. In many instances, the size of an item is specified in HTML as a percentage, to which the browser automatically scales the item. For cases where the size of an item is specified in HTML as pixels, however, the size can be reduced to ensure that it fits in the display area for the device.
  • Preceded FORM by: followsed all, grep, attributeMatch, text, getAttribute, html by: getAttribute Description: The value of the specified attribute from the proceeding tag. Preceded Any tag that has the specified attribute. by: followsed None. You can not have another method by: follow this method. Example: document.all.tags(“FRAME”).attri buteMatch(NAME “main”). Returns: The SRC attribute from the FRAME tag that is named “main”. grep Returned: This method returns elements containing text that matches the regular expression. Preceded Any method returning an object that contains by: text to match the regular expression.
  • the rule includes the tag name, the attribute and the attribute value, each separated by a colon. Syntax: sw-transform “Mozilla/2.0 (compatible;Elaine/1.0)” AddAttributeToTag:TAG NAME: ATTRIBUTE NAME “ATTRIBUTE VALUE” Example: To center heading 2, you would enter: sw-transform “Mozilla/2.0 (compatible;Elaine/1.0)” AddAttributeToTag H2:ALIGN:”CENTER”. IgnoreGlobalTransformations Description: This rule tells the conversion engine to ignore theglobal conversions.
  • sw-transform “Mozilla/2.0 (compatible;Elaine/1.0)” InsertTextFromFile:path to file and filename.
  • ORIGINAL TEXT is a regular expression Example: To remove text such as, “ ⁇ Title>Aether Softwares' Daily Product Update ⁇ /Title>” and replace it with ⁇ Title>ScoutWeb Update ⁇ Title>, you would enter: sw-transform “Nokia-WAP-Toolkit/ 1.2” Substitute:Aether Softwares' Daily Product Update:ScoutWeb Update:ig TranslateTables Description: This rule tells the conversion engine to remove the table formatting and make the table contents appear as straight text.
  • FIG. 11 is an illustration of a computer system which is also capable of implementing some or all of the computer processing in accordance with computer implemented embodiments of the present invention.
  • the procedures described herein are presented in terms of program procedures executed on, for example, a computer or network of computers.
  • a computer system designated by reference numeral 1100 has a computer portion 1102 having disk drives 1104 and 1106 .
  • Disk drive indications 1104 and 1106 are merely symbolic of a number of disk drives which might be accommodated by the computer system. Typically, these would include a floppy disk drive 1104 , a hard disk drive (not shown externally) and a CD ROM indicated by slot 1106 .
  • the number and type of drives vary, typically with different computer configurations. Disk drives 1104 and 1106 are in fact optional, and for space considerations, are easily omitted from the computer system used in conjunction with the production process/apparatus described herein.
  • the computer system also has an optional display 1108 upon which information, such as the screens illustrated in FIGS. 4 and/or 8 may be displayed.
  • a keyboard 1110 and a mouse 1112 are provided as input devices through which input may be provided, thus allowing input to interface with the central processing unit 1102 .
  • the keyboard 1110 is either a limited function keyboard or omitted in its entirety.
  • mouse 1112 optionally is a touch pad control device, or a track ball device, or even omitted in its entirety as well, and similarly may be used as an input device.
  • the computer system 1100 may also optionally include at least one infrared (or radio) transmitter and/or infrared (or radio) receiver for either transmitting and/or receiving infrared signals.
  • Computer system 1100 is illustrated having a single processor, a single hard disk drive and a single local memory, the system 1100 is optionally suitably equipped with any multitude or combination of processors or storage devices.
  • Computer system 1100 is, in point of fact, able to be replaced by, or combined with, any suitable processing system operative in accordance with the principles of the present invention, including hand-held, laptop/notebook, mini, mainframe and super computers, as well as processing system network combinations of the same.
  • FIG. 12 illustrates a block diagram of the internal hardware of the computer system 1100 of FIG. 11 .
  • a bus 1202 serves as the main information highway interconnecting the other components of the computer system 1100 .
  • CPU 1204 is the central processing unit of the system, performing calculations and logic operations required to execute a program.
  • Read only memory (ROM) 1206 and random access memory (RAM) 1208 constitute the main memory of the computer 1102 .
  • Disk controller 1210 interfaces one or more disk drives to the system bus 1202 . These disk drives are, for example, floppy disk drives such as 1104 or 1106 , or CD ROM or DVD (digital video disks) drive such as 1212 , or internal or external hard drives 1214 . As indicated previously, these various disk drives and disk controllers are optional devices.
  • a display interface 1218 interfaces display 1208 and permits information from the bus 1202 to be displayed on the display 1108 .
  • display 1108 is also an optional accessory.
  • display 1108 could be substituted or omitted.
  • optical fibers and/or electrical cables and/or conductors and/or optical communication e.g., infrared, and the like
  • wireless communication e.g., radio frequency (RF), and the like
  • Peripheral interface 1520 interfaces the keyboard 1410 and the mouse 1412 , permitting input data to be transmitted to the bus 1502 .
  • the above-identified CPU 1204 may be replaced by or combined with any other suitable processing circuits, including programmable logic devices, such as PALs (programmable array logic) and PLAs (programmable logic arrays). DSPs (digital signal processors), FPGAs (field programmable gate arrays), ASICs (application specific integrated circuits), VLSIs (very large scale integrated circuits) or the like.
  • PALs programmable array logic
  • PLAs programmable logic arrays
  • DSPs digital signal processors
  • FPGAs field programmable gate arrays
  • ASICs application specific integrated circuits
  • VLSIs very large scale integrated circuits
  • One of the implementations of the invention is as sets of instructions resident in the random access memory 1208 of one or more computer systems 1100 configured generally as described above.
  • the set of instructions may be stored in another computer readable memory, for example, in the hard disk drive 1214 , or in a removable memory such as an optical disk for eventual use in the CD-ROM 1212 or in a floppy disk for eventual use in a floppy disk drive 1104 , 1106 .
  • the set of instructions (such as those written in the Java programming language) can be stored in the memory of another computer and transmitted in a transmission means such as a local area network or a wide area network such as the Internet 114 when desired by the user.
  • a transmission means such as a local area network or a wide area network such as the Internet 114 when desired by the user.
  • storage or transmission of the computer program product changes the medium electrically, magnetically, or chemically so that the medium carries computer readable information.

Abstract

A system, method, and computer readable medium for reformatting web content into a format readable on one or more mobile devices is provided. A user generates a user request for a web page from a mobile device to a proxy server. The proxy server forwards the user request to an origin web server, which returns the requested web page to the proxy server. A conversion engine within the proxy server extracts the desired content from the web page, and reformats the content in accordance with one or more predefined transform methods associated with the one or more mobile devices before transmitting the transformed web page with the desired content to the one or more mobile devices. Secure or unsecure connection provided via a decorated uniform resource locator can be used to connect a mobile device, the proxy server, and an origin web server.

Description

    RELATED APPLICATION
  • This application claims priority to application Ser. No. 60/______, filed Nov. 6, 2000, entitled “Web Page Content Translator”, which is assigned to the assignee of this application. The disclosure of application Ser. No. 60/______ is incorporated herein by reference.
  • BACKGROUND OF THE INVENTION
  • 1. Field of the Invention
  • The present invention relates generally to dynamically extracting and reformatting existing web page content and, more particularly, to dynamically extracting a portion of content from a web page and reformatting the extracted content for viewing on a mobile device.
  • 2. Background Description
  • Organizations of all sizes are reliant on the Internet to conduct business. Because of the explosion of mobile enterprise solutions, users of wireless devices now demand that businesses deliver web content for viewing on desktop, or mobile/portable (e.g., handheld) devices. Whether organizations are creating new web applications, or extending existing infrastructure, the new Internet powered world demands that users have access to the applications and information they need when they need it to speed business, remain flexible and competitive, and drive stronger customer relationships.
  • Before now, the solutions available for delivering web content to mobile devices generally required organizations to develop and maintain multiple sets of content, one for viewing in a desktop environment, and others for viewing on each individual type of mobile device. Further, secure connections between mobile devices and web servers via a proxy server that reformats original web page content were generally unavailable via a decorated uniform resource locator (URL) connection. A need exists, therefore, for a standards based, create once, deliver everywhere approach to web enabling mobile devices.
  • SUMMARY OF THE INVENTION
  • It is a feature and advantage of the present invention to provide a system and method that dynamically extracts a portion of web content for viewing on mobile devices;
  • It is another feature and advantage of the present invention to provide a system and method that reformats extracted web content for viewing on mobile devices using transforms that, for example, add meta tag information to the header of a page, add a specific attribute and attribute value to a specific tag, ignore previously specified global conversions, and/or insert text from a specified file;
  • It is yet another feature and advantage of the present invention to manage and maintain a single set of web content that can be used in both desktop and mobile device environments;
  • It is still another feature and advantage of the present invention to eliminate the need to maintain multiple sets of web content, one for each device type, for delivery to a plurality of mobile devices.
  • It is another feature and advantage of the present invention to optionally provide a secure connection via a decorated URL between a mobile device and/or a client (e.g., a Wireless Access Protocol (WAP) gateway) which forwards a secure request from the mobile device, a proxy server that reformats original web page content, and a web page server.
  • It is another feature and advantage of the present invention to provide a secure connection between, for example, a proxy server that reformats an original web page and an origin web page server by setting up the proxy server in a mobile device browser (i.e., enabling the mobile device to communicate with the origin web page server via the proxy server).
  • To achieve these features and advantages, the present invention provides a system, method, and medium that extracts a portion of web page content and reformats the extracted content for delivery to one or more wireless devices. Embodiments of the present invention contemplate that web-based content can be created one time, whereafter at least a portion thereof is extracted, reformatted, and transmitted to, for example, one or more handheld device browsers (e.g., the Palm Web Clipping Browser from Palm, Inc., Santa Clara, Calif., Pocket Internet Explorer from Microsoft Corp, Redmond, Wash., and Wireless Access Protocol (WAP) on smart phones, etc.). This create-once, deliver-everywhere approach eliminates the need to build and maintain separate web pages for different devices and browsers, as well as the need to install proprietary browser software on the handheld device(s). In one embodiment contemplated by the present invention, a user generates a request, from a mobile device to a proxy server. The proxy server then forwards the user request to an origin web server (having a first file format), whereafter the requested web page is returned to the proxy server. The appropriate components (e.g., tags, etc.) of, for example, the HTML or Wireless Markup Language (WML) source code, are extracted from the web page. The extracted web page contents are then reformatted to place the extracted web page contents in a format the is viewable by one or more mobile devices. The reformatted web page is then transmitted from the proxy server to the requesting mobile device. The may be done for at least one of groups of devices, individual devices, web site-specific conversions, or for all web sites. The method of the present invention also provides a secure connection via a decorated URL between a mobile device and/or client (e.g., a WAP gateway) which forwards a secure request from the mobile device, a proxy server that reformats original web page content, and a web page server.
  • Before explaining at least one embodiment of the invention in detail, it is to be understood that the invention is not limited in its application to the details of construction and to the arrangements of the components set forth in the following description or illustrated in the drawings. The invention is capable of other embodiments and of being practiced and carried out in various ways. As such, those skilled in the art will appreciate that the conception, upon which this disclosure is based, may readily be utilized as a basis for the designing of other structures, methods and systems for carrying out the several purposes of the present invention. It is important, therefore, that the claims be regarded as including such equivalent constructions insofar as they do not depart from the spirit and scope of the present invention.
  • BRIEF DESCRIPTION OF THE DRAWINGS
  • The Detailed Description will be best understood when read in reference to the accompanying figures wherein:
  • FIG. 1 is a representative simplified block diagram of a mobile device, a proxy server, and a content server which also illustrates an overview of the method according to the present invention;
  • FIG. 2 is a schematically simplified flow diagram of the conversion workflow for HTML mobile devices;
  • FIG. 3 is a flow diagram illustrating a process of creating a device profile;
  • FIG. 4 is a representative screen display wherein a device profile can be created;
  • FIG. 5 is a site-mining workflow diagram;
  • FIG. 6 is a diagram of the Document Object Model (DOM);
  • FIG. 7 is a flow diagram illustrating a process of creating conversions for a group of mobile devices;
  • FIG. 8 is an exemplary screen display wherein conversions are defined for a group of mobile devices;
  • FIG. 9 is a flow diagram illustrating a process of creating conversions for particular mobile devices;
  • FIG. 10 is a flow diagram illustrating a process of creating conversions for all web sites;
  • FIG. 11 illustrates one example of a central processing unit for implementing a computer process in accordance with a computer implemented stand-alone embodiment of the present invention; and
  • FIG. 12 illustrates one example of a block diagram of internal hardware of the central processing unit of FIG. 11.
  • DETAILED DESCRIPTION OF A PREFERRED Embodiment of the Invention
  • FIG. 1 illustrates an architecture 100 as contemplated of the present invention (and environments thereof). Referring now to FIG. 1, it is envisioned that a proxy server 110 reformats/converts web content 104 on an origin web server 102 into a format 122 readable on any mobile device 108 (which can be any number of different mobile device types). Details of the architecture of the present invention, the order in which conversions are processed, and how mobile devices 108 are connected to proxy server 110 through the present invention are explained herein.
  • The proxy server 110 of the present invention “sits” between the clients (e.g., the mobile device(s) 108) and the origin web server(s) 102 that provide Web content 104. If necessary, a gateway 109 may optionally be provided that interfaces between, for example, the mobile device 108 and the proxy server 110. In this context, an origin web server 102 is a web server that contains the original web page 104. It is different from, for example, the proxy server 110 because the original web server 102 is maintained and updated by the individual(s) and/or organization(s) that hosts the web site for the web page 104. Unlike other proxy servers, however, the present invention obtains the code (e.g., HTML) of the user requested web page 104, and modifies it at the proxy server 110 (once obtained) in accordance with at least one novel method described herein. Embodiments contemplated by the present invention also envision reformatting and/or converting an entire web site or request specific Web content that is needed from the origin web server 102.
  • In general, embodiments of the present invention contemplate that architecture 100 comprises one or more servers 102 having web content (in the form of at least one web page 104), a proxy server 110, at least one mobile device 108, and at least one network 114. For simplicity, only one of each of the mobile device 108, server 102, and network 114 are shown in FIG. 1, although in general the system 100 may comprise multiples of each. It is envisioned that each instance of web content 104 each have associated therewith a URL.
  • Upon a request 106 from a mobile device 108 for a given web page 104, typically made through a HyperText Transport Protocol (HTTP) from the resident mobile device, or HyperText Transport Protocol Secure (HTTPS) request from the resident mobile device 108 browser, the process for providing a reformatted/converted and extracted web page 104 begins. It should be understood that the gateway 109 will receive such a HTTP or HTTPS request if a gateway 109 is used. Upon determining that the requested page 104 resides at the server 102, the proxy server 110 makes a request 112 for the page. As shown, the proxy server 110 and the server 102 are connected via a network 114 such as the Internet. It should be understood that the present invention can be used with networks other than the Internet where visual content is involved. Therefore, depending on the network(s) being utilized in conjunction with the present invention, it should be apparent that the visual content from such network(s) may be other than “web” content. The server 102 responsively returns 116, via the network 114, the requested web page 104 to the proxy server 110. The web page 104 is typically an HTML file with references to any component .wav, .mov, and/or Joint Photographic Experts Group (JPEG) files, which together comprise the web page 104. It should also be understood that other file formats (e.g., .gif (graphics interchange format)) and web page components (e.g., Java applets) can also be accessed and returned to the proxy server 110.
  • The conversion engine 118, preferably residing within the proxy server 110, retrieves and/or accesses the stored web page 104, and accesses a predefined extraction and conversion file associated with the mobile device 108 and/or web page 104, preferably via the extraction and conversion file database 120. Extraction and conversion files may, for example, contain the following information:
      • Variables: These are variables that are defined when a site-mining expression is created. A variable is essentially a place holder for the information to “go” after the conversion engine 118 extracts it from a web page 104 preferably residing on server 102. A site-mining expression is a command that tells the conversion engine 118 where to locate the desired web content (in, for example, the HTML code) in the web page 104. One embodiment of the present invention uses software such as Spyglass Prism from OpenTV, Inc., Mountain View, Calif. to extract data from a designated web page 104. Methods that can be used in site-mining expressions in accordance with the Spyglass Prism product are contained in, for example, the Exemplary Site Mining Methods section and other sections contained herein.
      • System variables: Embodiments of the present invention contemplate that there are preferably at least three system variables that can be added to extraction and conversion files, including:
      • a) &&Host;
      • Identifies the name of the server 102 that the proxy server 110 is connecting to for a particular request 106.
      • b) &&User-Agent (UA);
      • Identifies the type of mobile device 108 and the web browser of the mobile device 108.
      • c) &&URLLink;
      • Identifies the address of the server 102 that the proxy server 110 is connecting to.
  • It should be understood that the variables and delimiters are illustrative only and that different variables and/or delimiters can be used to achieve the same functionality
      • Transforms: Transforms are conversion tags that are used to re-format the content extracted from a web page 104. These special tags (also called sw-transforms) provide the power to display the Web content in the desired format 122 for a mobile device(s) 108. The present invention provides transforms that, for example: add meta tag information to the header of a page, add a specific attribute and attribute value to a specific tag, ignore previously specified global conversions, insert text from a specified file, remove a specific attribute from all tags, remove a specific attribute from a specific tag, remove the comments tag from a web site or specific web content, remove a specific tag from a web site or web content, remove a specific tag and all the information that appears within the tag from a web site or web content, replace one tag with another, set a specific value of a specific attribute of a specific tag, stop processing of all subsequent reformatting commands, substitute one sequence of text for another sequence of text, and remove table formatting. The sw-transforms used to reformat the extracted web content are contained in the SW-Transforms section contained herein.
  • Mobile devices 108 generally come in a variety of different sizes and have a variety of different screen interfaces. As will be discussed in further detail herein, the present invention provides the ability to uniquely tailor web page 104 content for specific mobile devices 108. A particular organization may know that its users will always be retrieving web pages using, for example, Palm operating system devices (e.g., Palm III, X, VIIs, etc.). Formatting rules may be set up that apply to the group of Palm operating system devices generally, as well as, for example, the Palm VII in particular. To create a device profile, both the specific version of a mobile device 108 and its web browser (e.g., a Palm V with browser A, etc.) are needed. In one embodiment, device profiles are registered with the proxy server 110 by using HTTP request headers, as will be explained in detail herein.
  • It should also be understood that in addition to providing a device profile for an individual mobile device 108, device profiles can also be created for a group of mobile devices 108, as well as all mobile devices 108. In the latter case, suppose, for example, an organization's mobile device 108 users will often be visiting graphic-intensive web sites, and that the users will be viewing these sites on, say, smart phones (i.e., a cellular telephone that provides voice, limited Internet access, e-mail, pager and/or facsimile service, and typically has a small screen and little memory). A global extraction and conversion file can be created that, for example, instructs the conversion engine 118 to replace all graphics with text links. This conversion would affect all web content that is delivered to all mobile device 108 users. Users can therefore access web sites they need without the inconvenience of waiting online for graphics to download onto their mobile devices 108.
  • Thus, using an extraction and conversion file within the storage 120 corresponding to the particular mobile device(s) 108, the conversion engine 118 uses the expressions defined therein, and performs the designated operations upon, for example, the HTML code contained in the web page 104. The designated HTML content of the retrieved web page 104 is extracted, subsequently and/or converted, and transmitted as a reformatted web page 122 to the mobile device 108.
  • To improve performance (e.g., speed), web page 104 can optionally be cached in a local cache 124 on the proxy server 110. Caching enables web pages 104 to be processed faster, thereby reducing the time mobile device 108 users spend online. When the proxy server 110 receives a web page 104 over, say, the Internet 114, the conversion engine 118 can convert and store the web page 122 in a web page 122 specific cache. When a user of a mobile device 108 wants to access the web page 122, the conversion engine 118 retrieves it from the cache 124, which reduces online time.
  • It should also be understood that the proxy server 110 can also cache unconverted web page 104 content. Unconverted web page 104 content is content received from the server 102, which has not yet been converted and/or extracted by the conversion engine 118. Cache settings can therefore be configured to meet specific needs (e.g., when caching will begin, the length of time pages will be kept in cache, and the amount of disk space and memory that will be allocated to caching).
  • Security Features
  • The proxy server 110 according to the present invention envisions the use of various types of security to ensure that the transmission of information is secure (e.g., that unauthorized parties cannot intercept and/or access the information). An example envisioned by embodiments of the present invention provides the ability to support the secure socket layer (SSL) protocol developed by Netscape Corp. (now merged with America Online, Inc., Dulles, Va.). When this feature is utilized, users can make secure connections (from, for example, a mobile device 108 to the proxy server 108 and from the proxy server 108 to the origin web server 102 and back), as well as partially secure connections. In embodiments contemplated by the present invention, the proxy server will the proxy server will load an SSL library, which includes, for example, SSL 2.0 and SSL 3.X protocol specification modules.
  • If the SSL feature of the present invention is utilized, a digital certificate from a certificate authority (e.g., VeriSign) must be obtained. The digital certificate is sent to a client (e.g., a mobile device 108 or a gateway 109) to authenticate the proxy server 110, in order to establish a secure connection between the client and the proxy server 110).
  • Embodiments of the present invention contemplate that there are at least four types of SSL settings that can be configured for the proxy server 110, including, for example:
      • SSLON: This setting determines whether SSL is turned on and off. The default setting is on (as indicated by, for example, SSLON=1).
      • SSL port: This setting determines which secure port the server listens on.
      • SSL Certificate Settings: SSL certificate request settings are located in the proxy server .ini file. Changes to the default public certificate file name or the password for the certificate key (e.g., password), are made via the proxy server 110 .ini file.
      • SSLOutboundPort: This port is a listening port the proxy server 110 uses for outbound SSL requests.
  • It is envisioned that if the defaults are accepted for each of the above four SSL settings, the SSL settings in, for example, the proxy server 110 .ini file do not have to be configured.
  • Embodiments of the present invention contemplate that in the event that a particular mobile device 108 does not enable a proxy server 110 to be used, the present invention enables mobile devices to be redirected to proxy through the proxy server 110 by typing (or in some way, entering or implementing) the proxy server 110 address (location) and the URL of the desired web site 104 in, for example, an address field of the mobile device 108 browser. This type of address is commonly referred to as a “decorated URL”. A decorated URL contains, for example, the proxy server 110 host name and port number, and the web address of the web site 104 that is to be accessed.
  • With the present invention, the above-identified URL decoration can be used to make an un-secure (http://) request or a secure (https://) request. Regardless of what type of connection is made, after an initial decorated URL is typed in, the proxy server retrieves the desired web page 104. For example, the proxy server automatically re-writes all of the other links within the site that are initially proxied to via the decorated URL. That is, if one or more links are embedded within a first web site, and a user clicks on one of the links, the link that the user clicks on will also be “rewritten” in decorated form in accordance with the invention. Also, if a connection is made to an un-secure site, and a user subsequently clicks a secure link within that web site, the proxy server 110 automatically re-decorates the URL, to provide the secure connection. Therefore, a user only has to type the decorated URL once each time a new Web site is accessed.
  • As indicated above, embodiments of the present invention contemplate that a decorated URL contains the proxy server 110 host name and port number, and the web address of the site that is to be accessed. For example, a decorated URL for the Aether Software Web (www.aethersystems.com) site may look like:
  • http://yourscoutweb_domain_name:port_number/?url=
  • http://www.aethersystems.com.
  • Secure requests made either to and/or from the proxy server 110 can be done by using a decorated URL. If a decorated URL is being used, there are three options. First, a completely secure connection can be made from the mobile device 108, and optionally forwarded by the gateway 109 (if one is used), to proxy server 110, and from the proxy server 110 to the origin web server 102 (i.e., the user makes a secure request to the proxy server 110 and a secure request to the web page 104. The origin server 102 then encrypts the user request and the web page 104 that is returned to the mobile device.). This type of connection provides end-to-end security and is useful, for example, for e-commerce sites or for secure Web-based applications. This type of decorated URL may look as follows:
  • https://yourscoutweb_domain_name:port_number/?url=
  • https://www.aethersystems.com.
  • Second, a secure connection can be made between the mobile device 108, including the gateway 109 (if one is used), and the proxy server 110. A Z business or content provider, for example, that uses the proxy server at the bridge of a firewall may want users to make a secure connection to the proxy server 110. This is a partially secure connection. This embodiment contemplates a secure connection between, for example, at least a gateway to which the mobile device 108 interfaces, and the proxy server 110. This type of decorated URL may look, for example, as follows:
  • https://yourscoutweb_domain_name:port_number/?url=
  • http://www.aethersystems.com.
  • Finally, a secure connection can be made between the proxy server 110 and the origin web server 102. For example, a wireless ISP may want to have users make a regular un-secure request in order to access the proxy server 110, and then make a secure connection between the proxy server 110 and the origin server 102. In this case, the decorated URL may look, for example, as follows:
  • http://yourscoutweb_domain_name:port_number/?url=
  • https://www.aethersystems.com.
  • It will be understood that, depending on the mobile device, the menus that a user will need to access on the mobile device to set up the decorated URL will vary. For example, on a PALM V device, the HandWeb icon in the applications launcher can be tapped to display the last page accessed. Then, the menu button can be tapped to display the Options menu, in which the Open Location menu item may be tapped. The decorated URL may then be typed in the URL field, and the web site corresponding to the URL is then accessed.
  • FIG. 2 is a simplified flow diagram of a conversion workflow for HTML-based mobile devices, as contemplated by the present invention. In step 201, a device profile is created for each type mobile device 108 in accordance with the HTTP. It is envisioned that each mobile device 108 is registered with the proxy server 110 to indicate which conversions for the device 108 are desired. Then, when conversion engine 110 receives a request 106, it compares the headers in the request 106 with the headers in an extraction and conversion file associated with the requesting mobile device 108 to determine which conversions to perform.
  • One method of performing step 201 as contemplated by embodiments of the present invention is shown in FIG. 3. In step 302, user-agent (UA) information (i.e., mobile device 108 information) is provided to the proxy server 110 that uniquely identifies a type of mobile device 108 (e.g., by make and/or model) and the Web browser used on that device. The user-agent information is stored in either the device profile information on the proxy server 110 or, for example, in a global file that stores such information for all devices 108.
  • In step 304, in accordance with the HTTP (and HTTPS) specification, UA-color information is provided via a header that specifies, for example, the screen color of the mobile device 108. In various embodiments if a mobile device 108 sends this header, the conversion engine 110 performs color reduction automatically taking into consideration, for example, the screen color of the mobile device 108. If the mobile device does not send the UA-color header, a color reduction conversion for the mobile device 108 can be configured. If the mobile device 108 does send a UA-color header, the value sent in the header can optionally be overridden to improve device performance by, for example, reducing colors to a level lower than the device's maximum capability.
  • The UA-connection type (e.g., HTTP or HTTPS) between the mobile device 108 and the proxy server 110, and/or the proxy server 110 and the origin web server 102 is specified in step 306. The UA-connection is used to specify the type of connection that the mobile device 108 connects to. In step 308, the UA-CPU is specified. This information is used to specify the CPU (e.g., the manufacturer, model, and/or clock speed) of the mobile device 108. In step 310, the UA display field is used to specify the display type of the user agent. In step 312, the UA-HTML field is used to specify the version of HTML of the mobile device 108. In step 314, The UA-input field 414 is used to specify the types of input fields (e.g., password field, text box, image, file, etc.) of the mobile device 108 screen display. In step 316, the UA-language field is used to specify the language of the mobile device 108 (e.g., English, Spanish, etc.). In step 316, other fields, such as UA-operating system can be used to specify, e.g., the operating system of the mobile device 108, as well as other items of information. It will be recognized that not all of the above-identified steps will be applicable to every type of mobile device 108.
  • FIG. 4 shows a representative screen display that may be used to enter the data of FIG. 3. The UA field 402, UA-color field 404 field, UA-connection field 406, UA-CPU field 408, UA-display field 410, UA-HTML field 412, UA-input field 414, and UA-language field 416 are shown. As indicated in step 316, other input fields, such as, for example, the UA operating system, may also be provided.
  • Mobile device 108 profiles, as previously noted, can comprise a series of device headers based on fields 402, 402, 406, 408, 410, 414, 416 (e.g., HTTP request headers). When a user requests a web page 104 using a mobile device 108, the mobile device 108 sends associated HTTP request headers, which uniquely identify the mobile device 108 to the proxy server 110. A mobile device 108 is generally defined by both the hardware and browser. The device headers thus serve to identify the mobile device 108 to the proxy server 110.
  • In step 202, site-mining is performed, where web page content is extracted from a web page 104. The site-mining 202 process as contemplated by embodiments of the present invention is shown in FIG. 5. In step 502, the desired web page 104 is retrieved by the proxy server 110. The retrieved document is envisioned to be a HTML-based or similar document (e.g., a WML document). In step 504, a Document Object Model (DOM) (shown at 600 in FIG. 6) corresponding to the retrieved web page 104 is created. The DOM 600, as proposed by the World Wide Web Consortium (W3C), is a standard internal representation of the document structure and attempts to make it easier for programmers to access components and delete, add or edit their content, attributes and style. In essence, the DOM 600 makes it possible for programmers to write applications which work properly on all browsers and servers, and on all platforms. While programmers may need to use different programming languages, they do not need to change their programming model. The W3C's DOM 600 thus offers programmers a platform- and language-neutral program interface which will enable programming across platforms with languages such as, for example, Java and ECMAScript.
  • Referring to FIG. 6, the DOM 600 shown therein is an exemplary representation of an HTML document in which all elements are treated as objects. The DOM is a platform-neutral and language neutral interface allowing dynamic access and updating of content, structure, and style of documents. A single DOM object can represent an element (e.g., the text in an element or an attribute value), the entire document (e.g., web page 104) or a collection of objects. The DOM 600 object hierarchy is a series of nested objects, where each object contains either data or additional objects. The topmost object is the HTML document 602 (e.g., web page 104) itself. For further reference, see the W3C's DOM Level 1 Specification, dated Oct. 1, 1998, which is incorporated herein by reference.
  • In step 506, objects are extracted from the web page 104 in accordance with the DOM 600. For example, the name of the tag the content resides in must be determined (e.g., table), as well as the tag number (e.g., is it the first table? Second?). Also, whether the content is in a sub-tag or child of a parent tag should be determined. If so, what number is it? (e.g., if it is a table row that is desired, then what number is it?)
  • In step 508, the site-mining expressions, contained in an extraction and conversion file 512, are performed on the extracted object(s) of step 506. Embodiments of the present invention contemplate that one or more methods having the functionality of the methods provided in, for example, the Exemplary Site Mining Methods section will be used to extract the desired content. In accordance with the present invention, one or more of the conversion methods shown in the Site-Mining Expressions Examples section is used to convert/reformat one or more of the extracted objects to facilitate display on one or more mobile devices 108. Then, in step 510, after applying the operations contained in the extraction and conversion file 512 to the web page 104, the transformed web page 122 is provided and transmitted to one or more mobile devices 108. (However, prior to the transmission to one or more mobile devices, other types of conversions can also be performed, as indicated in FIG. 2).
  • The following three examples of site-mining expressions are provided. The expressions utilize methods defined in, for example, the Exemplary Site-Mining Methods section. As shown by the following examples, a site-mining expression specifies a path to an object (HTML element) from the DOM (e.g., web page 104) using methods defined in the site-mining expression language as shown in the Exemplary Site-Mining Methods section. Each of the methods contained in the Exemplary Site-Mining Methods section performs an action on a collection of objects in the object hierarchy. Each method returns a list of one or more objects. It should be understood the following examples are illustrative only, and that the potential number of HTML source code and expression combinations are virtually infinite.
  • Site-Mining Expression Examples
  • Original HTML code
    <HTML>
    <HEAD> <TITLE> Title of the Page </TITLE> </HEAD>
    <BODY>
     <TABLE WIDTH=“600” ID=“ScoutWeb”>
      <TR><TD> table 1, row 1 </TD></TR>
      <TR><TD> table 1, row 2 </TD></TR>
      <TR><TD>
       <TABLE WIDTH=“300”>
        <TR><TD ID=“ScoutWeb”> table 2, row 1 </TD></TR>
        <TR><TD> table 2, row 2 </TD></TR>
       </TABLE>
      </TD></TR>
     </TABLE>
    </BODY>
    </HTML>
  • Site mining expression #1:
  • titleEx1=document.all.tags(“TITLE”).item(0).html; produces:
  • <TITLE> Title of the Page </TITLE>
  • Site mining expression #2:
  • titleEx2=document.all.tags(“TITLE”).item(0).text; produces
  • Title of the Page
  • Site mining expression #3:
  • tableEx1=document.all.tags(“TABLE”).item(1).html; produces
    <TABLE WIDTH=“600” ID=“ScoutWeb”>
      <TR><TD> table 1, row 1 </TD></TR>
      <TR><TD> table 1, row 2 </TD></TR>
      <TR><TD>
       <TABLE WIDTH=“300”>
        <TR><TD ID=“ScoutWeb”> table 2, row 1 </TD></TR>
        <TR><TD> table 2, row 2 </TD></TR>
       </TABLE>
      </TD></TR>
     </TABLE>
  • In step 204, group conversions can be optionally performed. Group conversions are conversion rules that are applied to a group of similar mobile devices. For example, a group conversion can be applied to all Palm operating system devices. After such group conversion rules have been created, these rules can be applied to every new version of a Palm operating system device that is added to the system. Using group conversions saves time, for example, because it saves from having to keep reentering the same conversion rule(s) for all versions of a device (e.g., Palm 3x, Palm VII, etc.). Thus, e.g., one or more predefined conversions can be applied to any device(s) using a given operating system (e.g., Palm OS).
  • A method (as contemplated by embodiments of the present invention) of performing step 204 is shown in FIG. 7. In step 702, an individual can define whether images are to be replaced with, for example, a text link field 602. In step 704, an individual can optionally scale images and image maps. In general, the user can type the percentage as an integer between, for example, 1 and 100. In step 706, an individual can reduce the colors of the graphics in the web page 104 contents being converted. For example, the mono number or color number (#=1, 2, 4, 8, 16, or 24, etc.) can be provided as input.
  • In step 708, the resolution of the graphics in the web page 104 being converted can be reduced. In general, the percentage can be entered as an integer between 1 and 100. In step 710, interpolation can optionally be used to improve image quality. This feature allows tuning of the quality of the scaled images. For example, an individual can select “yes” if he or she is scaling images and wants to improve quality. In step 712, the file format of images can be selected (e.g., .gif or JPEG).
  • In step 714, the quality of JPEG conversion is specified. Here, an individual can enter, for example, an integer between 0 and 100, where 100 indicates the highest quality. In step 716, images larger than a prespecified size can optionally be removed (i.e., from being sent to a mobile device 108). An individual can, for example, enter the number of the maximum file size to be sent to a mobile device 108 in kilobytes.
  • In step 718, an “always send converted image” feature can optionally be invoked. This will send a converted image even, for example, if the file size is larger than that specified in step 716. In step 720, the conversion engine 110 can be directed to send an error message to the corresponding mobile device 108 if an image conversion fails. In step 722, the conversion engine can be directed to remove comments (e.g., either in <COMMENT> tags or in <!--comment--> format) from the content. An individual can select “Yes”, for example, to remove all comments, or “No”, for example, to leave them in the content.
  • It should also be understood that additional settings regarding group conversions can optionally be provided in accordance with the present invention that allow users to, for example, translate tables, remove a tag, remove tag and content, replace tag, remove an attribute from a tag, add an attribute to a tag, set an attribute value, scale an attribute value, and/or set an attribute minimum and/or maximum. Illustrative examples of these features are provided in the Site-Mining Expression Examples section.
  • A representative screen display corresponding to the method shown in FIG. 7 is provided in FIG. 8. As shown, field 802 enables images to be replaced with text links. Other fields are also shown corresponding to the steps shown in and discussed with regard to FIG. 7.
  • Returning to FIG. 2, in step 206, device conversions can be optionally performed. Device conversions are rules that change or format Web content according to, for example, the specific version of a device and its web browser. As previously discussed with regard to step 204, a group conversion can be set up that is applicable to, say, Palm operating system devices. Using device conversions, it is possible to, for example, specify more specific formatting rules that apply to individual device types within, for example, the Palm OS family (e.g., Palm III, Palm X, Palm VII, etc. devices). As shown in FIG. 9, the method of performing a number of recommended conversions for specific mobile devices 108 is provided. In step 902, conversions are performed for mobile devices 108 that, for example, support Java scripts or applets. In step 904, conversions for gray-scale devices are made. Potential conversions include, for example, removing the <U> tag, encoding images as GIF, and converting any color header images to gray scale.
  • In step 906, conversions can be created for color devices. Such conversions for color devices will depend, for example, on goals. If the goal is to optimize the performance of the server 102, then either reducing images to gray scale by specifying a color depth (e.g., mono8 or lower), or reducing the resolution to decrease file size (e.g., enter 90 percent or lower) is generally recommended. In step 908, the effect of removing background images can be considered. Many web pages 104 use light text and a dark background. If the background images or color are removed, the light text becomes unreadable. Therefore, a conversion to remove the color attribute of the <FONT> tag can be provided. However, in one embodiment, it is not recommended that the width and height attributes of the <IMG> tag be removed. These attributes enable the mobile device 108 browser to format the display faster. Finally, it should also be understood that image conversions will slow down the performance of the proxy server 110. If the mobile device 108 web browser converts images fairly well (e.g., work as a clipper), it may be preferable to let the browser handle image conversions. It should be understood that in one embodiment a device specific conversion will override, for example, corresponding parameters and/or values specified in group conversions.
  • Of course, it should be understood that various other conversion types in addition to, and/or in lieu of, those mentioned in FIG. 9 are also contemplated by embodiments of the present invention.
  • Returning to FIG. 2, in step 208, site-specific conversions can be optionally performed. Site-specific conversions are rules that change or format web page 104 content for a specific web page 104, or for those web pages within a given directory, or site (or portion thereof). The number of possible conversions is virtually infinite, and may include any of the appropriate combinations of methods and transforms.
  • In step 210 of FIG. 2, global conversions can be optionally performed. Global conversions are rules that change or format web content on all web pages 104 for either one type of device or all devices. One possible method of performing global conversions is indicated in FIG. 10. In this exemplary embodiment, the conversion does not have an effect on the content the user sees, but decreases the amount of data sent, thus providing a faster download experience for any user. It should be understood that FIG. 10 is illustrative only, and that the invention enables numerous other operations to be performed on web pages depending on, for example, the needs and/or types of mobile devices 108 that a particular organization may utilize.
  • Referring now to FIG. 10, in step 1002 HTML comments are first removed. In step 1004, the largest file size for converted images is specified. That is, the largest amount of image data that is to be transmitted to a mobile device 108 is specified. The amount can be based at least on the type of Internet connection the mobile device 108 uses. For example, if the mobile device 108 has a slow connection, the conversion engine 118 can be configured to omit images over a specified size. If the mobile device 108 has a faster connection, larger file size value can be specified. In step 1006, HTML tags that the browser does not support are removed. A list of unsupported HTML tags can be obtained from, for example, the manufacturer of the browser on the mobile device 108. The conversion engine 118 can then be configured to remove and/or replace them. In general, it is typically more efficient, and therefore preferable, for the conversion engine 118 to remove such tags rather than sending information to the mobile device 108 which cannot be used. Finally, in step 1008, attributes should be scaled. In many instances, the size of an item is specified in HTML as a percentage, to which the browser automatically scales the item. For cases where the size of an item is specified in HTML as pixels, however, the size can be reduced to ensure that it fits in the display area for the device.
  • Exemplary Site-Mining Methods
  • This section contains a list of all of the site-mining methods. Each method reference contains the following information:
      • Method name
      • Description: A brief description of the method including a list of all objects the method can extract from an HTML page.
      • Preceded by: For methods that have to come after a particular method.
      • Followed by: A list of other methods that you can use in the site-mining expression following the object specified by this method. Because a site-mining expression drills down to a specific object in the DOM hierarchy, these methods must be provided in a specific order.
      • Example: Excerpts from an examplesite-mining expression used to extract content from a web site.
  • all
    Description: This method returns all elements contained in
    the proceeding object.
    Followed tags, item, grep, attributeMatch, text,
    by: getAttribute, html
    Example: document.all.html;
    Note: Allsite-mining expressions start with
    document.all.
    areas(n) or areas
    Description: Returns one or all areas defined in an image map
    Preceded Map
    by:
    Followed all, grep, attributeMatch, text, getAttribute, html
    by:
    Example: document.all.tags(“MAP”).item(0).
    areas(2).getAttribute(“HREF”);
    Results: This returns the HREF attribute from
    the 3rd area of the first image map in the
    document.
    attributeMatch
    Returns: Returns the object(s). Elements that contain these
    attribute name/value pairs.
    Followed all, grep, attributeMatch, text, getAttribute, html
    by:
    Example: document.all.tags(“TABLE”).attributeMatch
    (WIDTH=”300”).html;
    Results: This returns the html of the table(s) that
    have a WIDTH attribute set to 300.
    cells(n) or cells
    Returns: One or all cells in a table row.
    Preceded Table row. (TR)
    by:
    Followed all, grep, attributeMatch, text, getAttribute, html
    by:
    Example: document.all.tags(“TABLE”).item(
    0).tags(“TR”).item(4).cells.html;
    Results: This will give you the HTML for all of
    the cells (TD tags) in the 5th row of the 1st table
    in the HTML document.
    children(n) or children
    Returns: This returns children(n) or children. One or all
    children of form or list.
    Preceded This element will return one or all children
    by:
    Followed all, grep, attributeMatch, text, getAttribute, html
    by:
    Example: document.all.tags(“FORM”).item(0
    ).children.html;
    Results: This returns the html of all children
    objects of the 1st form.
    document.all.tags(“UL”).item(3).
    children(2).text;
    Results: Returns the text of the 3rd list item in
    the 4th unordered list in the document.
    document
    Returns: An HTML document.
    Preceded
    by:
    Followed all
    by:
    Example: document.all.html
    elements(n) or elements
    Returns: One or all elements in a form.
    Preceded FORM
    by:
    Followed all, grep, attributeMatch, text, getAttribute, html
    by:
    getAttribute
    Description: The value of the specified attribute from the
    proceeding tag.
    Preceded Any tag that has the specified attribute.
    by:
    Followed Nothing. You can not have another method
    by: follow this method.
    Example: document.all.tags(“FRAME”).attri
    buteMatch(NAME=“main”).
    Returns: The SRC attribute from the FRAME
    tag that is named “main”.
    grep
    Returned: This method returns elements containing text
    that matches the regular expression.
    Preceded Any method returning an object that contains
    by: text to match the regular expression.
    Followed all, grep, attributeMatch, text, getAttribute, html
    by:
    Example: document.all.tags(“TABLE”).grep(
    “Table of Contents”).html;
    Results: Returns all tables that contain the text
    “Table of Contents” anywhere inside the
    <TABLE>tags.
    HTML
    Description: This method returns the HTML tags and the text
    in an element.
    Followed Nothing. You can not have another method
    by: follow this method.
    Example: document.all.html;
    Results: All of the HTML in the document (the
    original HTML page).
    item(n)or item(“name”)
    Description: The nth + 1 element in a collection of elements, or
    elements with name specified as an ID or name
    attribute value.
    Followed all, grep, attributeMatch, areas, elements,
    by: options, rows, children, text, getAttribute, html
    Example: document.all.item(“sw-Main”).
    html;
    Results: Returns the HTML of all elements that
    contain a NAME-”sw-Main” attribute or an ID-”
    SW-Main” attribute.
    options(n) or options
    Description: Returns one or all options in a form's select list.
    Preceded Select tag in a form.
    by:
    Followed all, grep, attributeMatch, text, getAttribute, html
    by:
    Example: document.all.tags(“FORM”).item(0
    ).tags(“SELECT”).options.html;.i
    tem(0)
    Results: Returns the HTML for the options in the
    1st Select element in the 1st form of the HTML
    document.
    rows
    Description: Returns one or all rows in a table.
    Preceded Table.
    by:
    Followed all, cells, grep, attributeMatch, text, getAttribute,
    by: html
    Example: document.all.tags(“TABLE”).item(
    0).rows(2).cells(0).text;
    Results: Returns the text in the 1st cell of the 3rd row in
    the 1st table of the HTML document.
    tags
    Description: Returns all “tag” tags.
    Followed all, item, grep, attributeMatch, areas, elements,
    by: options, rows, children, text, getAttribute, html
    Example: document.all.tags(“P”).html;
    Results: Returns the HTML for all Paragraph <P> tags in
    the HTML document.
    text
    Description: This element gets the text contained in a list of
    objects
    Followed: Nothing. You cannot have another method
    by follow this method
    Example: document.all.tags(“TITLE”).item(
    0).text
  • All Site-Mining Expressions
  • The following table summarizes all of the site-mining methods that can be used to build site-mining expressions.
  • Method Object Returned by This Method
    all All elements contained in an object
    areas(n) or areas One or all areas defined in an image map
    attributeMatch Elements that contain these attribute
    (name=value[, name/value pairs
    name=value])
    cells(n) or cells One or all cells in a table row
    children(n) or children One or all children of an object
    document HTML document
    elements(n) or elements One or all elements in a form
    getAttribute(“attribute_id”) Value of the attribute
    grep(“regular Elements containing text that matches
    expression”) the regular expression
    html HTML representation of an element
    item(n)or item The nth + 1 element in a collection of
    (“name”) elements, or elements with name
    specified as an ID or name attribute value
    options(n) or options One or more.
  • Methods Used to Get Objects
  • Object Needed Method
    An HTML document document
    All elements contained in an object all
    nth + 1 element in a list of elements item(n)
    Elements with name specified as an ID or item(“name”)
    name attribute value
    Elements with this HTML tag tags(“tag”)
    Elements with this attributeMatch(name=value[,
    attribute name and value name=value])
    Elements containing text grep(“regular_expression”)
    that matches this regular_expression
  • SW-Transforms
      • Transform name
      • Description: a brief description of the method
      • Syntax: how the transform would appear in your template (either a site-specific template or the globals template)
      • Example: an example of the sw-transforms
  • AddHeader
    Description: This rule tells the conversion engine to add the meta tag
    information to the header of a page.
    Syntax: sw-transform “Nokia-WAP-Toolkit/ 1.2”
    AddHeader:META TAG
    NAME:META TAG VALUE
    Example: To add the header, <META
    name=“PalmComputingPlatform”
    content=”true”> to all Web content, you would
    enter the following text in the globals.txt file:
    sw-transform “Mozilla/2.0
    (compatible;Elaine/1.0)”
    AddHeader:PalmComputingPlatform:
    True.
    AddAttributteToTag
    Description: This rule tells the conversion engine to add a specific
    attribute and attribute value to a specific tag. The
    rule includes the tag name, the attribute and the
    attribute value, each separated by a colon.
    Syntax: sw-transform “Mozilla/2.0
    (compatible;Elaine/1.0)”
    AddAttributeToTag:TAG NAME:
    ATTRIBUTE NAME “ATTRIBUTE VALUE”
    Example: To center heading 2, you would enter:
    sw-transform “Mozilla/2.0
    (compatible;Elaine/1.0)”
    AddAttributeToTag
    H2:ALIGN:”CENTER”.
    IgnoreGlobalTransformations
    Description: This rule tells the conversion engine to ignore theglobal
    conversions.
    Syntax: sw-transform “Nokia-WAP-Toolkit/
    1.2”
    IgnoreGlobalTransformations
    Example: For example, say you applied the sw-transform
    RemoveAttributeFromTag rule to your Global
    Rules File so that you could remove all SRC
    attributes from the IMG tag from all Web sites.
    Then, you decide you need to display the images
    for a particular site. You could use the sw-transform
    IgnoreGlobalTransformations rule in
    the template forthe site tooverridethe global
    rule contained in the globals.txt file.
    sw-transform “Mozilla/2.0
    (compatible;Elaine/1.0)”
    IgnoreGlobalTransformations
    InsertTextFromFile
    Description: This rule tells the conversion engine to insert text from
    the specified file into the template.
    Syntax: sw-transform “Mozilla/2.0
    (compatible;Elaine/1.0)”
    InsertTextFromFile:path to file
    and filename.
    Example#1: sw-transform” Mozilla/3.0
    (compatible; HandHTTP 1.1
    ”InsertTextFromFile:c:\ScoutWeb\
    CommonTransforms
    Note: This can be used to create “functions of
    commonly used sw-transforms by putting
    common sw-transforms in a file and then
    referencing that file in a site-specific or globals
    template using the InsertTextFromFile
    command.
    Example#2: For this HTML code:
    <FRAMESET>
    <FRAME SRC=http://main.com”
    NAME=”main”>
    <FRAME SRC=http://nav.com”
    NAME=”nav”>
    <FRAME SRC=http://banner.com”
    NAME=”banner”>
    </FRAMESET>
    If some of the content is desired, the site
    mining expression would look like this:
    main=document.all.tags(“FRAME”).
    attributeMatch(NAME=”main”).getAttribute
    (“SRC”).text;
    The sw-transform would look like this:
    sw-transform “Mozilla/3.0
    (compatible; HandHTTP 1.1
    ” InsertTextFromFile:&%main;
    or
    If it is desired that the call to http://main.com to go
    through the conversion engine, then the following code
    may be provided:
    sw-transform “Mozilla/3.0
    (compatible; HandHTTP 1.1”
    InsertTextFromFile:http://scoutweb_server:81/&%main;
    RemoveAttributeFromAllTags
    Description: This rule tells the conversion engine to remove a
    specific attribute (such as the width) from all tags.
    Syntax: sw-transform “Mozilla/3.0
    (compatible; HandHTTP 1.1”
    RemoveAttributeFromAllTags:ATTRIBUTE
    NAME
    Example: To remove the WIDTH from all tags, you would
    enter:
    sw-transform “Mozilla/3.0
    (compatible; HandHTTP 1.1”
    RemoveAttributeFromAllTags:WIDTH
    RemoveAttributeFromTag
    Description: This rule tells the conversion engine to remove a
    specific attribute from a specific tag.
    Syntax: sw-transform “Mozilla/3.0
    (compatible; HandHTTP 1.1
    ” RemoveAttributeFromTag:TAG
    NAME:ATTRIBUTE NAME
    Example: To remove the width from a table, the following may be
    entered:
    sw-transform “Mozilla/3.0
    (compatible; HandHTTP 1.1
    RemoveAttributeFromTag:
    TABLE:WIDTH
    To remove the Background attribute from the
    Body tag, the following may be entered:
    sw-transform “Mozilla/3.0
    (compatible; HandHTTP 1.1”
    RemoveAttributeFromTag:BODY:BACKGROUND.
    RemoveComments
    Description: This rule tells the conversion engine to remove the
    comments tag from a Web site or specific Web
    content. (Comments include both general
    information on the page (such as: <!...text...>)
    and information actually within the
    <COMMENT> tag.)
    Syntax: sw-transform “Mozilla/3.0
    (compatible; HandHTTP 1.1
    ” RemoveComments
    Example: To remove comments, the following may be entered:
    sw-transform “Mozilla/3.0
    (compatible; HandHTTP 1.1
    ” RemoveComments
    RemoveTag
    Description: This rule tells the conversion engine to remove a
    specific tag from a Web site or Web content, but leave
    the text or other HTML that lies within the tag.
    Syntax: sw-transform “Mozilla/3.0
    (compatible; HandHTTP 1.1
    ” RemoveTag:TAG NAME
    Example: To remove all images from a site the following may be
    entered:
    sw-transform “Mozilla/3.0
    (compatible; HandHTTP 1.1
    ” RemoveTag:IMG
    Note: This tag will always work, even if the Web
    content you are transforming generally contains poorly
    formatted HTML.
    RemoveTagAndContent
    Description: This rule tells the conversion engine to remove a
    specific tag, and the information that appears within the
    tags, from a Web site or Web content.
    Syntax: sw-transform “Mozilla/3.0
    (compatible; HandHTTP 1.1
    ” RemoveTagAndContent:TAG
    Example: To remove the SCRIPT tag so that all of the
    client-side script on a specific Web site or page
    is removed, the following may be entered:
    sw-transform “Mozilla/3.0
    (compatible; HandHTTP 1.1
    “SCRIPT
    Note: The RemoveTagandContent tag will not be
    completely effective if the Web content being
    transformed is poorly formatted (e.g.,
    there is an open tag without a close tag).
    The conversion engine will attempt to clean up the
    HTML, but may not be completely effective.
    Also, this tag does not have any meaning for
    empty tags.
    ReplaceTag
    Description: This rule tells the conversion engine to replace one
    tag with another.
    Syntax: sw-transform “Mozilla/3.0
    (compatible; HandHTTP 1.1
    ” ReplaceTag:ORIGINAL TAG:NEW
    TAG
    Example: To remove all of the I tags and replace them with
    B, so that all of the text that appears italicized on
    a Web page appears bold on the mobile device
    screen, the following may be entered:
    sw-transform “Mozilla/3.0
    (compatible; HandHTTP 1.1
    ” ReplaceTag:I:B.
    SetAttributeValue
    Description: This rule tells the conversion engine to set a
    specific value for a specific attribute of a specific tag.
    The attribute must already be present in the tag for
    this to work. This rule includes the tag name,
    attribute name, and value, all separated by
    colons.
    Syntax: sw-transform “Nokia-WAP-Toolkit/
    1.2”
    SetAttributeValue:TAG:ATTRIBUTE:
    ATTRIBUTE VALUE
    Example: To give all tables a width of 150, the following
    may be entered:
    sw-transform “Nokia-WAP-Toolkit/
    1.2”
    SetAttributeValue:TABLE:WIDTH:”1
    50”
    To make the font 2 pt, you would enter:
    sw-transform “ Nokia-WAP-Toolkit/
    1.2”
    SetAttributeValue: FONT:SIZE:”2”
    Stop
    Description: This rule tells the conversion engine to stop processing
    all sw-transforms that follow in a template. This can be
    used at the end of a site-specific template file
    to keep the conversion engine from performing Global
    transforms.
    Syntax: sw-transform “Nokia-WAP-Toolkit/
    1.2” STOP
    Example: sw-transform “Nokia-WAP-Toolkit/
    1.2”RemoveComments
    sw-transform ”Nokia-WAP-Toolkit/
    1.2”RemoveTag:B
    sw-transform “Nokia-WAP-Toolkit/
    1.2” STOP
    sw-transform “Nokia-WAP-Toolkit/
    1.2” RemoveTag:I
    (Not performed because the stop is above this
    last transform.).
    Substitute
    Description: This rule tells the conversion engine to substitute one
    sequence of text for another sequence of text.
    You can substitute anything within or outside
    tags. This conversion works like a find and
    replace function. This transform is a regular
    expression.
    You can make substitutions in one of four ways:
    1. Add “i” to the end of the conversion if you
    want to substitute the first instance of the text
    regardless of case.
    2. Add “g” to the end of the conversion if you
    want to do a case-sensitive global substitution.
    3. Add “i” and “g” to the end of the tag if you
    want to perform a global, case insensitive
    substitution.
    4. Don't add anything to the end of the tag if you
    want to perform case sensitive substitution of the
    first instance of the text.
    Syntax: sw-transform “Nokia-WAP-Toolkit/
    1.2” Substitute:ORIGINAL
    TEXT:NEW TEXT:(i,g) parameters,
    or none of the above.
    Note: ORIGINAL TEXT is a regular
    expression
    Example: To remove text such as, “<Title>Aether
    Softwares' Daily Product Update</Title>” and
    replace it with <Title>ScoutWeb Update<Title>,
    you would enter:
    sw-transform “Nokia-WAP-Toolkit/
    1.2” Substitute:Aether
    Softwares' Daily Product
    Update:ScoutWeb Update:ig
    TranslateTables
    Description: This rule tells the conversion engine to remove the table
    formatting and make the table contents appear as
    straight text.
    Syntax: sw-transform “Nokia-WAP-Toolkit/
    1.2” TranslateTables
    Example: <TABLE BORDER=0 CELLPADDING=“0”
    CELLSPACING=“0”>
    done using rows
    <tr>
    <td><input type=“text” value
    =“one” size=7 maxlength=10
    name=“symbol”></td>
    <td><input type=“text”
    value=“two” size=7 maxlength=10
    name=“symbol”></td>
    <td><input type=“text”
    value=“three” size=7
    maxlength=10 name=“symbol”></td>
    <td><input type=“text”
    value=“four” size=7 maxlength=10
    name=“symbol”></td>
    <td><input type=“text”
    value=“five” size=7 maxlength=10
    name=“symbol”></td> </tr>
    <tr>
    <td><input type=“text”
    value=“six” size=7 maxlength=10
    name=“symbol”></td>
    <td><input type=“text”
    value=“seven” size=7
    maxlength=10 name=“symbol”></td>
    <td><input type=“text”
    value=“eight” size=7
    maxlength=10 name=“symbol”></td>
    <td><input type=“text”
    value=“nine” size=7 maxlength=10
    name=“symbol”></td>
    value=“ten” size=7 maxlength=10
    name=“symbol”></td>
    </tr>
    </TABLE>
    <BR>
    After TranslateTables
    iinput type=“text” value =“one”
    size=7 maxlength=10
    name=“symbol”>&nbsp;&nbsp;&nbsp;
    &nbsp;&nbsp;
    <input type=“text” value=“two”
    size=7 maxlength=10
    name=“symbol”>&nbsp;&nbsp;&nbsp;
    &nbsp;&nbsp;
    <input type=“text” value=“three”
    size=7 maxlength=10
    name=“symbol”>&nbsp;&nbsp;&nbsp;
    &nbsp;&nbsp;
    <input type=“text” value=“four”
    size=7 maxlength=10
    name=“symbol”>&nbsp;&nbsp;&nbsp;
    &nbsp;&nbsp;
    <input type=“text” value=“five”
    size=7 maxlength=10
    name=“symbol”>&nbsp;&nbsp;&nbsp;
    &nbsp;&nbsp;
    <input type=“text” value=“six”
    size=7 maxlength=10
    name=“symbol”>&nbsp;&nbsp;&nbsp;
    &nbsp;&nbsp;
    <input type=“text” value=“seven”
    size=7 max length=10
    name=“symbol”>&nbsp;&nbsp;&nbsp&
    nbsp;&nbsp;
    <input type=“text” value=“eight”
    size=7 maxlength=10 name=“sym
    bol”>&nbsp;&nbsp;&nbsp;&nbsp;&nb
    sp;.
    <input type=“text” value=“nine”
    size=7 maxlength=10 name=“sym
    bol”>&nbsp;&nbsp;&nbsp;&nbsp;&ns
    p;
    <input type=“text” value=“ten”
    size=7 maxlength=10
    name=“symbol”>&nbsp;&nbsp;&nbsp;
    &nbsp;&nbsp;
  • Computer Implementation
  • The techniques of the present invention may be implemented on a computing unit such as that depicted in FIG. 11. In this regard, FIG. 11 is an illustration of a computer system which is also capable of implementing some or all of the computer processing in accordance with computer implemented embodiments of the present invention. The procedures described herein are presented in terms of program procedures executed on, for example, a computer or network of computers.
  • Viewed externally in FIG. 11, a computer system designated by reference numeral 1100 has a computer portion 1102 having disk drives 1104 and 1106. Disk drive indications 1104 and 1106 are merely symbolic of a number of disk drives which might be accommodated by the computer system. Typically, these would include a floppy disk drive 1104, a hard disk drive (not shown externally) and a CD ROM indicated by slot 1106. The number and type of drives vary, typically with different computer configurations. Disk drives 1104 and 1106 are in fact optional, and for space considerations, are easily omitted from the computer system used in conjunction with the production process/apparatus described herein.
  • The computer system also has an optional display 1108 upon which information, such as the screens illustrated in FIGS. 4 and/or 8 may be displayed. In some situations, a keyboard 1110 and a mouse 1112 are provided as input devices through which input may be provided, thus allowing input to interface with the central processing unit 1102. Then again, for enhanced portability, the keyboard 1110 is either a limited function keyboard or omitted in its entirety. In addition, mouse 1112 optionally is a touch pad control device, or a track ball device, or even omitted in its entirety as well, and similarly may be used as an input device. In addition, the computer system 1100 may also optionally include at least one infrared (or radio) transmitter and/or infrared (or radio) receiver for either transmitting and/or receiving infrared signals.
  • Although computer system 1100 is illustrated having a single processor, a single hard disk drive and a single local memory, the system 1100 is optionally suitably equipped with any multitude or combination of processors or storage devices. Computer system 1100 is, in point of fact, able to be replaced by, or combined with, any suitable processing system operative in accordance with the principles of the present invention, including hand-held, laptop/notebook, mini, mainframe and super computers, as well as processing system network combinations of the same.
  • FIG. 12 illustrates a block diagram of the internal hardware of the computer system 1100 of FIG. 11. A bus 1202 serves as the main information highway interconnecting the other components of the computer system 1100. CPU 1204 is the central processing unit of the system, performing calculations and logic operations required to execute a program. Read only memory (ROM) 1206 and random access memory (RAM) 1208 constitute the main memory of the computer 1102. Disk controller 1210 interfaces one or more disk drives to the system bus 1202. These disk drives are, for example, floppy disk drives such as 1104 or 1106, or CD ROM or DVD (digital video disks) drive such as 1212, or internal or external hard drives 1214. As indicated previously, these various disk drives and disk controllers are optional devices.
  • A display interface 1218 interfaces display 1208 and permits information from the bus 1202 to be displayed on the display 1108. Again as indicated, display 1108 is also an optional accessory. For example, display 1108 could be substituted or omitted. Communications with external devices, for example, the other components of the system described herein, occur utilizing communication port 1516. For example, optical fibers and/or electrical cables and/or conductors and/or optical communication (e.g., infrared, and the like) and/or wireless communication (e.g., radio frequency (RF), and the like) can be used as the transport medium between the external devices and communication port 1516. Peripheral interface 1520 interfaces the keyboard 1410 and the mouse 1412, permitting input data to be transmitted to the bus 1502.
  • In alternate embodiments, the above-identified CPU 1204, may be replaced by or combined with any other suitable processing circuits, including programmable logic devices, such as PALs (programmable array logic) and PLAs (programmable logic arrays). DSPs (digital signal processors), FPGAs (field programmable gate arrays), ASICs (application specific integrated circuits), VLSIs (very large scale integrated circuits) or the like.
  • One of the implementations of the invention is as sets of instructions resident in the random access memory 1208 of one or more computer systems 1100 configured generally as described above. Until required by the computer system, the set of instructions may be stored in another computer readable memory, for example, in the hard disk drive 1214, or in a removable memory such as an optical disk for eventual use in the CD-ROM 1212 or in a floppy disk for eventual use in a floppy disk drive 1104, 1106. Further, the set of instructions (such as those written in the Java programming language) can be stored in the memory of another computer and transmitted in a transmission means such as a local area network or a wide area network such as the Internet 114 when desired by the user. One skilled in the art knows that storage or transmission of the computer program product changes the medium electrically, magnetically, or chemically so that the medium carries computer readable information.
  • The many features and advantages of the invention are apparent from the detailed specification, and thus, it is intended by the appended claims to cover all such features and advantages of the invention which fall within the true spirit and scope of the invention. Further, since numerous modifications and variations will readily occur to those skilled in the art, it is not desired to limit the invention to the exact construction and operation illustrated and described, and accordingly, all suitable modifications and equivalents may be resorted to, falling within the scope of the invention. While the foregoing invention has been described in detail by way of illustration and example of preferred embodiments, numerous modifications, substitutions, and alterations are possible without departing from the scope of the invention defined in the following claims.

Claims (23)

1-105. (canceled)
106. A system for extracting and reformatting web page content into a format readable on a mobile device, comprising:
a receiving module to receive a user request from said mobile device for web page content having a first format;
a physical proxy server to retrieve said requested web page content from a physical origin web server, to access a predefined extraction and conversion file associated with said requested web page content, and to convert said requested web page content in accordance with said predefined extraction and conversion file associated with said requested web page content.
107. The system according to claim 106, wherein said physical proxy server comprises:
a storage repository that contains at least one data file associated with each of said mobile device; and
a conversion engine that receives said requested web page content and site-mines and reformats at least a portion of said requested web page content from said requested web page content having said first format, for transmission to said mobile device, in accordance with one or more predetermined instructions in each of said at least one data file associated with each of said mobile device.
108. The system according to claim 106, further comprising:
a cache that stores said requested web page content prior to transmitting said extracted and reformatted web content to said mobile device.
109. The system according to claim 106, wherein:
at least one of said data files is defined for at least two mobile devices having a predefined common characteristic.
110. The system according to claim 109, wherein said predefined characteristic is at least one of:
a type of operating system,
a type of browser, and
a manufacturer.
111. The system according to claim 106, wherein:
at least one of said data files is defined for a particular type of said mobile device.
112. The system according to claim 111, wherein:
said particular type of said mobile device is defined by said manufacturer and model.
113. The system according to claim 106, further comprising:
a secure connection between said mobile device and said physical proxy server provided by a secure socket layer connection.
114. The system according to claim 106, further comprising:
a secure connection provided between said physical proxy server and said physical origin web server.
115. The system according to claim 114, wherein:
said secure connection is a secure socket layer connection.
116. A method of extracting and reformatting web page content into a format readable on a mobile device, comprising:
receiving a user request from said mobile device for web page content having a first format; and
retrieving said requested web page content from a physical origin web server;
accessing a predefined extraction and conversion file associated with said requested web page content; and
converting said requested web page content in accordance with said predefined extraction and conversion file associated with said requested web page content.
117. The method according to claim 116, further comprising:
providing a storage repository that contains at least one data file associated with each of said mobile device; and
providing a conversion engine that receives said requested web page content and site-mines and reformats at least a portion of said requested web page content from said requested web page content having said first format, for transmission to said mobile device, in accordance with one or more predetermined instructions in each of said at least one data file associated with each of said mobile device.
118. The method according to claim 116, further comprising:
caching said requested web page content prior to transmitting said extracted and reformatted web content to said mobile device.
119. The method according to claim 116, wherein:
at least one of said data files is defined for at least two mobile devices having a predefined common characteristic.
120. The method according to claim 119, wherein said predefined characteristic is at least one of:
a type of operating system,
a type of browser, and
a manufacturer.
121. The method according to claim 116, wherein:
at least one of said data files is defined for a particular type of said mobile device.
122. The method according to claim 121, wherein:
said particular type of said mobile device is defined by said manufacturer and model.
123. The method according to claim 116, further comprising:
establishing a secure connection between said mobile device and said physical proxy server through a secure socket layer connection.
124. The method according to claim 116, further comprising:
establishing a secure connection provided between said physical proxy server and said physical origin web server.
125. The method according to claim 124, wherein:
said secure connection is a secure socket layer connection.
126. Apparatus for extracting and reformatting web page content into a format readable on a mobile device, comprising:
means for receiving a user request from said mobile device for web page content having a first format; and
means for retrieving said requested web page content from a physical origin web server;
means for accessing a predefined extraction and conversion file associated with said requested web page content; and
means for converting said requested web page content in accordance with said predefined extraction and conversion file associated with said requested web page content.
127. The apparatus according to claim 126, further comprising:
means for storage repository that contains at least one data file associated with each of said mobile device; and
means for site-mining that receives said requested web page content and site-mines and reformats at least a portion of said requested web page content from said web page content having said first format, for transmission to said mobile device, in accordance with one or more predetermined instructions in each of said at least one data file associated with each of said mobile device.
US12/458,153 2000-11-06 2009-07-01 Web page content translator Abandoned US20100017464A1 (en)

Priority Applications (1)

Application Number Priority Date Filing Date Title
US12/458,153 US20100017464A1 (en) 2000-11-06 2009-07-01 Web page content translator

Applications Claiming Priority (3)

Application Number Priority Date Filing Date Title
US24568000P 2000-11-06 2000-11-06
US09/707,770 US7574486B1 (en) 2000-11-06 2000-11-08 Web page content translator
US12/458,153 US20100017464A1 (en) 2000-11-06 2009-07-01 Web page content translator

Related Parent Applications (1)

Application Number Title Priority Date Filing Date
US09/707,770 Continuation US7574486B1 (en) 2000-11-06 2000-11-08 Web page content translator

Publications (1)

Publication Number Publication Date
US20100017464A1 true US20100017464A1 (en) 2010-01-21

Family

ID=40934387

Family Applications (3)

Application Number Title Priority Date Filing Date
US09/707,770 Expired - Fee Related US7574486B1 (en) 2000-11-06 2000-11-08 Web page content translator
US12/458,154 Expired - Fee Related US8793341B2 (en) 2000-11-06 2009-07-01 Web page content translator
US12/458,153 Abandoned US20100017464A1 (en) 2000-11-06 2009-07-01 Web page content translator

Family Applications Before (2)

Application Number Title Priority Date Filing Date
US09/707,770 Expired - Fee Related US7574486B1 (en) 2000-11-06 2000-11-08 Web page content translator
US12/458,154 Expired - Fee Related US8793341B2 (en) 2000-11-06 2009-07-01 Web page content translator

Country Status (1)

Country Link
US (3) US7574486B1 (en)

Cited By (19)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US20070220599A1 (en) * 2006-03-15 2007-09-20 Doug Moen Client-side extensions for use in connection with HTTP proxy policy enforcement
US20110022559A1 (en) * 2009-07-24 2011-01-27 Bank Of America Corporation Browser preview
US20110047249A1 (en) * 2008-02-12 2011-02-24 Mtld Top Level Domain Limited Determining a property of a communication device
US20110258250A1 (en) * 2010-04-19 2011-10-20 Mtld Top Level Domain Limited Transcoder hinting
US20120096366A1 (en) * 2010-10-15 2012-04-19 Cellco Partnership D/B/A Verizon Wireless Technique for handling urls for different mobile devices that use different user interface platforms
US20120188264A1 (en) * 2010-09-27 2012-07-26 Research In Motion Limited Mobile wireless communications system providing enhanced user interface (ui) content display features and related methods
US20120194519A1 (en) * 2011-01-28 2012-08-02 Strangeloop Networks Inc. Image Optimization
US20120284611A1 (en) * 2009-03-31 2012-11-08 International Business Machines Corporation Selective partial updates of web content
US8346889B1 (en) 2010-03-24 2013-01-01 Google Inc. Event-driven module loading
US8396990B2 (en) 2008-10-10 2013-03-12 Afilias Technologies Limited Transcoding web resources
US8453049B1 (en) * 2010-05-19 2013-05-28 Google Inc. Delayed code parsing for reduced startup latency
US20140033018A1 (en) * 2012-07-30 2014-01-30 Vistaprint Technologies Limited Method and system for automatically generating social network site page based on electronic document content
US20140129920A1 (en) * 2012-05-07 2014-05-08 Armor5, Inc. Enhanced Document and Event Mirroring for Accessing Internet Content
CN104380280A (en) * 2012-04-16 2015-02-25 权五石 System and method for dynamically converting webpage, and computer-readable recording medium
US9003309B1 (en) * 2010-01-22 2015-04-07 Adobe Systems Incorporated Method and apparatus for customizing content displayed on a display device
US20150278818A1 (en) * 2014-03-31 2015-10-01 Ncr Corporation Fraud Detection in Self-Service Terminal
US20160124914A1 (en) * 2014-10-30 2016-05-05 Alibaba Group Holding Limited Page Processing for Mobile App
WO2017020072A1 (en) 2015-07-31 2017-02-09 Wisetech Global Limited Systems and methods for executable content and executable content flow distribution
US10705862B2 (en) 2010-07-08 2020-07-07 Afilias Technologies Limited Server-based generation of user interfaces for delivery to mobile communication devices

Families Citing this family (85)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US20100145794A1 (en) * 1999-10-21 2010-06-10 Sean Barnes Barger Media Processing Engine and Ad-Per-View
US6792575B1 (en) * 1999-10-21 2004-09-14 Equilibrium Technologies Automated processing and delivery of media to web servers
CN1262968C (en) * 2000-02-04 2006-07-05 松下电器产业株式会社 Information terminal
US7565411B1 (en) * 2004-10-13 2009-07-21 Palmsource, Inc. Method and apparatus for device and carrier independent location systems for mobile devices
US7587669B2 (en) * 2001-04-09 2009-09-08 Aol Llc Server-based browser system
US7873734B1 (en) * 2001-05-17 2011-01-18 Computer Associates Think, Inc. Management of multiple user sessions and user requests for multiple electronic devices
US8285880B2 (en) * 2001-11-30 2012-10-09 Oracle International Corporation Servicing requests that are issued in a protocol other than the protocol expected by the service
AU2003247593A1 (en) 2002-06-18 2003-12-31 Wireless Ink, Llc Method, apparatus and system for management of information content for enhanced accessibility over wireless communication networks
JP4082591B2 (en) * 2003-05-20 2008-04-30 インターナショナル・ビジネス・マシーンズ・コーポレーション Data editing apparatus and program
US7496560B2 (en) * 2003-09-23 2009-02-24 Amazon Technologies, Inc. Personalized searchable library with highlighting capabilities
CA2539431C (en) * 2003-09-23 2017-07-11 Amazon.Com, Inc. Personalized searchable library with highlighting capabilities
WO2005062175A2 (en) * 2003-12-23 2005-07-07 Corizon Limited Method and apparatus for composite user interface creation
KR100687730B1 (en) * 2004-08-04 2007-02-27 경북대학교 산학협력단 Active node, contents transfer system and method using an active node
GB0420409D0 (en) * 2004-09-14 2004-10-20 Waterleaf Ltd Online commercial transaction system and method of operation thereof
US7904337B2 (en) 2004-10-19 2011-03-08 Steve Morsa Match engine marketing
US8346956B2 (en) 2004-10-29 2013-01-01 Akamai Technologies, Inc. Dynamic image delivery system
US8059793B2 (en) * 2005-02-07 2011-11-15 Avaya Inc. System and method for voicemail privacy
US7962894B2 (en) * 2005-11-23 2011-06-14 Oracle International Corporation System and method for identifying non-supported features in a multiple code editor environment
US7822874B2 (en) * 2006-04-07 2010-10-26 Dell Products L.P. Providing third party content to media devices
US20080114695A1 (en) 2006-11-10 2008-05-15 Semantic Components S.L. Process for implementing a method for the on-line sale of software product use licenses through a data network, and software component which allows carrying out said process
TWI327706B (en) * 2007-01-11 2010-07-21 Ind Tech Res Inst Web service accessing device and method for simplifying service interface
JP5312349B2 (en) * 2007-02-09 2013-10-09 ノキア コーポレイション Method and system for providing a portion of information content to a client device
US7921187B2 (en) * 2007-06-28 2011-04-05 Apple Inc. Newsreader for mobile device
JP4502015B2 (en) * 2008-01-24 2010-07-14 富士ゼロックス株式会社 Information processing apparatus and program
ES2326949B1 (en) 2008-03-18 2010-07-14 Clarity Systems, S.L. PROCEDURE USED BY A STREAMING SERVER TO MAKE A TRANSMISSION OF A MULTIMEDIA FILE IN A DATA NETWORK.
US7984097B2 (en) 2008-03-18 2011-07-19 Media Patents, S.L. Methods for transmitting multimedia files and advertisements
US20090265618A1 (en) * 2008-04-18 2009-10-22 Hong-Yung Wang Method of browsing web information using a mobile handheld device
US20090270076A1 (en) * 2008-04-29 2009-10-29 Microsoft Corporation Performance optimizer for mobile devices website
JP4671061B2 (en) * 2008-07-29 2011-04-13 岩崎通信機株式会社 Content display device and content display method
KR20100081030A (en) * 2009-01-05 2010-07-14 삼성전자주식회사 Mobile terminal having oled and method for controlling power thereof
US9154532B2 (en) 2009-04-27 2015-10-06 Zaron Remote Llc Methods and apparatus for transmitting multimedia files in a data network
US8479092B1 (en) * 2009-04-30 2013-07-02 Adobe Systems Incorporated Content layout for an electronic document
US10346483B2 (en) 2009-10-02 2019-07-09 Akamai Technologies, Inc. System and method for search engine optimization
US8521779B2 (en) 2009-10-09 2013-08-27 Adelphoi Limited Metadata record generation
US20120246557A1 (en) * 2009-10-12 2012-09-27 Hcl Technologies Limited System and method for transcoding web content adaptable to multiple client devices
US11102325B2 (en) 2009-10-23 2021-08-24 Moov Corporation Configurable and dynamic transformation of web content
CN102271142B (en) * 2010-06-01 2015-01-28 中兴通讯股份有限公司 Service development platform, system thereof and method thereof
SG185673A1 (en) 2010-06-09 2012-12-28 Adelphoi Ltd System and method for audio media recognition
CA2742059C (en) 2010-06-22 2019-10-29 Blaze Software Inc. Method and system for automated analysis and transformation of web pages
JP5668342B2 (en) * 2010-07-07 2015-02-12 富士通株式会社 Content conversion program, content conversion system, and content conversion server
JP5676971B2 (en) * 2010-08-18 2015-02-25 キヤノン株式会社 Information processing apparatus, display control method, and program
US8516362B2 (en) * 2010-09-14 2013-08-20 Usablenet Inc. Methods for extending a document transformation server to process multiple documents from multiple sites and devices thereof
US9558285B2 (en) * 2010-09-14 2017-01-31 Accenture Global Services Limited Treatment controller
US9122767B2 (en) 2010-09-17 2015-09-01 Oracle International Corporation Method and apparatus for pre-rendering expected system response
US9275165B2 (en) * 2010-09-17 2016-03-01 Oracle International Corporation Method and apparatus for defining an application to allow polymorphic serialization
CN103098055B (en) * 2010-09-17 2018-01-12 甲骨文国际公司 Recursive navigation in mobile client relation management
US8566702B2 (en) 2010-09-20 2013-10-22 Blackberry Limited Methods and systems of outputting content of interest
EP2431891A1 (en) * 2010-09-20 2012-03-21 Research In Motion Limited Methods and systems of outputting content of interest
US9753609B2 (en) * 2010-12-03 2017-09-05 Facebook, Inc. User interface with media wheel facilitating viewing of media objects
US9418353B2 (en) 2010-12-20 2016-08-16 Akamai Technologies, Inc. Methods and systems for delivering content to differentiated client devices
US9164988B2 (en) * 2011-01-14 2015-10-20 Lionbridge Technologies, Inc. Methods and systems for the dynamic creation of a translated website
US9007405B1 (en) * 2011-03-28 2015-04-14 Amazon Technologies, Inc. Column zoom
US9220062B2 (en) 2011-03-30 2015-12-22 Nokia Technologies Oy Method and apparatus for low-power browsing
US10482121B2 (en) * 2011-04-28 2019-11-19 Sony Interactive Entertainment LLC User interface for accessing games
US9269096B2 (en) * 2011-05-23 2016-02-23 Microsoft Technology Licensing, Llc Advertisement rendering for multiple synced devices
CN103139258A (en) * 2011-11-30 2013-06-05 百度在线网络技术(北京)有限公司 Method and device and system for processing page access requests of mobile terminal
US9742858B2 (en) 2011-12-23 2017-08-22 Akamai Technologies Inc. Assessment of content delivery services using performance measurements from within an end user client application
US9419852B1 (en) 2011-12-30 2016-08-16 Akamai Technologies, Inc. Systems and methods for identifying and characterizing client devices
US9817916B2 (en) 2012-02-22 2017-11-14 Akamai Technologies Inc. Methods and apparatus for accelerating content authored for multiple devices
US8341516B1 (en) * 2012-03-12 2012-12-25 Christopher Mason Method and system for optimally transcoding websites
US9043441B1 (en) * 2012-05-29 2015-05-26 Google Inc. Methods and systems for providing network content for devices with displays having limited viewing area
US20140089786A1 (en) * 2012-06-01 2014-03-27 Atiq Hashmi Automated Processor For Web Content To Mobile-Optimized Content Transformation
CN103455475B (en) * 2012-06-01 2016-12-14 腾讯科技(深圳)有限公司 Composition method, equipment and system
US9106690B1 (en) * 2012-06-14 2015-08-11 Bromium, Inc. Securing an endpoint by proxying document object models and windows
US8786889B2 (en) * 2012-08-29 2014-07-22 Eastman Kodak Company Method for computing scale for tag insertion
US8928929B2 (en) * 2012-08-29 2015-01-06 Eastman Kodak Company System for generating tag layouts
US9785621B2 (en) 2012-11-26 2017-10-10 Akamai Technologies, Inc. Progressive consolidation of web page resources
US20140149206A1 (en) * 2012-11-29 2014-05-29 Linkedin Corporation Combined sponsored and unsponsored content group
US10282401B2 (en) * 2013-03-13 2019-05-07 Usablenet Inc. Methods for processing cascading style sheets and devices thereof
US9942299B2 (en) * 2013-03-15 2018-04-10 Yottaa Inc. System and method for managing multiple variants of an HTTP object
CN104065632B (en) * 2013-04-08 2015-07-29 腾讯科技(深圳)有限公司 The processing method of sharing contents, server, client and system
US9916720B2 (en) 2013-08-02 2018-03-13 Bally Gaming, Inc. Intelligent wagering game content distribution
US9686372B1 (en) * 2013-08-14 2017-06-20 Amazon Technologies, Inc. Systems and methods for automatically rewriting network page code
US9477774B2 (en) 2013-09-25 2016-10-25 Akamai Technologies, Inc. Key resource prefetching using front-end optimization (FEO) configuration
US9547629B2 (en) * 2013-11-29 2017-01-17 Documill Oy Efficient creation of web fonts
US10848544B2 (en) * 2014-09-02 2020-11-24 Apple Inc. Communicating mapping application data between electronic devices
EP3220284A1 (en) * 2014-11-14 2017-09-20 Fujitsu Limited Data acquisition program, data acquisition method and data acquisition device
US9961126B2 (en) 2015-04-29 2018-05-01 International Business Machines Corporation Managing data access on a computing device
US9609126B2 (en) 2015-05-11 2017-03-28 Paypal, Inc. User device detection and integration for an IVR system
KR102395701B1 (en) * 2015-11-11 2022-05-10 삼성전자주식회사 Electronic apparatus and method for controlling of an electronic apparatus
CN106790593B (en) * 2016-12-28 2020-11-06 北京奇虎科技有限公司 Page processing method and device
CN107733997A (en) * 2017-09-22 2018-02-23 刘静静 A kind of implementation method of Multifunctional mobile webpage and web game based on browser
US10909306B2 (en) 2018-03-16 2021-02-02 Canva Pty Ltd. Systems and methods of publishing a design
CN108600267A (en) * 2018-05-09 2018-09-28 北京信安世纪科技股份有限公司 A kind of proxy server intelligent buffer method
US10896593B1 (en) * 2018-06-10 2021-01-19 Frequentis Ag System and method for brokering mission critical communication between parties having non-uniform communication resources

Citations (46)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US6049821A (en) * 1997-01-24 2000-04-11 Motorola, Inc. Proxy host computer and method for accessing and retrieving information between a browser and a proxy
US6247048B1 (en) * 1998-04-30 2001-06-12 Openwave Systems Inc Method and apparatus for transcoding character sets between internet hosts and thin client devices over data networks
US20010003823A1 (en) * 1996-06-03 2001-06-14 Lee S. Mighdoll Method for downloading a web page to a client for efficient display on a television screen
US6311180B1 (en) * 2000-03-28 2001-10-30 Linx Data Terminals, Inc. Method for mapping and formatting information for a display device
US6412008B1 (en) * 1999-01-28 2002-06-25 International Business Machines Corporation System and method for cooperative client/server customization of web pages
US6421717B1 (en) * 1999-09-10 2002-07-16 Avantgo, Inc. System, method, and computer program product for customizing channels, content, and data for mobile devices
US20020143821A1 (en) * 2000-12-15 2002-10-03 Douglas Jakubowski Site mining stylesheet generator
US6463440B1 (en) * 1999-04-08 2002-10-08 International Business Machines Corporation Retrieval of style sheets from directories based upon partial characteristic matching
US6487588B1 (en) * 1996-09-23 2002-11-26 International Business Machines Corporation Web browser which automatically loads selected types of graphics
US6493758B1 (en) * 1998-09-08 2002-12-10 Microsoft Corporation Offline viewing of internet content with a mobile device
US6494762B1 (en) * 2000-03-31 2002-12-17 Matsushita Electrical Industrial Co., Ltd. Portable electronic subscription device and service
US6507867B1 (en) * 1998-12-22 2003-01-14 International Business Machines Corporation Constructing, downloading, and accessing page bundles on a portable client having intermittent network connectivity
US6507872B1 (en) * 1992-09-25 2003-01-14 David Michael Geshwind Class of methods for improving perceived efficiency of end-user interactive access of a large database such as the world-wide web via a communication network such as “The Internet”
US6584567B1 (en) * 1999-06-30 2003-06-24 International Business Machines Corporation Dynamic connection to multiple origin servers in a transcoding proxy
US20030120686A1 (en) * 2001-12-21 2003-06-26 Xmlcities, Inc. Extensible stylesheet designs using meta-tag and/or associated meta-tag information
US6587871B1 (en) * 1998-12-22 2003-07-01 Ericsson Inc. System, method, and apparatus for converting voice mail to text and transmitting as an email or facsimile
US6594349B2 (en) * 1997-04-23 2003-07-15 Nortel Networks Limited System and method for automatically delivering messages to a telecommunications device
US6606663B1 (en) * 1998-09-29 2003-08-12 Openwave Systems Inc. Method and apparatus for caching credentials in proxy servers for wireless user agents
US6610105B1 (en) * 1997-12-09 2003-08-26 Openwave Systems Inc. Method and system for providing resource access in a mobile environment
US6615212B1 (en) * 1999-08-19 2003-09-02 International Business Machines Corporation Dynamically provided content processor for transcoded data types at intermediate stages of transcoding process
US6643684B1 (en) * 1998-10-08 2003-11-04 International Business Machines Corporation Sender- specified delivery customization
US6654786B1 (en) * 1998-04-30 2003-11-25 Openwave Systems Inc. Method and apparatus for informing wireless clients about updated information
US20040049737A1 (en) * 2000-04-26 2004-03-11 Novarra, Inc. System and method for displaying information content with selective horizontal scrolling
US6718015B1 (en) * 1998-12-16 2004-04-06 International Business Machines Corporation Remote web page reader
US6738614B1 (en) * 2000-06-19 2004-05-18 1477.Com Wireless, Inc. Method and system for communicating data to a wireless device
US6742038B2 (en) * 2000-04-07 2004-05-25 Danger, Inc. System and method of linking user identification to a subscriber identification module
US6772180B1 (en) * 1999-01-22 2004-08-03 International Business Machines Corporation Data representation schema translation through shared examples
US6775805B1 (en) * 1999-10-06 2004-08-10 International Business Machines Corporation Method, apparatus and program product for specifying an area of a web page for audible reading
US6779178B1 (en) * 1997-03-07 2004-08-17 Signature Mail. Com, Llc System and method for personalizing electronic mail messages
US20040215829A1 (en) * 2000-03-30 2004-10-28 United Devices, Inc. Data conversion services and associated distributed processing system
US6826597B1 (en) * 1999-03-17 2004-11-30 Oracle International Corporation Providing clients with services that retrieve data from data sources that do not necessarily support the format required by the clients
US6834306B1 (en) * 1999-08-10 2004-12-21 Akamai Technologies, Inc. Method and apparatus for notifying a user of changes to certain parts of web pages
US6857102B1 (en) * 1998-04-07 2005-02-15 Fuji Xerox Co., Ltd. Document re-authoring systems and methods for providing device-independent access to the world wide web
US6920488B1 (en) * 2000-07-28 2005-07-19 International Business Machines Corporation Server assisted system for accessing web pages from a personal data assistant
US6993476B1 (en) * 1999-08-26 2006-01-31 International Business Machines Corporation System and method for incorporating semantic characteristics into the format-driven syntactic document transcoding framework
US7058699B1 (en) * 2000-06-16 2006-06-06 Yahoo! Inc. System and methods for implementing code translations that enable persistent client-server communication via a proxy
US7134073B1 (en) * 2000-06-15 2006-11-07 International Business Machines Corporation Apparatus and method for enabling composite style sheet application to multi-part electronic documents
US20070067329A1 (en) * 2005-07-21 2007-03-22 Maryam Kamvar Overloaded communication session
US7249196B1 (en) * 2000-10-06 2007-07-24 Juniper Networks, Inc. Web page source file transfer system and method
US7349955B1 (en) * 2000-02-11 2008-03-25 Goamerica, Inc. Method of and system for transferring data over a wireless communications network
US7415537B1 (en) * 2000-04-07 2008-08-19 International Business Machines Corporation Conversational portal for providing conversational browsing and multimedia broadcast on demand
US7475346B1 (en) * 1999-12-22 2009-01-06 Unisys Corporation System and method for providing a customizable web portal service
US7502922B1 (en) * 2000-03-01 2009-03-10 Novell, Inc. Computer network having a security layer interface independent of the application transport mechanism
US7509397B1 (en) * 2000-04-06 2009-03-24 Yahoo! Inc. Web portholes: using web proxies to capture and enhance display real estate
US20090125809A1 (en) * 2000-04-26 2009-05-14 Novarra, Inc. System and Method for Adapting Information Content for an Electronic Device
US20100228880A1 (en) * 2000-04-26 2010-09-09 Simon Hunt System and Method for Providing and Displaying Information Content

Family Cites Families (16)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US5185857A (en) * 1989-12-13 1993-02-09 Rozmanith A Martin Method and apparatus for multi-optional processing, storing, transmitting and retrieving graphical and tabular data in a mobile transportation distributable and/or networkable communications and/or data processing system
US6553410B2 (en) * 1996-02-27 2003-04-22 Inpro Licensing Sarl Tailoring data and transmission protocol for efficient interactive data transactions over wide-area networks
US5822614A (en) * 1996-05-31 1998-10-13 Unisys Corporation Self-identifying peripheral device
US5890014A (en) * 1996-08-05 1999-03-30 Micronet Technology, Inc. System for transparently identifying and matching an input/output profile to optimal input/output device parameters
US6938073B1 (en) * 1997-11-14 2005-08-30 Yahoo! Inc. Method and apparatus for re-formatting web pages
US6925595B1 (en) * 1998-08-05 2005-08-02 Spyglass, Inc. Method and system for content conversion of hypertext data using data mining
US6564263B1 (en) * 1998-12-04 2003-05-13 International Business Machines Corporation Multimedia content description framework
US6434626B1 (en) * 1999-01-14 2002-08-13 Compaq Information Technologies Group, L.P. Method and apparatus for low latency network performance monitoring
US6272493B1 (en) * 1999-01-21 2001-08-07 Wired Solutions, Llc System and method for facilitating a windows based content manifestation environment within a WWW browser
US6287198B1 (en) * 1999-08-03 2001-09-11 Mccauley Jack J. Optical gun for use with computer games
EP2275920A1 (en) * 1999-11-02 2011-01-19 Canon Kabushiki Kaisha Information processor, method for processing information and memory medium for storing program readable by computer
US7668913B1 (en) * 1999-11-05 2010-02-23 Decentrix, Inc. Method and apparatus for generating a web site with dynamic content data from an external source integrated therein
US7239629B1 (en) * 1999-12-01 2007-07-03 Verizon Corporate Services Group Inc. Multiservice network
US20020087416A1 (en) * 2000-04-24 2002-07-04 Knutson Roger C. System and method for providing learning material
US6539384B1 (en) * 2000-06-02 2003-03-25 Bellsouth Intellectual Property Corporation Browser on test equipment
DE102006020102A1 (en) * 2006-04-29 2007-10-31 Leybold Vacuum Gmbh Lubricant-free vacuum pump used as a turbo molecular pump comprises a gas bearing surface facing a shaft and/or a gas bearing rotor and having a hard layer

Patent Citations (46)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US6507872B1 (en) * 1992-09-25 2003-01-14 David Michael Geshwind Class of methods for improving perceived efficiency of end-user interactive access of a large database such as the world-wide web via a communication network such as “The Internet”
US20010003823A1 (en) * 1996-06-03 2001-06-14 Lee S. Mighdoll Method for downloading a web page to a client for efficient display on a television screen
US6487588B1 (en) * 1996-09-23 2002-11-26 International Business Machines Corporation Web browser which automatically loads selected types of graphics
US6049821A (en) * 1997-01-24 2000-04-11 Motorola, Inc. Proxy host computer and method for accessing and retrieving information between a browser and a proxy
US6779178B1 (en) * 1997-03-07 2004-08-17 Signature Mail. Com, Llc System and method for personalizing electronic mail messages
US6594349B2 (en) * 1997-04-23 2003-07-15 Nortel Networks Limited System and method for automatically delivering messages to a telecommunications device
US6610105B1 (en) * 1997-12-09 2003-08-26 Openwave Systems Inc. Method and system for providing resource access in a mobile environment
US6857102B1 (en) * 1998-04-07 2005-02-15 Fuji Xerox Co., Ltd. Document re-authoring systems and methods for providing device-independent access to the world wide web
US6654786B1 (en) * 1998-04-30 2003-11-25 Openwave Systems Inc. Method and apparatus for informing wireless clients about updated information
US6247048B1 (en) * 1998-04-30 2001-06-12 Openwave Systems Inc Method and apparatus for transcoding character sets between internet hosts and thin client devices over data networks
US6493758B1 (en) * 1998-09-08 2002-12-10 Microsoft Corporation Offline viewing of internet content with a mobile device
US6606663B1 (en) * 1998-09-29 2003-08-12 Openwave Systems Inc. Method and apparatus for caching credentials in proxy servers for wireless user agents
US6643684B1 (en) * 1998-10-08 2003-11-04 International Business Machines Corporation Sender- specified delivery customization
US6718015B1 (en) * 1998-12-16 2004-04-06 International Business Machines Corporation Remote web page reader
US6587871B1 (en) * 1998-12-22 2003-07-01 Ericsson Inc. System, method, and apparatus for converting voice mail to text and transmitting as an email or facsimile
US6507867B1 (en) * 1998-12-22 2003-01-14 International Business Machines Corporation Constructing, downloading, and accessing page bundles on a portable client having intermittent network connectivity
US6772180B1 (en) * 1999-01-22 2004-08-03 International Business Machines Corporation Data representation schema translation through shared examples
US6412008B1 (en) * 1999-01-28 2002-06-25 International Business Machines Corporation System and method for cooperative client/server customization of web pages
US6826597B1 (en) * 1999-03-17 2004-11-30 Oracle International Corporation Providing clients with services that retrieve data from data sources that do not necessarily support the format required by the clients
US6463440B1 (en) * 1999-04-08 2002-10-08 International Business Machines Corporation Retrieval of style sheets from directories based upon partial characteristic matching
US6584567B1 (en) * 1999-06-30 2003-06-24 International Business Machines Corporation Dynamic connection to multiple origin servers in a transcoding proxy
US6834306B1 (en) * 1999-08-10 2004-12-21 Akamai Technologies, Inc. Method and apparatus for notifying a user of changes to certain parts of web pages
US6615212B1 (en) * 1999-08-19 2003-09-02 International Business Machines Corporation Dynamically provided content processor for transcoded data types at intermediate stages of transcoding process
US6993476B1 (en) * 1999-08-26 2006-01-31 International Business Machines Corporation System and method for incorporating semantic characteristics into the format-driven syntactic document transcoding framework
US6421717B1 (en) * 1999-09-10 2002-07-16 Avantgo, Inc. System, method, and computer program product for customizing channels, content, and data for mobile devices
US6775805B1 (en) * 1999-10-06 2004-08-10 International Business Machines Corporation Method, apparatus and program product for specifying an area of a web page for audible reading
US7475346B1 (en) * 1999-12-22 2009-01-06 Unisys Corporation System and method for providing a customizable web portal service
US7349955B1 (en) * 2000-02-11 2008-03-25 Goamerica, Inc. Method of and system for transferring data over a wireless communications network
US7502922B1 (en) * 2000-03-01 2009-03-10 Novell, Inc. Computer network having a security layer interface independent of the application transport mechanism
US6311180B1 (en) * 2000-03-28 2001-10-30 Linx Data Terminals, Inc. Method for mapping and formatting information for a display device
US20040215829A1 (en) * 2000-03-30 2004-10-28 United Devices, Inc. Data conversion services and associated distributed processing system
US6494762B1 (en) * 2000-03-31 2002-12-17 Matsushita Electrical Industrial Co., Ltd. Portable electronic subscription device and service
US7509397B1 (en) * 2000-04-06 2009-03-24 Yahoo! Inc. Web portholes: using web proxies to capture and enhance display real estate
US6742038B2 (en) * 2000-04-07 2004-05-25 Danger, Inc. System and method of linking user identification to a subscriber identification module
US7415537B1 (en) * 2000-04-07 2008-08-19 International Business Machines Corporation Conversational portal for providing conversational browsing and multimedia broadcast on demand
US20040049737A1 (en) * 2000-04-26 2004-03-11 Novarra, Inc. System and method for displaying information content with selective horizontal scrolling
US20090125809A1 (en) * 2000-04-26 2009-05-14 Novarra, Inc. System and Method for Adapting Information Content for an Electronic Device
US20100228880A1 (en) * 2000-04-26 2010-09-09 Simon Hunt System and Method for Providing and Displaying Information Content
US7134073B1 (en) * 2000-06-15 2006-11-07 International Business Machines Corporation Apparatus and method for enabling composite style sheet application to multi-part electronic documents
US7058699B1 (en) * 2000-06-16 2006-06-06 Yahoo! Inc. System and methods for implementing code translations that enable persistent client-server communication via a proxy
US6738614B1 (en) * 2000-06-19 2004-05-18 1477.Com Wireless, Inc. Method and system for communicating data to a wireless device
US6920488B1 (en) * 2000-07-28 2005-07-19 International Business Machines Corporation Server assisted system for accessing web pages from a personal data assistant
US7249196B1 (en) * 2000-10-06 2007-07-24 Juniper Networks, Inc. Web page source file transfer system and method
US20020143821A1 (en) * 2000-12-15 2002-10-03 Douglas Jakubowski Site mining stylesheet generator
US20030120686A1 (en) * 2001-12-21 2003-06-26 Xmlcities, Inc. Extensible stylesheet designs using meta-tag and/or associated meta-tag information
US20070067329A1 (en) * 2005-07-21 2007-03-22 Maryam Kamvar Overloaded communication session

Cited By (37)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US20070220599A1 (en) * 2006-03-15 2007-09-20 Doug Moen Client-side extensions for use in connection with HTTP proxy policy enforcement
US8826411B2 (en) * 2006-03-15 2014-09-02 Blue Coat Systems, Inc. Client-side extensions for use in connection with HTTP proxy policy enforcement
US20110047249A1 (en) * 2008-02-12 2011-02-24 Mtld Top Level Domain Limited Determining a property of a communication device
US9185182B2 (en) 2008-02-12 2015-11-10 Afilias Technologies Limited Determining a property of a communication device
US8396990B2 (en) 2008-10-10 2013-03-12 Afilias Technologies Limited Transcoding web resources
US9882954B2 (en) * 2009-03-31 2018-01-30 Snap Inc. Selective partial updates of web content
US20120284611A1 (en) * 2009-03-31 2012-11-08 International Business Machines Corporation Selective partial updates of web content
US20110022559A1 (en) * 2009-07-24 2011-01-27 Bank Of America Corporation Browser preview
US8930805B2 (en) * 2009-07-24 2015-01-06 Bank Of America Corporation Browser preview
US9003309B1 (en) * 2010-01-22 2015-04-07 Adobe Systems Incorporated Method and apparatus for customizing content displayed on a display device
US8346889B1 (en) 2010-03-24 2013-01-01 Google Inc. Event-driven module loading
US8407319B1 (en) 2010-03-24 2013-03-26 Google Inc. Event-driven module loading
US20110258250A1 (en) * 2010-04-19 2011-10-20 Mtld Top Level Domain Limited Transcoder hinting
US9141724B2 (en) * 2010-04-19 2015-09-22 Afilias Technologies Limited Transcoder hinting
US8453049B1 (en) * 2010-05-19 2013-05-28 Google Inc. Delayed code parsing for reduced startup latency
US8458585B1 (en) * 2010-05-19 2013-06-04 Google Inc. Delayed code parsing for reduced startup latency
US9703761B2 (en) 2010-05-19 2017-07-11 Google Inc. Delayed code parsing for reduced startup latency
US11385913B2 (en) 2010-07-08 2022-07-12 Deviceatlas Limited Server-based generation of user interfaces for delivery to mobile communication devices
US10705862B2 (en) 2010-07-08 2020-07-07 Afilias Technologies Limited Server-based generation of user interfaces for delivery to mobile communication devices
US20120188264A1 (en) * 2010-09-27 2012-07-26 Research In Motion Limited Mobile wireless communications system providing enhanced user interface (ui) content display features and related methods
US20120096366A1 (en) * 2010-10-15 2012-04-19 Cellco Partnership D/B/A Verizon Wireless Technique for handling urls for different mobile devices that use different user interface platforms
US9009599B2 (en) * 2010-10-15 2015-04-14 Cellco Partnership Technique for handling URLs for different mobile devices that use different user interface platforms
US9542501B2 (en) * 2011-01-28 2017-01-10 Radware Ltd. System and method for presenting content in a client/server environment
US20120194519A1 (en) * 2011-01-28 2012-08-02 Strangeloop Networks Inc. Image Optimization
JP2015518589A (en) * 2012-04-16 2015-07-02 オ ソク クォン Web page dynamic conversion system, method, and computer-readable recording medium
CN104380280A (en) * 2012-04-16 2015-02-25 权五石 System and method for dynamically converting webpage, and computer-readable recording medium
US10798127B2 (en) 2012-05-07 2020-10-06 Digital Guardian Llc Enhanced document and event mirroring for accessing internet content
US9489356B2 (en) * 2012-05-07 2016-11-08 Digital Guardian, Inc. Enhanced document and event mirroring for accessing internet content
US20140129920A1 (en) * 2012-05-07 2014-05-08 Armor5, Inc. Enhanced Document and Event Mirroring for Accessing Internet Content
US20140033018A1 (en) * 2012-07-30 2014-01-30 Vistaprint Technologies Limited Method and system for automatically generating social network site page based on electronic document content
US20150278818A1 (en) * 2014-03-31 2015-10-01 Ncr Corporation Fraud Detection in Self-Service Terminal
US20160124914A1 (en) * 2014-10-30 2016-05-05 Alibaba Group Holding Limited Page Processing for Mobile App
WO2016069946A1 (en) * 2014-10-30 2016-05-06 Alibaba Group Holding Limited Page processing for mobile app
CN105574049A (en) * 2014-10-30 2016-05-11 阿里巴巴集团控股有限公司 Page processing method, device and system of mobile applications
WO2017020072A1 (en) 2015-07-31 2017-02-09 Wisetech Global Limited Systems and methods for executable content and executable content flow distribution
AU2016302391B2 (en) * 2015-07-31 2022-06-23 WiseTech Global (Licensing) Pty Ltd Systems and methods for executable content and executable content flow distribution
CN108475267A (en) * 2015-07-31 2018-08-31 慧咨环球有限公司 System and method for executable content and executable content stream distribution

Also Published As

Publication number Publication date
US8793341B2 (en) 2014-07-29
US7574486B1 (en) 2009-08-11
US20100017502A1 (en) 2010-01-21

Similar Documents

Publication Publication Date Title
US8793341B2 (en) Web page content translator
US8589388B2 (en) Method, system, and software for transmission of information
US6338096B1 (en) System uses kernals of micro web server for supporting HTML web browser in providing HTML data format and HTTP protocol from variety of data sources
US6272484B1 (en) Electronic document manager
US20180032629A1 (en) Transport and administration model for offline browsing
US6405222B1 (en) Requesting concurrent entries via bookmark set
US6647531B2 (en) Customization of network documents
US7072984B1 (en) System and method for accessing customized information over the internet using a browser for a plurality of electronic devices
US7747782B2 (en) System and method for providing and displaying information content
US6493758B1 (en) Offline viewing of internet content with a mobile device
US6393462B1 (en) Method and apparatus for automatic downloading of URLs and internet addresses
JP3924102B2 (en) Method for customizing file and information processing system
US7500181B2 (en) Method for updating a portal page
US20010009016A1 (en) Computer-based presentation manager and method for individual user-device data representation
EP1641211A2 (en) Web server and method for dynamic content.
US20040205496A1 (en) Displaying subheadings and hyperlinks in a scrollable long document
WO2004040481A1 (en) A system and method for providing and displaying information content
US20020188435A1 (en) Interface for submitting richly-formatted documents for remote processing
KR19990044850A (en) Method and system for international support of Internet web pages
US8019884B2 (en) Proxy content for submitting web service data in the user&#39;s security context
US6253229B1 (en) Hotspots only interfaces to links in hypertext document pages in network display stations
US20030106025A1 (en) Method and system for providing XML-based web pages for non-pc information terminals
JP2004510251A (en) Configurable conversion of electronic documents
WO2002087135A2 (en) System and method for adapting information content for an electronic device
WO2001073562A1 (en) Content server device

Legal Events

Date Code Title Description
AS Assignment

Owner name: TELECOMMUNICATION SYSTEMS, INC.,MARYLAND

Free format text: ASSIGNMENT OF ASSIGNORS INTEREST;ASSIGNORS:CHENG, YIN;WILFREDO, PADIN;JIANG, RONGLI;AND OTHERS;REEL/FRAME:022944/0567

Effective date: 20020111

AS Assignment

Owner name: SILICON VALLEY BANK, AGENT, MASSACHUSETTS

Free format text: SECURITY AGREEMENT;ASSIGNORS:TELECOMMUNICATION SYSTEMS, INC.;LONGHORN ACQUISITION, LLC;SOLVERN INNOVATIONS, INC.;AND OTHERS;REEL/FRAME:023870/0484

Effective date: 20091231

Owner name: SILICON VALLEY BANK, AGENT,MASSACHUSETTS

Free format text: SECURITY AGREEMENT;ASSIGNORS:TELECOMMUNICATION SYSTEMS, INC.;LONGHORN ACQUISITION, LLC;SOLVERN INNOVATIONS, INC.;AND OTHERS;REEL/FRAME:023870/0484

Effective date: 20091231

AS Assignment

Owner name: NEXTGEN COMMUNICATIONS, INC., MARYLAND

Free format text: RELEASE;ASSIGNOR:SILICON VALLEY BANK;REEL/FRAME:031307/0347

Effective date: 20130927

Owner name: TELECOMMUNICATION SYSTEMS, INC., MARYLAND

Free format text: RELEASE;ASSIGNOR:SILICON VALLEY BANK;REEL/FRAME:031307/0347

Effective date: 20130927

Owner name: MICRODATA GIS, INC., MARYLAND

Free format text: RELEASE;ASSIGNOR:SILICON VALLEY BANK;REEL/FRAME:031307/0347

Effective date: 20130927

Owner name: SOLVERN INNOVATIONS, INC., MARYLAND

Free format text: RELEASE;ASSIGNOR:SILICON VALLEY BANK;REEL/FRAME:031307/0347

Effective date: 20130927

Owner name: MICRODATA, LLC, MARYLAND

Free format text: RELEASE;ASSIGNOR:SILICON VALLEY BANK;REEL/FRAME:031307/0347

Effective date: 20130927

Owner name: NETWORKS IN MOTION, INC., MARYLAND

Free format text: RELEASE;ASSIGNOR:SILICON VALLEY BANK;REEL/FRAME:031307/0347

Effective date: 20130927

AS Assignment

Owner name: CRFD RESEARCH, INC., VIRGINIA

Free format text: ASSIGNMENT OF ASSIGNORS INTEREST;ASSIGNOR:TELECOMMUNICATION SYSTEMS, INC.;REEL/FRAME:031994/0124

Effective date: 20130930

AS Assignment

Owner name: DBD CREDIT FUNDING, LLC, NORTH CAROLINA

Free format text: SECURITY INTEREST;ASSIGNORS:MARATHON PATENT GROUP, INC.;CRFD RESEARCH, INC.;REEL/FRAME:034872/0689

Effective date: 20150129

STCB Information on status: application discontinuation

Free format text: ABANDONED -- FAILURE TO RESPOND TO AN OFFICE ACTION

AS Assignment

Owner name: TELECOMMUNICATION SYSTEMS, INC., MARYLAND

Free format text: RELEASE BY SECURED PARTY;ASSIGNOR:SILICON VALLEY BANK;REEL/FRAME:037994/0113

Effective date: 20160223

Owner name: NETWORKS IN MOTION, INC., WISCONSIN

Free format text: RELEASE BY SECURED PARTY;ASSIGNOR:SILICON VALLEY BANK;REEL/FRAME:037994/0113

Effective date: 20160223

Owner name: SOLVEM INNOVATIONS, INC., MARYLAND

Free format text: RELEASE BY SECURED PARTY;ASSIGNOR:SILICON VALLEY BANK;REEL/FRAME:037994/0113

Effective date: 20160223

Owner name: QUASAR ACQUISITION, LLC, GEORGIA

Free format text: RELEASE BY SECURED PARTY;ASSIGNOR:SILICON VALLEY BANK;REEL/FRAME:037994/0113

Effective date: 20160223

Owner name: LONGHORN ACQUISITION, LLC, MARYLAND

Free format text: RELEASE BY SECURED PARTY;ASSIGNOR:SILICON VALLEY BANK;REEL/FRAME:037994/0113

Effective date: 20160223

AS Assignment

Owner name: CITIBANK, N.A., NEW YORK

Free format text: SECURITY INTEREST;ASSIGNORS:COMTECH TELECOMMUNICATIONS CORP.;COMTECH EF DATA CORP.;COMTECH XICOM TECHNOLOGY, INC.;AND OTHERS;REEL/FRAME:048104/0080

Effective date: 20181031