US20180007114A9 - Server-based browser system - Google Patents

Server-based browser system Download PDF

Info

Publication number
US20180007114A9
US20180007114A9 US14/496,562 US201414496562A US2018007114A9 US 20180007114 A9 US20180007114 A9 US 20180007114A9 US 201414496562 A US201414496562 A US 201414496562A US 2018007114 A9 US2018007114 A9 US 2018007114A9
Authority
US
United States
Prior art keywords
page
client device
server
client
browser
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.)
Granted
Application number
US14/496,562
Other versions
US9866612B2 (en
US20160094609A1 (en
Inventor
Ahad Rana
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.)
MERCURY KINGDOM ASSETS Ltd
Original Assignee
MERCURY KINGDOM ASSETS Ltd
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
Application filed by MERCURY KINGDOM ASSETS Ltd filed Critical MERCURY KINGDOM ASSETS Ltd
Priority to US14/496,562 priority Critical patent/US9866612B2/en
Publication of US20160094609A1 publication Critical patent/US20160094609A1/en
Publication of US20180007114A9 publication Critical patent/US20180007114A9/en
Application granted granted Critical
Publication of US9866612B2 publication Critical patent/US9866612B2/en
Adjusted expiration legal-status Critical
Expired - Fee Related legal-status Critical Current

Links

Images

Classifications

    • 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]
    • 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/954Navigation, e.g. using categorised browsing
    • 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
    • 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
    • G06F17/2235
    • G06F17/30873
    • G06F17/30899
    • G06F17/30905
    • 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/134Hyperlinking
    • H04L65/607
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L65/00Network arrangements, protocols or services for supporting real-time applications in data packet communication
    • H04L65/60Network streaming of media packets
    • H04L65/70Media network packetisation
    • 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/42
    • 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/04Protocols for data compression, e.g. ROHC

Definitions

  • the invention relates to Web browsing technology. More particularly, the invention relates to a system and method for fast delivery of and fast rendering of Web pages on a lightweight network device.
  • a typical Web page today contains not only HTML content but also, by reference to, other content elements such as graphics and external style sheets.
  • a browser acquires the referenced content elements by spawning worker threads that retrieve the data via multiple HTTP-TCP/IP connections.
  • This model works well for desktop systems containing large amounts of processing power and RAM. However, it is usually not feasible for mobile, lightweight, embedded devices in which processing power and RAM are much limited.
  • HTML parsing, validation, and layout code is normally quite complex and requires large amount of CPU and RAM to execute. Size and manufacturing cost have been major concerns in providing embedded devices with a capacity to implement the process. Although embedded devices are getting more and more processing power and RAM, the requirements of a proper browser engine still outdistance the resources available to even the highest end of embedded devices.
  • the invention provides a server-based browser system.
  • the system offloads heavy weight components of a traditional browser to a back end server.
  • the invention leaves a lightweight client device with a minimal task of implementing a customizable interface to display a pre-rendered representation of Web pages.
  • a preferred embodiment of the invention provides a server-based browser and a client system browser.
  • the client browser determines the position of a user click on its display screen and sends a navigation request containing the coordinates of the click, or a hotspot ID, to the server-side browser.
  • the client browser will also accept a specific URL from a user and places the URL in the navigation request.
  • the server-side browser retrieves a Document Object Model (DOM) model and view tree from a storage device for the client. It then finds the location on the Web page that the user clicked on using the coordinates or hotspot ID received from the client. If there is a script associated with the location, it is executed and the resulting page location is requested from the appropriate server. If there is a URL associated with the location, it is requested from the appropriate server.
  • DOM Document Object Model
  • the response Web page HTML page definition is parsed and a DOM tree model is created.
  • the server-side browser uses the DOM tree and creates a two-dimensional view tree model, and stores both trees on the storage device.
  • the server-side browser retrieves a style sheet, layout algorithms, and device constraints for the client device from the storage device. It lays out the view model using the style sheet, layout algorithms, and device constraints onto a virtual page.
  • the DOM tree and view tree are compressed into a stream and sent to the client browser which decodes the stream, translates the DOM tree and view tree, and displays the page to the user.
  • the server-side browser determines the visual content on the virtual page and the location of the visual content.
  • Visual content and positional information are highly compressed and formatted into a stream and sent to the client browser which decodes the stream and displays the page to the user using the visual content and positional information.
  • the DOM tree and view tree and all state information (including Javascripts and cookies) for the client are stored on the storage device by the server-side browser.
  • FIG. 1 is a block schematic diagram of a preferred embodiment of the invention showing a server-side browser and a client browser according to the invention
  • FIG. 2 is a block schematic diagram of a server-side browser and renderer and client device according to the invention
  • FIG. 3 is a block schematic diagram of a server-side browser engine and client device according to the invention.
  • FIG. 4 is a block schematic diagram showing an HTML document tree according to the invention.
  • FIG. 5 is a block schematic diagram showing a view tree according to the invention.
  • FIG. 6 is a block schematic diagram of a view layout of a Web page according to the invention.
  • FIG. 7 is a block schematic diagram of a flowchart of an embodiment of the invention according to the invention.
  • FIG. 8 is a block schematic diagram of a task viewpoint of a preferred embodiment of the invention according to the invention.
  • the invention is embodied in a server-based browser system.
  • a system according to the invention offloads heavy weight components of a traditional browser to a back end server.
  • the invention provides a server-based browser system that leaves a lightweight client device with a minimal task of implementing a customizable interface to display a pre-rendered representation of Web pages.
  • a typical desktop browser requires a large amount of processor time to handle the load of obtaining Web page information and parsing the HTML code in the page. Secondary requests within the HTML code also require a large amount of processing time. Simple client devices such as PDAs, cellphones, and low CPU power set top boxes cannot handle the amount of processing power required to perform typical Web browsing.
  • bandwidth on devices such as cellphones are limited and are charged to the user on a byte basis. This means that the large data transfers involved in typical Web browsing are too expensive in terms of bandwidth limitations and cost to the user.
  • the invention provides a server-based 101 browser 104 that converts Web pages to a minimal format adaptable to different types of wired/wireless client devices such as cellphones, PDAs, and set top TV boxes.
  • a light weight browser 105 is provided on a client device 102 to accept highly compressed streams of data from the server-side browser 104 .
  • the server-side browser 104 accesses information across the Internet or intranet 103 .
  • a user using a client device 206 , 207 requests a Web page from a light weight browser or the light weight browser itself requests a Web page.
  • the request is sent from the client 206 , 207 to a server-side browser 201 .
  • the server-side browser 201 identifies the Web page that the user requested and sends a request to the proper server across the Internet or intranet.
  • the server-side browser 201 When the requested Web page is returned to the server-side browser 201 , the server-side browser 201 loads the initial HTML document.
  • the received HTML document consists of text, which comprises the content of the document, and tags, which define the structure and appearance of the document.
  • the server-side browser 201 looks at any dependencies within the document (e.g., referenced images, Javascript files that need to be loaded remotely, etc.) and opens multiple sockets to get the required information across the Internet or intranet.
  • the server-side browser 201 gathers the Web page information and lays out the information to calculate how to display the information on a particular device.
  • the server-side browser 201 makes a second pass at the layout information and then transcodes the information into a very tight data stream that can be represented on the client 206 , 207 .
  • the stream includes positional information that is not present in the normal HTML for the Web page.
  • the server-side browser 201 takes all of the HTML information for a Web page and represents it as two dimensional content on the server. This two-dimensional representation helps the browser determine the exact position information positional information for all of the pieces of a particular HTML Web page. If there are any images or other dependencies, the server-side browser 201 scales (or crops) the images down and/or preprocesses the images (e.g., reduce the bit depth of an image, dither the image, etc.) to match the capabilities of the client 206 , 207 . The browser then creates a compressed stream that is sent down to the client. This compressed stream contains text and images with exact positional information (that tells where the pieces of content fit on the page), and hot spot information. The browser maps each rectangular hotspot region to a related URL. Thus, no extraneous information, such as hyperlink URLs, or Cookie Data is sent down to the client.
  • the server-side browser 205 uses device characteristics information 202 for each supported device type, consisting of the associated default CSS style sheet, a list of supported fonts and their text metrics, device aspect ratios, pixel depth, color palette, form control dimensions, preferred layout algorithms, a DTD specifying level of HTML compliance, JavaScript policies, the User-Agent String to represent to a Web Server, and the compressed stream format encoder, to properly determine the ideal representation of Web content on the device.
  • Various examples of potential clients with vastly different device characteristics could include: a cellphone 206 with a minimal CPU and minimal RAM; a PDA client with a small display but powerful CPU and high RAM; or a TV box 207 with a large display, high capacity CPU, low RAM, and non TCP/IP based communications.
  • the server-side browser 205 utilizes many different layout algorithms to properly render information with these various classes of clients that all have different: display, CPU, RAM, and IO constraints.
  • a lightweight client browser is provided on the clients 206 , 207 that accepts a standard information format from the server-side browser 201 and displays the data streams. This means that the server-side browser 201 can be updated at any time without affecting the clients 206 , 207 .
  • a preferred embodiment of the invention provides a server-side browser engine 302 that accepts HTML (e.g., HTML 4.0 content with support for CSS version 1) pages 303 and parses the HTML 304 .
  • the parser 304 creates a Document Object Model (DOM) object hierarchy model 305 .
  • the DOM model 305 is a tree representation of the HTML in the Web page, which is well known in the art.
  • a style sheet 306 tells the server-side browser 301 what fonts to use for standard HTML tags (e.g., bold), border sizes, and other stylistic information for each supported client device.
  • a device information file 307 is also used by the browser that tells the server-side browser 301 the limitations of a client device (e.g., the size of a text control, fonts available, aspect ratio, etc.).
  • the server-side browser 301 discovers what device type the client is when the client signs onto the server.
  • the server-side browser 301 uses the style sheet 306 and the device information 307 for the particular device to create a view tree 308 which is a two-dimensional model of the parent-child relationship between viewable objects of the DOM model 305 .
  • a DOM tree is shown in FIG. 4 .
  • the HTML 401 is the root of the tree and underneath has a Body tag 402 .
  • Under the Body tag 402 is an Anchor tag 403 which has Text 404 underneath.
  • the Table 405 has a row 406 which has a cell 407 .
  • the browser makes views of DOM tree elements that are visible. For example, a Text view 408 is made of the Text 404 , a Table view 409 is made of the Table 405 , a TR view 410 is made of the row 406 , and a TD view 411 is made of the cell 407 .
  • FIG. 5 An exemplary view model is shown in FIG. 5 , where a Body view 501 is the root of the tree.
  • a Table view 502 sits below the Body view 501 and has a TR view 503 below it.
  • a TD view 504 is below the TR view 503 .
  • the TR view 504 has both a text view 505 and an image view 506 below it.
  • the server-side browser 301 then lays out the view model 308 on a virtual page.
  • Each view in the view model 308 has a rectangular area of information attached to it.
  • the server-side browser 301 lays out the views using specific layout algorithms for each view (e.g., tables, block levels, etc.) and uses the style sheet 306 and device information 307 for the particular device to make sure that any special characteristics or behaviors of the device are taken into account.
  • specific layout algorithms for each view e.g., tables, block levels, etc.
  • For example, for a TV box client there may be a fixed table width defined in the view and fixed table widths are ignored by the TV box, or, one pixel width table borders are only supported on the TV box client.
  • An example of a layout algorithm is every cell in a table is considered a row in itself, for a certain device each cell is to be laid out vertical
  • the server-side browser performs the first layout pass which lays out all of the views of the page 601 .
  • the page 601 is a virtual view of how the page looks.
  • a body view 605 has a table view 604 within it.
  • the Table view 604 has a row 603 which has a cell with text in it 602 .
  • Each view has a rectangular area that it represents and a parent-child relationship. This allows the server-side browser to walk through the viewable area to see what it represents.
  • a second pass is made to determine what the real content is on the page.
  • HTML authors often define multiply nested tables to constrain a layout of an HTML page.
  • the server-side browser throws away the unnecessary information that does not contribute to the appearance of the page (e.g., not renderable).
  • the server-side browser is concerned with the physical positioning of content elements within the page. For example, the browser finds text 602 on the page 601 and accumulates the text into a string and compresses it to send to the client.
  • the server-side browser also sends the client information that tells the client where the text should be displayed in its viewing area. This information is placed in a binary format that the client device feeds into.
  • the DOM tree and view tree and all state information (including Javascripts) for the client are preserved on the server. This is to ensure that, when the user is interacting with a page on the client, the server-side browser knows where the user has clicked on the page.
  • the server-side browser does not send URL links to the client. This means that the client only has positional or hotspot information relating to where the user clicked or pressed on the page and sends that coordinate or hotspot information to the server-side browser.
  • the server-side browser looks at the DOM tree and view model to find where the coordinates map onto the page.
  • the view model is used to find the location of the coordinates or hotspot ID and the DOM tree is used to find the URL or script associated with the clicked area.
  • the server-side browser finds the area that corresponds to location where the user clicked, the server-side browser executes whatever script or URL request that corresponds with the area.
  • the server-side browser then updates the client with the new page if the action was navigational, for example.
  • the server-side browser caches all of the user's cookies in a user state that the server-side browser preserves on the server for each user.
  • a session object exists on both the server and the client.
  • the session protocol is used by the client and server to communicate information. For example, when the client first signs onto the server, it tells the server its configuration information and other information.
  • the server-side browser looks into its database and finds the client device's style and device information.
  • the client browser 711 sends a navigation request to the server-side browser engine 701 .
  • the browser session 702 retrieves the client specific style sheet 703 and layout algorithms 704 .
  • the browser session 702 fetches the requested Web page from the Internet or intranet.
  • the HTML Web page 705 is parsed and a DOM tree model is created 706 .
  • the DOM tree model is then used to create a two-dimensional view tree model 707 .
  • the invention lays out the view tree based on the client specific style sheet and layout algorithms 708 . Any additional layouts are performed on the view tree to fit the client device constraints 709 .
  • the resulting two-dimensional view tree and DOM tree are encoded in a lightweight format and sent to the client which decodes the format 710 and displays the resulting page to the user through the client browser 711 .
  • the Client Browser module 812 determines the position of a user click or press on its display screen and sends a navigation request containing the coordinates of the click or press, or the hotspot ID, to the server-side browser through the Client Session module 811 to the Server Session module 804 .
  • the Client Browser module 812 will also accept a specific URL from a user and places the URL in the navigation request.
  • the Server Session module 804 forwards the navigation request to the Find Position module 805 .
  • the Find Position module 805 accepts Specific URLs from the client, coordinates of a user's click or press, and hotspot IDs 810 .
  • the Find Position module 805 forwards any specific URL to the Web Page Manager 902 . Otherwise, the Find Position module 805 retrieves the DOM model and view tree from the storage device 807 for the particular client. It then finds the location on the Web page that the user clicked or pressed on using the coordinates or hotspot ID received from the client. If there is a script associated with the location, it is executed and the resulting page location is sent to the Web Page Manager 902 . If there is a URL associated with the location, it is forwarded to the Web Page Manager 902 .
  • the Web Page Manager 802 receives the URL from the Find Position module 805 and formats a request for the Web page. The request is sent to the Web Session module 803 . The Web page is returned to the Web Session module 803 and is forwarded to the Web Page Manager 802 .
  • the Web page Manager 802 forwards the HTML Web page definition to the Parse HTML module 801 .
  • the Parse HTML module 801 parses the HTML and creates a DOM tree model which it stores on the storage device 807 .
  • the Web page Manager 802 then activates the Create View module 806 .
  • the Create View module 806 uses the DOM model stored on the storage device 807 , creates a two-dimensional view tree model, and stores it on the storage device 807 .
  • the Web page Manager 802 retrieves the style sheet, layout algorithms, and device constraints for the specific client device are retrieved from the storage device 807 .
  • the Web page Manager 802 lays out the view model using the style sheet, layout algorithms, and device constraints.
  • the Client Browser 812 is a subset of the server-side browser engine, then the DOM tree and view tree are compressed into a stream 809 and sent through the Server Session module 804 to the Client Browser 812 via the Client Session module 811 .
  • the Client Browser 812 decodes the stream, translates the DOM tree and view tree, and displays the page to the user.
  • the Web page Manager 802 performs the first layout pass and lays out all of the views of the page.
  • the Web page Manager 802 then makes a second pass to determine the visual content on the page.
  • Visual content and positional information are highly compressed and formatted into a stream 809 and forwarded to the Server Session module 804 .
  • the Server Session module 804 sends the stream to the Client Browser 812 via the Client Session module 811 .
  • the Client Browser 812 decodes the stream and displays the page to the user using the visual content and positional information.
  • the DOM tree and view tree and all state information (including Javascripts and cookies) for the client are stored on the storage device 807 by the Web page Manager 802 .

Landscapes

  • Engineering & Computer Science (AREA)
  • Theoretical Computer Science (AREA)
  • Databases & Information Systems (AREA)
  • General Engineering & Computer Science (AREA)
  • General Physics & Mathematics (AREA)
  • Physics & Mathematics (AREA)
  • Data Mining & Analysis (AREA)
  • Computer Networks & Wireless Communication (AREA)
  • Signal Processing (AREA)
  • Remote Sensing (AREA)
  • Radar, Positioning & Navigation (AREA)
  • Multimedia (AREA)
  • Computer Security & Cryptography (AREA)
  • Health & Medical Sciences (AREA)
  • Artificial Intelligence (AREA)
  • Audiology, Speech & Language Pathology (AREA)
  • Computational Linguistics (AREA)
  • General Health & Medical Sciences (AREA)
  • Information Transfer Between Computers (AREA)

Abstract

A server-based browser system provides a server-based browser and a client system browser. The client browser reports the position of a user click on its display screen, hotspot ID, or URL to the server-side browser which retrieves a Document Object Model (DOM) model and view tree for the client and finds the location on the Web page that the user clicked on using the coordinates or hotspot ID received from the client. If there is a script associated with the location, it is executed and the resulting page location is requested from the appropriate server. If there is a URL associated with the location, it is requested from the appropriate server. The response Web page HTML definition is parsed and a DOM tree model is created which is used to create a view tree model. The server-side browser retrieves a style sheet, layout algorithms, and device constraints for the client device and lays out the view model using them onto a virtual page and determines the visual content. Textual and positional information are highly compressed and formatted into a stream and sent to the client browser which decodes the stream and displays the page to the user using the textual and positional information.

Description

    CROSS REFERENCE TO RELATED APPLICATIONS
  • This application is a continuation of U.S. patent application Ser. No. 12/535,550 entitled “SERVER-BASED BROWSER SYSTEM,” filed on April Aug. 4, 2009, which is a continuation of U.S. Pat. No. 7,587,669 entitled “SERVER-BASED BROWSER SYSTEM,” filed on Apr. 16, 2004, which is a national stage entry of Patent Cooperation Treaty (PCT) Application No. PCT/US02/11420, filed on Apr. 9, 2002, which claims benefit of Provisional App. No. 60/282,194 filed on Apr. 9, 2001, the entirety of which are incorporated by reference herein in their entireties.
  • BACKGROUND OF THE INVENTION
  • 1. Technical Field
  • The invention relates to Web browsing technology. More particularly, the invention relates to a system and method for fast delivery of and fast rendering of Web pages on a lightweight network device.
  • 2. Description of the Prior Art
  • A typical Web page today contains not only HTML content but also, by reference to, other content elements such as graphics and external style sheets. A browser acquires the referenced content elements by spawning worker threads that retrieve the data via multiple HTTP-TCP/IP connections. This model works well for desktop systems containing large amounts of processing power and RAM. However, it is usually not feasible for mobile, lightweight, embedded devices in which processing power and RAM are much limited.
  • The process for proper HTML parsing, validation, and layout code is normally quite complex and requires large amount of CPU and RAM to execute. Size and manufacturing cost have been major concerns in providing embedded devices with a capacity to implement the process. Although embedded devices are getting more and more processing power and RAM, the requirements of a proper browser engine still outdistance the resources available to even the highest end of embedded devices.
  • High levels of CPU usage are detrimental to the preservation of battery life, which is a very important consideration for today's mobile devices. Heavy loads in HTTP communications, HTML parsing, HTML validation and layout may largely shorten the battery life.
  • Bandwidth usage is also a major constraint that must be considered in designing a browser model for embedded devices. Text based HTML content, although compressible, is already quite large with respect to the limited transmission speed of today's wireless networks. When image content designed for higher resolution and larger form factor display is included, one may quickly end up consuming a lot of wasted bandwidth transmitting redundant, not necessarily usable data to mobile devices.
  • Although various browsing technologies have been already presented in the marketplace, many of them fail to meet the tight constraints and stringent requirements of the embedded devices. Writing a cross platform code base for these devices is an even bigger challenge, given the multitude of operating systems, memory models and processors available for embedded device manufacturers.
  • It would be advantageous to provide a server-based browser system that offloads heavy weight components of a traditional browser to a back end server. It would further be advantageous to provide a server-based browser system that leaves a lightweight client device with a minimal task of implementing a customizable interface to display a pre-rendered representation of Web pages.
  • SUMMARY OF THE INVENTION
  • The invention provides a server-based browser system. The system offloads heavy weight components of a traditional browser to a back end server. In addition, the invention leaves a lightweight client device with a minimal task of implementing a customizable interface to display a pre-rendered representation of Web pages.
  • A preferred embodiment of the invention provides a server-based browser and a client system browser. The client browser determines the position of a user click on its display screen and sends a navigation request containing the coordinates of the click, or a hotspot ID, to the server-side browser. The client browser will also accept a specific URL from a user and places the URL in the navigation request.
  • The server-side browser retrieves a Document Object Model (DOM) model and view tree from a storage device for the client. It then finds the location on the Web page that the user clicked on using the coordinates or hotspot ID received from the client. If there is a script associated with the location, it is executed and the resulting page location is requested from the appropriate server. If there is a URL associated with the location, it is requested from the appropriate server.
  • The response Web page HTML page definition is parsed and a DOM tree model is created. The server-side browser uses the DOM tree and creates a two-dimensional view tree model, and stores both trees on the storage device.
  • The server-side browser retrieves a style sheet, layout algorithms, and device constraints for the client device from the storage device. It lays out the view model using the style sheet, layout algorithms, and device constraints onto a virtual page.
  • If the client browser is a subset of the server-side browser engine, then the DOM tree and view tree are compressed into a stream and sent to the client browser which decodes the stream, translates the DOM tree and view tree, and displays the page to the user.
  • Otherwise, the server-side browser determines the visual content on the virtual page and the location of the visual content. Visual content and positional information are highly compressed and formatted into a stream and sent to the client browser which decodes the stream and displays the page to the user using the visual content and positional information.
  • The DOM tree and view tree and all state information (including Javascripts and cookies) for the client are stored on the storage device by the server-side browser.
  • Other aspects and advantages of the invention will become apparent from the following detailed description in combination with the accompanying drawings, illustrating, by way of example, the principles of the invention.
  • BRIEF DESCRIPTION OF THE DRAWINGS
  • FIG. 1 is a block schematic diagram of a preferred embodiment of the invention showing a server-side browser and a client browser according to the invention;
  • FIG. 2 is a block schematic diagram of a server-side browser and renderer and client device according to the invention;
  • FIG. 3 is a block schematic diagram of a server-side browser engine and client device according to the invention;
  • FIG. 4 is a block schematic diagram showing an HTML document tree according to the invention;
  • FIG. 5 is a block schematic diagram showing a view tree according to the invention;
  • FIG. 6 is a block schematic diagram of a view layout of a Web page according to the invention;
  • FIG. 7 is a block schematic diagram of a flowchart of an embodiment of the invention according to the invention; and
  • FIG. 8 is a block schematic diagram of a task viewpoint of a preferred embodiment of the invention according to the invention.
  • DETAILED DESCRIPTION OF THE INVENTION
  • The invention is embodied in a server-based browser system. A system according to the invention offloads heavy weight components of a traditional browser to a back end server. In addition, the invention provides a server-based browser system that leaves a lightweight client device with a minimal task of implementing a customizable interface to display a pre-rendered representation of Web pages.
  • A typical desktop browser requires a large amount of processor time to handle the load of obtaining Web page information and parsing the HTML code in the page. Secondary requests within the HTML code also require a large amount of processing time. Simple client devices such as PDAs, cellphones, and low CPU power set top boxes cannot handle the amount of processing power required to perform typical Web browsing.
  • Additionally, bandwidth on devices such as cellphones are limited and are charged to the user on a byte basis. This means that the large data transfers involved in typical Web browsing are too expensive in terms of bandwidth limitations and cost to the user.
  • Referring to FIG. 1, the invention provides a server-based 101 browser 104 that converts Web pages to a minimal format adaptable to different types of wired/wireless client devices such as cellphones, PDAs, and set top TV boxes. A light weight browser 105 is provided on a client device 102 to accept highly compressed streams of data from the server-side browser 104. The server-side browser 104 accesses information across the Internet or intranet 103.
  • With respect to FIG. 2, a user using a client device 206, 207 requests a Web page from a light weight browser or the light weight browser itself requests a Web page. The request is sent from the client 206, 207 to a server-side browser 201. The server-side browser 201 identifies the Web page that the user requested and sends a request to the proper server across the Internet or intranet.
  • When the requested Web page is returned to the server-side browser 201, the server-side browser 201 loads the initial HTML document. The received HTML document consists of text, which comprises the content of the document, and tags, which define the structure and appearance of the document. The server-side browser 201 looks at any dependencies within the document (e.g., referenced images, Javascript files that need to be loaded remotely, etc.) and opens multiple sockets to get the required information across the Internet or intranet.
  • The server-side browser 201 gathers the Web page information and lays out the information to calculate how to display the information on a particular device. The server-side browser 201 makes a second pass at the layout information and then transcodes the information into a very tight data stream that can be represented on the client 206, 207. The stream includes positional information that is not present in the normal HTML for the Web page.
  • The server-side browser 201 takes all of the HTML information for a Web page and represents it as two dimensional content on the server. This two-dimensional representation helps the browser determine the exact position information positional information for all of the pieces of a particular HTML Web page. If there are any images or other dependencies, the server-side browser 201 scales (or crops) the images down and/or preprocesses the images (e.g., reduce the bit depth of an image, dither the image, etc.) to match the capabilities of the client 206, 207. The browser then creates a compressed stream that is sent down to the client. This compressed stream contains text and images with exact positional information (that tells where the pieces of content fit on the page), and hot spot information. The browser maps each rectangular hotspot region to a related URL. Thus, no extraneous information, such as hyperlink URLs, or Cookie Data is sent down to the client.
  • The server-side browser 205 uses device characteristics information 202 for each supported device type, consisting of the associated default CSS style sheet, a list of supported fonts and their text metrics, device aspect ratios, pixel depth, color palette, form control dimensions, preferred layout algorithms, a DTD specifying level of HTML compliance, JavaScript policies, the User-Agent String to represent to a Web Server, and the compressed stream format encoder, to properly determine the ideal representation of Web content on the device. Various examples of potential clients with vastly different device characteristics could include: a cellphone 206 with a minimal CPU and minimal RAM; a PDA client with a small display but powerful CPU and high RAM; or a TV box 207 with a large display, high capacity CPU, low RAM, and non TCP/IP based communications. The server-side browser 205 utilizes many different layout algorithms to properly render information with these various classes of clients that all have different: display, CPU, RAM, and IO constraints.
  • A lightweight client browser is provided on the clients 206, 207 that accepts a standard information format from the server-side browser 201 and displays the data streams. This means that the server-side browser 201 can be updated at any time without affecting the clients 206, 207.
  • Referring to FIGS. 3, 4, and 5, a preferred embodiment of the invention provides a server-side browser engine 302 that accepts HTML (e.g., HTML 4.0 content with support for CSS version 1) pages 303 and parses the HTML 304. The parser 304 creates a Document Object Model (DOM) object hierarchy model 305. The DOM model 305 is a tree representation of the HTML in the Web page, which is well known in the art.
  • A style sheet 306 tells the server-side browser 301 what fonts to use for standard HTML tags (e.g., bold), border sizes, and other stylistic information for each supported client device. A device information file 307 is also used by the browser that tells the server-side browser 301 the limitations of a client device (e.g., the size of a text control, fonts available, aspect ratio, etc.). The server-side browser 301 discovers what device type the client is when the client signs onto the server.
  • Using the style sheet 306 and the device information 307 for the particular device, the server-side browser 301 creates a view tree 308 which is a two-dimensional model of the parent-child relationship between viewable objects of the DOM model 305.
  • A DOM tree is shown in FIG. 4. The HTML 401 is the root of the tree and underneath has a Body tag 402. Under the Body tag 402 is an Anchor tag 403 which has Text 404 underneath. There is also a Table 405 beneath the Anchor tag 403. The Table 405 has a row 406 which has a cell 407. The browser makes views of DOM tree elements that are visible. For example, a Text view 408 is made of the Text 404, a Table view 409 is made of the Table 405, a TR view 410 is made of the row 406, and a TD view 411 is made of the cell 407.
  • An exemplary view model is shown in FIG. 5, where a Body view 501 is the root of the tree. A Table view 502 sits below the Body view 501 and has a TR view 503 below it. A TD view 504 is below the TR view 503. The TR view 504 has both a text view 505 and an image view 506 below it.
  • The server-side browser 301 then lays out the view model 308 on a virtual page. Each view in the view model 308 has a rectangular area of information attached to it. The server-side browser 301 lays out the views using specific layout algorithms for each view (e.g., tables, block levels, etc.) and uses the style sheet 306 and device information 307 for the particular device to make sure that any special characteristics or behaviors of the device are taken into account. For example, for a TV box client, there may be a fixed table width defined in the view and fixed table widths are ignored by the TV box, or, one pixel width table borders are only supported on the TV box client. An example of a layout algorithm is every cell in a table is considered a row in itself, for a certain device each cell is to be laid out vertically instead of the normal horizontal layout.
  • With respect to FIG. 6, the server-side browser performs the first layout pass which lays out all of the views of the page 601. The page 601 is a virtual view of how the page looks. In this example, a body view 605 has a table view 604 within it. The Table view 604 has a row 603 which has a cell with text in it 602. Each view has a rectangular area that it represents and a parent-child relationship. This allows the server-side browser to walk through the viewable area to see what it represents.
  • A second pass is made to determine what the real content is on the page. HTML authors often define multiply nested tables to constrain a layout of an HTML page. The server-side browser throws away the unnecessary information that does not contribute to the appearance of the page (e.g., not renderable). The server-side browser is concerned with the physical positioning of content elements within the page. For example, the browser finds text 602 on the page 601 and accumulates the text into a string and compresses it to send to the client. The server-side browser also sends the client information that tells the client where the text should be displayed in its viewing area. This information is placed in a binary format that the client device feeds into.
  • The DOM tree and view tree and all state information (including Javascripts) for the client are preserved on the server. This is to ensure that, when the user is interacting with a page on the client, the server-side browser knows where the user has clicked on the page. The server-side browser does not send URL links to the client. This means that the client only has positional or hotspot information relating to where the user clicked or pressed on the page and sends that coordinate or hotspot information to the server-side browser. The server-side browser looks at the DOM tree and view model to find where the coordinates map onto the page. The view model is used to find the location of the coordinates or hotspot ID and the DOM tree is used to find the URL or script associated with the clicked area. When the server-side browser finds the area that corresponds to location where the user clicked, the server-side browser executes whatever script or URL request that corresponds with the area. The server-side browser then updates the client with the new page if the action was navigational, for example.
  • Cookie data are impractical to place on the client device. The server-side browser caches all of the user's cookies in a user state that the server-side browser preserves on the server for each user.
  • A session object exists on both the server and the client. The session protocol is used by the client and server to communicate information. For example, when the client first signs onto the server, it tells the server its configuration information and other information. The server-side browser looks into its database and finds the client device's style and device information.
  • Referring to FIG. 7, a flowchart of an another preferred embodiment of the invention is shown. The client browser 711 sends a navigation request to the server-side browser engine 701. The browser session 702 retrieves the client specific style sheet 703 and layout algorithms 704.
  • The browser session 702 fetches the requested Web page from the Internet or intranet. The HTML Web page 705 is parsed and a DOM tree model is created 706. The DOM tree model is then used to create a two-dimensional view tree model 707.
  • The invention lays out the view tree based on the client specific style sheet and layout algorithms 708. Any additional layouts are performed on the view tree to fit the client device constraints 709. The resulting two-dimensional view tree and DOM tree are encoded in a lightweight format and sent to the client which decodes the format 710 and displays the resulting page to the user through the client browser 711.
  • With respect to FIG. 8, a task viewpoint of the invention is shown. The Client Browser module 812 determines the position of a user click or press on its display screen and sends a navigation request containing the coordinates of the click or press, or the hotspot ID, to the server-side browser through the Client Session module 811 to the Server Session module 804. The Client Browser module 812 will also accept a specific URL from a user and places the URL in the navigation request. The Server Session module 804 forwards the navigation request to the Find Position module 805. The Find Position module 805 accepts Specific URLs from the client, coordinates of a user's click or press, and hotspot IDs 810.
  • The Find Position module 805 forwards any specific URL to the Web Page Manager 902. Otherwise, the Find Position module 805 retrieves the DOM model and view tree from the storage device 807 for the particular client. It then finds the location on the Web page that the user clicked or pressed on using the coordinates or hotspot ID received from the client. If there is a script associated with the location, it is executed and the resulting page location is sent to the Web Page Manager 902. If there is a URL associated with the location, it is forwarded to the Web Page Manager 902.
  • The Web Page Manager 802 receives the URL from the Find Position module 805 and formats a request for the Web page. The request is sent to the Web Session module 803. The Web page is returned to the Web Session module 803 and is forwarded to the Web Page Manager 802.
  • The Web page Manager 802 forwards the HTML Web page definition to the Parse HTML module 801. The Parse HTML module 801 parses the HTML and creates a DOM tree model which it stores on the storage device 807.
  • The Web page Manager 802 then activates the Create View module 806. The Create View module 806 uses the DOM model stored on the storage device 807, creates a two-dimensional view tree model, and stores it on the storage device 807.
  • Once the view tree is completed, the Web page Manager 802 retrieves the style sheet, layout algorithms, and device constraints for the specific client device are retrieved from the storage device 807. The Web page Manager 802 lays out the view model using the style sheet, layout algorithms, and device constraints.
  • If the Client Browser 812 is a subset of the server-side browser engine, then the DOM tree and view tree are compressed into a stream 809 and sent through the Server Session module 804 to the Client Browser 812 via the Client Session module 811. The Client Browser 812 decodes the stream, translates the DOM tree and view tree, and displays the page to the user.
  • Otherwise, the Web page Manager 802 performs the first layout pass and lays out all of the views of the page. The Web page Manager 802 then makes a second pass to determine the visual content on the page. Visual content and positional information are highly compressed and formatted into a stream 809 and forwarded to the Server Session module 804. The Server Session module 804 sends the stream to the Client Browser 812 via the Client Session module 811. The Client Browser 812 decodes the stream and displays the page to the user using the visual content and positional information.
  • The DOM tree and view tree and all state information (including Javascripts and cookies) for the client are stored on the storage device 807 by the Web page Manager 802.
  • Although the invention is described herein with reference to the preferred embodiment, one skilled in the art will readily appreciate that other applications may be substituted for those set forth herein without departing from the spirit and scope of the present invention. Accordingly, the invention should only be limited by the Claims included below.

Claims (21)

1. (canceled)
2. A method comprising:
receiving a navigation request from a client device, the navigation request including display screen coordinates corresponding to a position on a display of the client device;
identifying a script associated with the display screen coordinates;
executing the script and requesting an associated page from a corresponding server;
receiving the page from the corresponding server;
creating a layout of the page by determining a plurality of content elements present in the page based at least in part on device characteristics information associated with the client device, the position of each content element within said page represented by position data comprising two-dimensional coordinates;
creating a compressed stream containing the plurality of content elements and the position data; and
sending said compressed stream and the layout to the client device.
3. The method of claim 2, further comprising:
identifying any images associated with the page; and
scaling the images based at least in part on the device characteristics information, before creating the compressed stream.
4. The method of claim 2, further comprising:
identifying any images associated with the page; and
cropping the images based at least in part on the device characteristics information, before creating the compressed stream.
5. The method of claim 2, further comprising:
identifying any images associated with the page; and
reducing a bit depth of the image based at least in part on the device characteristics information, before creating the compressed stream.
6. The method of claim 2, wherein the device characteristics information includes stylistic information, layout algorithms, and format encodings associated with the client device.
7. The method of claim 2, wherein the client device is at least one of a cell phone or personal digital assistant (PDA) device.
8. The method of claim 2, wherein the client device is a set top box.
9. The method of claim 2, further comprising:
receiving a sign on request form the client device;
in response to receiving the sign on request, identifying a type associated with the client device; and
based at least in part on the type, accessing the device characteristics information.
10. The method of claim 2, wherein creating the compressed stream comprises:
determining real content associated with the page;
removing nested tables form the page received from the corresponding server; and
accumulating text of the page into a string.
11. A hardware apparatus for hosting a server-based browser that interacts with a plurality of client device types, the interactions comprising:
receiving a navigation request from a client device, the navigation request including display screen coordinates corresponding to a position on a display of the client device;
requesting a page from a corresponding server based at least in part on the display screen coordinates;
receiving the page from the corresponding server;
creating a layout of the page by determining a plurality of content elements present in the page based at least in part on device characteristics information associated with the client device, the position of each content element within said page represented by position data comprising two-dimensional coordinates;
creating a compressed stream containing the plurality of content elements and the position data; and
sending said compressed stream and the layout to the client device.
12. The apparatus of claim 11, wherein the interaction further comprise:
determining real content associated with the page;
removing nested tables form the page received from the corresponding server; and
accumulating text of the page into a string.
13. The apparatus of claim 11, wherein the interaction further comprise:
receiving a sign on request form the client device;
in response to receiving the sign on request, identifying a type associated with the client device; and
based at least in part on the type, accessing the device characteristics information.
14. The apparatus of claim 11, wherein the interaction further comprise:
identifying any images associated with the page; and
cropping the images based at least in part on the device characteristics information, before creating the compressed stream.
15. The apparatus of claim 11, wherein the stream includes a Document Object Model (DOM) tree.
16. One or more non-transitory computer-readable media having computer-executable instructions that, when executed by one or more processors, cause the one or more processors to perform operations comprising:
receiving a request from a client device, the request including display screen coordinates corresponding to a position on a display of the client device;
identifying a hotspot associated with the display screen coordinates;
requesting an associated page from a corresponding server associated with the hotspot;
receiving the page from the corresponding server;
creating a layout of the page by determining a plurality of content elements present in the page based at least in part on device characteristics information associated with the client device, the position of each content element within said page represented by position data comprising two-dimensional coordinates;
creating a compressed stream containing the plurality of content elements and the position data; and
sending said compressed stream and the layout to the client device.
17. The one or more non-transitory computer-readable media of claim 16, wherein the device characteristics information includes stylistic information, layout algorithms, and format encodings associated with the client device.
18. The one or more computer-readable media as recited in claim 16, having computer-executable instructions that, when executed by the one or more processors, cause the one or more processors to perform operations comprising:
parsing the HTML code of the page to create a Document Object Model (DOM) tree; and
sending the DOM tree as part of the compressed stream.
19. The one or more non-transitory computer-readable media of claim 16, wherein the client device is at least one of a cell phone or personal digital assistant (PDA) device.
20. The one or more non-transitory computer-readable media of claim 16, wherein the client device is a set top box.
21. The one or more computer-readable media as recited in claim 16, having computer-executable instructions that, when executed by the one or more processors, cause the one or more processors to perform operations comprising:
identifying any images associated with the page; and
scaling the images based at least in part on the device characteristics information, before creating the compressed stream.
US14/496,562 2001-04-09 2014-09-25 Server-based browser system Expired - Fee Related US9866612B2 (en)

Priority Applications (1)

Application Number Priority Date Filing Date Title
US14/496,562 US9866612B2 (en) 2001-04-09 2014-09-25 Server-based browser system

Applications Claiming Priority (5)

Application Number Priority Date Filing Date Title
US28219401P 2001-04-09 2001-04-09
PCT/US2002/011420 WO2002082229A2 (en) 2001-04-09 2002-04-09 Server-based browser system
US10/474,300 US7587669B2 (en) 2001-04-09 2002-04-09 Server-based browser system
US12/535,550 US8874637B2 (en) 2001-04-09 2009-08-04 Server-based browser system
US14/496,562 US9866612B2 (en) 2001-04-09 2014-09-25 Server-based browser system

Related Parent Applications (1)

Application Number Title Priority Date Filing Date
US12/535,550 Continuation US8874637B2 (en) 2001-04-09 2009-08-04 Server-based browser system

Publications (3)

Publication Number Publication Date
US20160094609A1 US20160094609A1 (en) 2016-03-31
US20180007114A9 true US20180007114A9 (en) 2018-01-04
US9866612B2 US9866612B2 (en) 2018-01-09

Family

ID=23080464

Family Applications (3)

Application Number Title Priority Date Filing Date
US10/474,300 Expired - Lifetime US7587669B2 (en) 2001-04-09 2002-04-09 Server-based browser system
US12/535,550 Expired - Lifetime US8874637B2 (en) 2001-04-09 2009-08-04 Server-based browser system
US14/496,562 Expired - Fee Related US9866612B2 (en) 2001-04-09 2014-09-25 Server-based browser system

Family Applications Before (2)

Application Number Title Priority Date Filing Date
US10/474,300 Expired - Lifetime US7587669B2 (en) 2001-04-09 2002-04-09 Server-based browser system
US12/535,550 Expired - Lifetime US8874637B2 (en) 2001-04-09 2009-08-04 Server-based browser system

Country Status (3)

Country Link
US (3) US7587669B2 (en)
AU (1) AU2002258769A1 (en)
WO (1) WO2002082229A2 (en)

Families Citing this family (109)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US7594001B1 (en) * 2001-07-06 2009-09-22 Microsoft Corporation Partial page output caching
US7299411B2 (en) * 2002-09-27 2007-11-20 Liberate Technologies Providing a presentation engine adapted for use by a constrained resource client device
EP1406183A3 (en) * 2002-10-01 2004-04-14 Sap Ag Method and system for refreshing browser pages
KR20040076649A (en) 2003-02-26 2004-09-03 삼성전자주식회사 Apparatus and method for displaying browser graphic by aspect ratio
FI118311B (en) * 2004-03-03 2007-09-28 Helmi Technologies Oy Procedure, data processing apparatus, computer software product and arrangements for processing electronic data
US8271541B2 (en) * 2004-03-31 2012-09-18 Fusionops Corporation Method and apparatus for developing composite applications
US9026578B2 (en) * 2004-05-14 2015-05-05 Microsoft Corporation Systems and methods for persisting data between web pages
US9329827B2 (en) * 2004-12-29 2016-05-03 Funmobility, Inc. Cropping of images for display on variably sized display devices
US20060218618A1 (en) * 2005-03-22 2006-09-28 Lorkovic Joseph E Dual display interactive video
US20060248463A1 (en) * 2005-04-28 2006-11-02 Damien Forkner Persistant positioning
US7814410B2 (en) * 2005-09-12 2010-10-12 Workman Nydegger Initial server-side content rendering for client-script web pages
US7535475B2 (en) * 2005-11-01 2009-05-19 Adobe Systems Incorporated Virtual view tree
US9106649B2 (en) * 2006-05-25 2015-08-11 Apptou Technologies Ltd Method and system for efficient remote application provision
US20080040661A1 (en) * 2006-07-07 2008-02-14 Bryce Allen Curtis Method for inheriting a Wiki page layout for a Wiki page
US20080010388A1 (en) * 2006-07-07 2008-01-10 Bryce Allen Curtis Method and apparatus for server wiring model
US7954052B2 (en) * 2006-07-07 2011-05-31 International Business Machines Corporation Method for processing a web page for display in a wiki environment
US20080010386A1 (en) * 2006-07-07 2008-01-10 Bryce Allen Curtis Method and apparatus for client wiring model
US8560956B2 (en) * 2006-07-07 2013-10-15 International Business Machines Corporation Processing model of an application wiki
US8219900B2 (en) 2006-07-07 2012-07-10 International Business Machines Corporation Programmatically hiding and displaying Wiki page layout sections
US20080010345A1 (en) * 2006-07-07 2008-01-10 Bryce Allen Curtis Method and apparatus for data hub objects
US8775930B2 (en) 2006-07-07 2014-07-08 International Business Machines Corporation Generic frequency weighted visualization component
US20080010338A1 (en) * 2006-07-07 2008-01-10 Bryce Allen Curtis Method and apparatus for client and server interaction
US8196039B2 (en) 2006-07-07 2012-06-05 International Business Machines Corporation Relevant term extraction and classification for Wiki content
US20080010387A1 (en) * 2006-07-07 2008-01-10 Bryce Allen Curtis Method for defining a Wiki page layout using a Wiki page
KR101451851B1 (en) * 2007-01-03 2014-10-23 삼성전자주식회사 Web server and web service method thereof
JP5551938B2 (en) * 2007-02-09 2014-07-16 ノキア コーポレイション Method and apparatus for providing information content to be displayed on a client device
US8504913B2 (en) * 2007-06-08 2013-08-06 Apple Inc. Client-side components
WO2008157322A1 (en) * 2007-06-13 2008-12-24 Quattro Wireless, Inc. Displaying content on a mobile device
US20090063530A1 (en) * 2007-09-04 2009-03-05 Lg Telecom Ltd. System and method for mobile web service
KR101424261B1 (en) * 2007-09-04 2014-07-31 주식회사 엘지유플러스 Method for prviding mobile web service and a mobile phone for excuting the method
US9122650B1 (en) * 2007-11-14 2015-09-01 Appcelerator, Inc. Web server based on the same paradigms as web clients
US8914774B1 (en) 2007-11-15 2014-12-16 Appcelerator, Inc. System and method for tagging code to determine where the code runs
US8954989B1 (en) * 2007-11-19 2015-02-10 Appcelerator, Inc. Flexible, event-driven JavaScript server architecture
US8260845B1 (en) 2007-11-21 2012-09-04 Appcelerator, Inc. System and method for auto-generating JavaScript proxies and meta-proxies
US8719451B1 (en) * 2007-11-23 2014-05-06 Appcelerator, Inc. System and method for on-the-fly, post-processing document object model manipulation
US8566807B1 (en) 2007-11-23 2013-10-22 Appcelerator, Inc. System and method for accessibility of document object model and JavaScript by other platforms
US8819539B1 (en) 2007-12-03 2014-08-26 Appcelerator, Inc. On-the-fly rewriting of uniform resource locators in a web-page
US8756579B1 (en) 2007-12-03 2014-06-17 Appcelerator, Inc. Client-side and server-side unified validation
US8806431B1 (en) 2007-12-03 2014-08-12 Appecelerator, Inc. Aspect oriented programming
US8938491B1 (en) 2007-12-04 2015-01-20 Appcelerator, Inc. System and method for secure binding of client calls and server functions
US8527860B1 (en) 2007-12-04 2013-09-03 Appcelerator, Inc. System and method for exposing the dynamic web server-side
US8639743B1 (en) 2007-12-05 2014-01-28 Appcelerator, Inc. System and method for on-the-fly rewriting of JavaScript
US8285813B1 (en) 2007-12-05 2012-10-09 Appcelerator, Inc. System and method for emulating different user agents on a server
US8335982B1 (en) 2007-12-05 2012-12-18 Appcelerator, Inc. System and method for binding a document object model through JavaScript callbacks
GB0802585D0 (en) * 2008-02-12 2008-03-19 Mtld Top Level Domain Ltd Determining a property of communication device
US8291079B1 (en) 2008-06-04 2012-10-16 Appcelerator, Inc. System and method for developing, deploying, managing and monitoring a web application in a single environment
US8880678B1 (en) 2008-06-05 2014-11-04 Appcelerator, Inc. System and method for managing and monitoring a web application using multiple cloud providers
US7596620B1 (en) 2008-11-04 2009-09-29 Aptana, Inc. System and method for developing, deploying, managing and monitoring a web application in a single environment
GB2465138B (en) 2008-10-10 2012-10-10 Afilias Technologies Ltd Transcoding web resources
US8464318B1 (en) * 2008-11-24 2013-06-11 Renen Hallak System and method for protecting web clients and web-based applications
US20100174818A1 (en) * 2009-01-07 2010-07-08 Microsoft Corporation Input Service for Client Devices
CN101515300B (en) 2009-04-02 2011-07-20 阿里巴巴集团控股有限公司 Method and system for grabbing Ajax webpage content
US8073875B2 (en) * 2009-04-22 2011-12-06 International Business Machines Corporation Managing deleted directory entries
US8285754B2 (en) * 2009-04-22 2012-10-09 International Business Machines Corporation Preserving references to deleted directory entries
US8346784B1 (en) 2012-05-29 2013-01-01 Limelight Networks, Inc. Java script reductor
US9058402B2 (en) 2012-05-29 2015-06-16 Limelight Networks, Inc. Chronological-progression access prioritization
US20110029899A1 (en) * 2009-08-03 2011-02-03 FasterWeb, Ltd. Systems and Methods for Acceleration and Optimization of Web Pages Access by Changing the Order of Resource Loading
US8495171B1 (en) 2012-05-29 2013-07-23 Limelight Networks, Inc. Indiscriminate virtual containers for prioritized content-object distribution
US9141724B2 (en) * 2010-04-19 2015-09-22 Afilias Technologies Limited Transcoder hinting
US8495485B2 (en) 2010-06-30 2013-07-23 International Business Machines Corporation System, method, and apparatus for location identification of content
GB2481843A (en) 2010-07-08 2012-01-11 Mtld Top Level Domain Ltd Web based method of generating user interfaces
CN102487402B (en) * 2010-12-03 2014-03-19 腾讯科技(深圳)有限公司 Method, device and system for realizing webpage rendering by server side
US8645491B2 (en) 2010-12-18 2014-02-04 Qualcomm Incorporated Methods and apparatus for enabling a hybrid web and native application
CN102073502B (en) * 2011-01-11 2013-02-20 百度在线网络技术(北京)有限公司 Method for rendering page frame by WEB primary layout and device thereof
US9002139B2 (en) 2011-02-16 2015-04-07 Adobe Systems Incorporated Methods and systems for automated image slicing
CN102163213B (en) * 2011-02-25 2015-06-24 中国科学院计算技术研究所 Voice browsing method and browser
CN102651002B (en) * 2011-02-28 2017-08-11 深圳市世纪光速信息技术有限公司 A kind of method for abstracting web page information and its system
KR20120099931A (en) * 2011-03-02 2012-09-12 삼성전자주식회사 Browsing method, device, and computer readable storage medium thereof
US8863248B2 (en) 2011-04-07 2014-10-14 International Business Machines Corporation Method and apparatus to auto-login to a browser application launched from an authenticated client application
US9015576B2 (en) * 2011-05-16 2015-04-21 Microsoft Technology Licensing, Llc Informed partitioning of data in a markup-based document
US8788711B2 (en) 2011-06-14 2014-07-22 Google Inc. Redacting content and inserting hypertext transfer protocol (HTTP) error codes in place thereof
US9769285B2 (en) 2011-06-14 2017-09-19 Google Inc. Access to network content
CN102323880A (en) * 2011-06-30 2012-01-18 中兴通讯股份有限公司 Mobile phone application interface development method and terminal based on browser parsing mode
US8650139B2 (en) 2011-07-01 2014-02-11 Google Inc. Predicting user navigation events
US8744988B1 (en) 2011-07-15 2014-06-03 Google Inc. Predicting user navigation events in an internet browser
US9195768B2 (en) * 2011-08-26 2015-11-24 Amazon Technologies, Inc. Remote browsing session management
US8655819B1 (en) 2011-09-15 2014-02-18 Google Inc. Predicting user navigation events based on chronological history data
US10025928B2 (en) * 2011-10-03 2018-07-17 Webroot Inc. Proactive browser content analysis
WO2013079113A1 (en) * 2011-12-01 2013-06-06 Fundacio Privada Barcelona Digital Centre Tecnologic Secure cloud browsing client-server system and method of secure remote browsing using the same
KR101597616B1 (en) * 2011-12-30 2016-02-25 인텔 코포레이션 Cognitive load assessment for digital documents
US10296558B1 (en) * 2012-02-27 2019-05-21 Amazon Technologies, Inc. Remote generation of composite content pages
KR20130106519A (en) * 2012-03-20 2013-09-30 삼성전자주식회사 Method and apparatus for managing history of web-browser
CN103365859B (en) * 2012-03-28 2017-03-08 上海商派网络科技有限公司 The method processing webpage mouse click event
CN103365901B (en) * 2012-04-01 2017-05-24 上海聚力传媒技术有限公司 Method for obtaining information on clicked webpage objects, device for obtaining information on clicked webpage objects and equipment for obtaining information on clicked webpage objects
CN102681850B (en) * 2012-05-07 2015-05-20 北京奇虎科技有限公司 Method and device for realizing web browsing based on Webkit kernel
US9946792B2 (en) 2012-05-15 2018-04-17 Google Llc Access to network content
US9705964B2 (en) * 2012-05-31 2017-07-11 Intel Corporation Rendering multiple remote graphics applications
US9075877B2 (en) 2012-06-29 2015-07-07 Citrix Systems Inc. System and method for transparent in-network adaptation of rich internet applications
US9323730B2 (en) * 2012-09-05 2016-04-26 Hbr Labs Llc Platform and method for real-time synchronized co-browsing of web pages
KR101491591B1 (en) * 2012-11-05 2015-02-09 주식회사 케이티 Virtualization server providing virtualization service of web application and method for transmitting data for providing the same
US10078626B1 (en) * 2012-11-27 2018-09-18 Amazon Technologies, Inc. Automated layout testing of content
EP2767905A1 (en) * 2013-02-15 2014-08-20 Samsung Electronics Co., Ltd Terminal apparatus, server, browser of terminal apparatus operating system and method of operating browser
US9645983B1 (en) * 2013-06-18 2017-05-09 Amazon Technologies, Inc. Modifying a document at a script processing server using a client device's state information
US9015348B2 (en) 2013-07-19 2015-04-21 Limelight Networks, Inc. Dynamically selecting between acceleration techniques based on content request attributes
US20150067475A1 (en) * 2013-08-30 2015-03-05 Wal-Mart Stores, Inc. Web Application Framework
JP2015052821A (en) * 2013-09-05 2015-03-19 株式会社東芝 Communication device and communication method
US20150193399A1 (en) * 2014-01-09 2015-07-09 Nokia Corporation Method and apparatus for determining partial updates for a document object model
KR20150099891A (en) * 2014-02-23 2015-09-02 삼성전자주식회사 Data Transition Processing Method and Electronic Device supporting the same
WO2015167511A2 (en) * 2014-04-30 2015-11-05 Empire Technology Development Llc Adjusting tap position on touch screen
US9349007B2 (en) * 2014-05-29 2016-05-24 The United States Of America As Represented By The Secretary Of The Air Force Web malware blocking through parallel resource rendering
US20160012551A1 (en) * 2014-07-10 2016-01-14 MyMojo Corporation Apparatus and Application Server for Providing a Service to a User
CN104217036B (en) * 2014-10-08 2019-01-15 广州华多网络科技有限公司 A kind of webpage content extracting method and equipment
CN105677240B (en) * 2015-12-30 2019-04-23 上海联影医疗科技有限公司 Data-erasure method and system
CN108108367B (en) * 2016-11-24 2021-10-26 腾讯科技(深圳)有限公司 Webpage display method and device
CN106777055B (en) * 2016-12-09 2021-01-01 武汉斗鱼网络科技有限公司 Method and device for realizing website interfacing rendering
US10630782B2 (en) * 2017-07-06 2020-04-21 Amzetta Technologies, Llc Light-weight web browser support for thin client solution
US20200322698A1 (en) * 2019-04-05 2020-10-08 Sony Interactive Entertainment LLC Supporting interactive video on non-browser-based devices
CN112749355B (en) * 2019-10-30 2024-03-22 腾讯科技(深圳)有限公司 Page display method, device, terminal, server and storage medium
US11816177B2 (en) * 2021-07-21 2023-11-14 Yext, Inc. Streaming static web page generation

Family Cites Families (93)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US671759A (en) * 1901-01-04 1901-04-09 Robert P Brown Paper box.
JP3019178B2 (en) * 1993-05-27 2000-03-13 インターナショナル・ビジネス・マシーンズ・コーポレイション Screen display sharing system
AU684872B2 (en) * 1994-03-10 1998-01-08 Cable And Wireless Plc Communication system
US5874960A (en) * 1995-07-05 1999-02-23 Microsoft Corporation Method and system for sharing applications between computer systems
US5845282A (en) * 1995-08-07 1998-12-01 Apple Computer, Inc. Method and apparatus for remotely accessing files from a desktop computer using a personal digital assistant
CA2162188C (en) * 1995-11-06 1999-05-25 Harold Jeffrey Gartner Location transparency of distributed objects over multiple middlewares
US5706431A (en) * 1995-12-29 1998-01-06 At&T System and method for distributively propagating revisions through a communications network
US5754173A (en) * 1996-02-28 1998-05-19 Sun Microsystems, Inc. Method and system for creating user interface independent programs with a user interface provider
US5950010A (en) * 1996-11-25 1999-09-07 J.D. Edwards World Source Co. System and method for customized application package building and installation
US6081262A (en) * 1996-12-04 2000-06-27 Quark, Inc. Method and apparatus for generating multi-media presentations
US5948066A (en) * 1997-03-13 1999-09-07 Motorola, Inc. System and method for delivery of information over narrow-band communications links
US6023714A (en) 1997-04-24 2000-02-08 Microsoft Corporation Method and system for dynamically adapting the layout of a document to an output device
US6175842B1 (en) * 1997-07-03 2001-01-16 At&T Corp. System and method for providing dynamic three-dimensional multi-user virtual spaces in synchrony with hypertext browsing
CA2210755C (en) * 1997-07-17 2003-12-23 Ibm Canada Limited - Ibm Canada Limitee Creating proxies for distribution of beans and event objects
JP3968176B2 (en) * 1997-10-06 2007-08-29 松下電器産業株式会社 Transmission document editing device, reception document processing device
US6535913B2 (en) * 1997-10-31 2003-03-18 Selectica, Inc. Method and apparatus for use of an application state storage system in interacting with on-line services
US6788315B1 (en) * 1997-11-17 2004-09-07 Fujitsu Limited Platform independent computer network manager
US5999179A (en) * 1997-11-17 1999-12-07 Fujitsu Limited Platform independent computer network management client
US6167441A (en) * 1997-11-21 2000-12-26 International Business Machines Corporation Customization of web pages based on requester type
US6012098A (en) * 1998-02-23 2000-01-04 International Business Machines Corp. Servlet pairing for isolation of the retrieval and rendering of data
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
US6397259B1 (en) * 1998-05-29 2002-05-28 Palm, Inc. Method, system and apparatus for packet minimized communications
US6253326B1 (en) * 1998-05-29 2001-06-26 Palm, Inc. Method and system for secure communications
US6154771A (en) 1998-06-01 2000-11-28 Mediastra, Inc. Real-time receipt, decompression and play of compressed streaming video/hypervideo; with thumbnail display of past scenes and with replay, hyperlinking and/or recording permissively intiated retrospectively
US6300947B1 (en) * 1998-07-06 2001-10-09 International Business Machines Corporation Display screen and window size related web page adaptation system
US6125391A (en) 1998-10-16 2000-09-26 Commerce One, Inc. Market makers using documents for commerce in trading partner networks
US6477543B1 (en) * 1998-10-23 2002-11-05 International Business Machines Corporation Method, apparatus and program storage device for a client and adaptive synchronization and transformation server
US6584499B1 (en) * 1999-07-09 2003-06-24 Lsi Logic Corporation Methods and apparatus for performing mass operations on a plurality of managed devices on a network
US6718535B1 (en) * 1999-07-30 2004-04-06 Accenture Llp System, method and article of manufacture for an activity framework design in an e-commerce based environment
US7200809B1 (en) * 1999-08-04 2007-04-03 Oracle International Corporation Multi-device support for mobile applications using XML
US6356933B2 (en) * 1999-09-07 2002-03-12 Citrix Systems, Inc. Methods and apparatus for efficiently transmitting interactive application data between a client and a server using markup language
US6430624B1 (en) * 1999-10-21 2002-08-06 Air2Web, Inc. Intelligent harvesting and navigation system and method
US6950881B1 (en) * 1999-11-02 2005-09-27 Mshift, Inc. System for converting wireless communications for a mobile device
US6829746B1 (en) * 1999-12-09 2004-12-07 International Business Machines Corp. Electronic document delivery system employing distributed document object model (DOM) based transcoding
US6549221B1 (en) * 1999-12-09 2003-04-15 International Business Machines Corp. User interface management through branch isolation
US6812941B1 (en) * 1999-12-09 2004-11-02 International Business Machines Corp. User interface management through view depth
US6920607B1 (en) * 1999-12-15 2005-07-19 Microsoft Corp. Methods and systems for dynamically creating user interfaces
US6735186B1 (en) * 1999-12-22 2004-05-11 Nokia Corporation Method and system for optimizing usage of air link
US7023572B2 (en) * 2000-02-02 2006-04-04 Raja Singh Tuli Portable high speed internet access device
US6941382B1 (en) * 2000-02-07 2005-09-06 Raja Tuli Portable high speed internet or desktop device
US7111060B2 (en) * 2000-03-14 2006-09-19 Aep Networks, Inc. Apparatus and accompanying methods for providing, through a centralized server site, a secure, cost-effective, web-enabled, integrated virtual office environment remotely accessible through a network-connected web browser
US6883137B1 (en) * 2000-04-17 2005-04-19 International Business Machines Corporation System and method for schema-driven compression of extensible mark-up language (XML) documents
US6976090B2 (en) * 2000-04-20 2005-12-13 Actona Technologies Ltd. Differentiated content and application delivery via internet
US7072984B1 (en) * 2000-04-26 2006-07-04 Novarra, Inc. System and method for accessing customized information over the internet using a browser for a plurality of electronic devices
US6581186B1 (en) * 2000-05-31 2003-06-17 Xilinx, Inc. Methods and systems for providing logic cores from third party logic core providers
US7210099B2 (en) * 2000-06-12 2007-04-24 Softview Llc Resolution independent vector display of internet content
US6728750B1 (en) * 2000-06-27 2004-04-27 International Business Machines Corporation Distributed application assembly
US20040181801A1 (en) * 2000-12-28 2004-09-16 David Hagen Interactive television for promoting goods and services
US20020016801A1 (en) * 2000-08-01 2002-02-07 Steven Reiley Adaptive profile-based mobile document integration
US7013329B1 (en) * 2000-08-04 2006-03-14 Oracle International Corporation Techniques for programming event-driven transactions in mobile applications
US6934933B2 (en) * 2000-08-14 2005-08-23 Twin Communications Of America, Inc. Portable operating environment for information devices
AU2001293269A1 (en) * 2000-09-11 2002-03-26 David Edgar System, method, and computer program product for optimization and acceleration of data transport and processing
US6717593B1 (en) 2000-09-12 2004-04-06 Avaya Technology Corp. Mark-up language implementation of graphical or non-graphical user interfaces
US20020128908A1 (en) 2000-09-15 2002-09-12 Levin Brian E. System for conducting user-specific promotional campaigns using multiple communications device platforms
GB0023570D0 (en) 2000-09-26 2000-11-08 Volantis Systems Ltd Web server
US7089330B1 (en) * 2000-09-28 2006-08-08 I2 Technologies Us, Inc. System and method for transforming custom content generation tags associated with web pages
US7574486B1 (en) * 2000-11-06 2009-08-11 Telecommunication Systems, Inc. Web page content translator
US6741853B1 (en) * 2000-11-09 2004-05-25 Nortel Networks Limited Device aware internet portal
US20020099829A1 (en) 2000-11-27 2002-07-25 Richards Kenneth W. Filter proxy system and method
US7877518B2 (en) 2000-11-30 2011-01-25 Access Systems Americas, Inc. Method and apparatus for updating applications on a mobile device via device synchronization
US6957390B2 (en) * 2000-11-30 2005-10-18 Mediacom.Net, Llc Method and apparatus for providing dynamic information to a user via a visual display
US6775671B1 (en) * 2000-12-13 2004-08-10 William Marsh Rice University Component-based adaptation system and method
US20020152244A1 (en) 2000-12-22 2002-10-17 International Business Machines Corporation Method and apparatus to dynamically create a customized user interface based on a document type definition
US7076728B2 (en) * 2000-12-22 2006-07-11 International Business Machines Corporation Method and apparatus for end-to-end content publishing system using XML with an object dependency graph
US20030189593A1 (en) 2001-01-05 2003-10-09 Yarvin Curtis G. Method and apparatus for dynamically updating a markup language based user interface
SE0100191L (en) 2001-01-24 2002-07-25 Ericsson Telefon Ab L M An apparatus and method relating to accessing applications / services
US6871236B2 (en) * 2001-01-26 2005-03-22 Microsoft Corporation Caching transformed content in a mobile gateway
US6836796B2 (en) * 2001-03-16 2004-12-28 Digi International, Inc. System and method to manage network-enabled embedded devices operating under various protocols
US7054878B2 (en) * 2001-04-02 2006-05-30 Accenture Global Services Gmbh Context-based display technique with hierarchical display format
US20020147749A1 (en) 2001-04-06 2002-10-10 Ortiz C. Enrique Mobile presentation system
US6966028B1 (en) * 2001-04-18 2005-11-15 Charles Schwab & Co., Inc. System and method for a uniform website platform that can be targeted to individual users and environments
WO2002088908A2 (en) * 2001-05-02 2002-11-07 Bitstream Inc. Methods, systems, and programming for producing and displaying subpixel-optimized font bitmaps using non-linear color balancing
US7346667B2 (en) 2001-05-31 2008-03-18 Ubs Ag System for delivering dynamic content
US6801604B2 (en) * 2001-06-25 2004-10-05 International Business Machines Corporation Universal IP-based and scalable architectures across conversational applications using web services for speech and audio processing resources
US6961912B2 (en) * 2001-07-18 2005-11-01 Xerox Corporation Feedback mechanism for use with visual selection methods
US6880014B2 (en) * 2001-09-24 2005-04-12 International Business Machines Corporation Method and system of use of transcode directives for distributed control of transcoding servers
US6807631B2 (en) * 2001-11-16 2004-10-19 National Instruments Corporation System and method for deploying a hardware configuration with a computer program
US7065744B2 (en) * 2002-01-14 2006-06-20 International Business Machines Corporation System and method for converting management models to specific console interfaces
US9374451B2 (en) * 2002-02-04 2016-06-21 Nokia Technologies Oy System and method for multimodal short-cuts to digital services
US7065707B2 (en) * 2002-06-24 2006-06-20 Microsoft Corporation Segmenting and indexing web pages using function-based object models
US20040015537A1 (en) 2002-07-15 2004-01-22 Richard Doerksen Handheld client framework system
US7570943B2 (en) * 2002-08-29 2009-08-04 Nokia Corporation System and method for providing context sensitive recommendations to digital services
US7203901B2 (en) * 2002-11-27 2007-04-10 Microsoft Corporation Small form factor web browsing
US7239877B2 (en) 2003-10-07 2007-07-03 Accenture Global Services Gmbh Mobile provisioning tool system
US7324473B2 (en) 2003-10-07 2008-01-29 Accenture Global Services Gmbh Connector gateway
US20060168526A1 (en) 2005-01-12 2006-07-27 Nokia Corporation Platform-specific application user interface remoting
US20060265359A1 (en) 2005-05-18 2006-11-23 Microsoft Corporation Flexible data-bound user interfaces
US20070226314A1 (en) * 2006-03-22 2007-09-27 Sss Research Inc. Server-based systems and methods for enabling interactive, collabortive thin- and no-client image-based applications
US20100268831A1 (en) * 2009-04-16 2010-10-21 Microsoft Corporation Thin Client Session Management
CN102907069B (en) * 2010-06-04 2015-09-23 国际商业机器公司 Perform the method and system of graphical application
JP5388246B1 (en) * 2012-08-31 2014-01-15 Necシステムテクノロジー株式会社 INPUT DISPLAY CONTROL DEVICE, THIN CLIENT SYSTEM, INPUT DISPLAY CONTROL METHOD, AND PROGRAM
JP2014135013A (en) * 2013-01-11 2014-07-24 Fujitsu Ltd Image transfer method, server apparatus, and program
US9342616B2 (en) * 2013-03-04 2016-05-17 International Business Machines Corporation User influenced asynchronous module definition loader

Also Published As

Publication number Publication date
US9866612B2 (en) 2018-01-09
US7587669B2 (en) 2009-09-08
US20090300111A1 (en) 2009-12-03
US20050027823A1 (en) 2005-02-03
AU2002258769A1 (en) 2002-10-21
WO2002082229A3 (en) 2003-04-17
WO2002082229A2 (en) 2002-10-17
US8874637B2 (en) 2014-10-28
US20160094609A1 (en) 2016-03-31

Similar Documents

Publication Publication Date Title
US9866612B2 (en) Server-based browser system
US7840647B2 (en) System, method, and computer program product for executing scripts on mobile devices
US7853593B2 (en) Content markup transformation
US7539766B1 (en) Supplying electronic content to networked appliances
US20030011631A1 (en) System and method for document division
US8984395B2 (en) Methods, systems and devices for transcoding and displaying electronic documents
CA2518654C (en) Method for requesting and viewing a zoomed area of detail from an image attachment on a mobile communication device
US20020091738A1 (en) Resolution independent vector display of internet content
US20080316225A1 (en) Method for requesting and viewing a zoomed area of detail from an image attachment on a mobile communication device
US9456048B2 (en) System, method, and computer program product for server side processing in a mobile device environment
US20060048051A1 (en) Method for rendering formatted content on a mobile device
JP4811069B2 (en) Information presentation device, information presentation method, and information presentation processing program
GB2346238A (en) Tailoring Web page content in HTML format for display, using XML tools
JP2004527041A (en) System and method for content delivery over a wireless communication medium to a portable computing device
CN110598140A (en) Page adjusting method and device and server
JP2004220260A (en) Web page browsing system and image distribution server
US20040148292A1 (en) Method of adaptive data transmission
EP1630689B1 (en) Method for rendering formatted content on a mobile device
JP2002342213A (en) Method of providing contents
US7246126B2 (en) Communications system for retrieving instruction files from a server
CA2516906C (en) Method for rendering formatted content on a mobile device
JP2008021193A (en) Information processor, method and computer program
JPWO2002044906A1 (en) Content provision method
KR20070093599A (en) Method for accessing internet webpage using snapshot navigation
Lin et al. Content transcoding middleware for pervasive geospatial intelligence access

Legal Events

Date Code Title Description
FEPP Fee payment procedure

Free format text: PETITION RELATED TO MAINTENANCE FEES GRANTED (ORIGINAL EVENT CODE: PTGR)

STCF Information on status: patent grant

Free format text: PATENTED CASE

FEPP Fee payment procedure

Free format text: MAINTENANCE FEE REMINDER MAILED (ORIGINAL EVENT CODE: REM.); ENTITY STATUS OF PATENT OWNER: LARGE ENTITY

LAPS Lapse for failure to pay maintenance fees

Free format text: PATENT EXPIRED FOR FAILURE TO PAY MAINTENANCE FEES (ORIGINAL EVENT CODE: EXP.); ENTITY STATUS OF PATENT OWNER: LARGE ENTITY

STCH Information on status: patent discontinuation

Free format text: PATENT EXPIRED DUE TO NONPAYMENT OF MAINTENANCE FEES UNDER 37 CFR 1.362

FP Lapsed due to failure to pay maintenance fee

Effective date: 20220109