US20130305139A1 - Methods for extending a document transformation server to process multiple documents from multiple sites and devices thereof29547.0164 - Google Patents
Methods for extending a document transformation server to process multiple documents from multiple sites and devices thereof29547.0164 Download PDFInfo
- Publication number
- US20130305139A1 US20130305139A1 US13/939,838 US201313939838A US2013305139A1 US 20130305139 A1 US20130305139 A1 US 20130305139A1 US 201313939838 A US201313939838 A US 201313939838A US 2013305139 A1 US2013305139 A1 US 2013305139A1
- Authority
- US
- United States
- Prior art keywords
- document
- http request
- processors
- transformation server
- http
- 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
Links
- 230000009466 transformation Effects 0.000 title claims abstract description 96
- 238000000034 method Methods 0.000 title claims abstract description 79
- 230000008569 process Effects 0.000 title claims abstract description 54
- 230000004044 response Effects 0.000 claims abstract description 16
- 238000013507 mapping Methods 0.000 claims description 18
- 230000001131 transforming effect Effects 0.000 claims description 10
- 238000004891 communication Methods 0.000 description 17
- 238000005516 engineering process Methods 0.000 description 9
- 238000012545 processing Methods 0.000 description 8
- 239000000284 extract Substances 0.000 description 5
- 238000009877 rendering Methods 0.000 description 5
- 239000012634 fragment Substances 0.000 description 3
- 230000006870 function Effects 0.000 description 3
- 230000005055 memory storage Effects 0.000 description 3
- 230000003287 optical effect Effects 0.000 description 3
- 230000004075 alteration Effects 0.000 description 2
- 230000006872 improvement Effects 0.000 description 2
- 238000012986 modification Methods 0.000 description 2
- 230000004048 modification Effects 0.000 description 2
- 230000010267 cellular communication Effects 0.000 description 1
- 238000011161 development Methods 0.000 description 1
- 238000010586 diagram Methods 0.000 description 1
- 230000007246 mechanism Effects 0.000 description 1
- 230000010076 replication Effects 0.000 description 1
- 239000000344 soap Substances 0.000 description 1
- 230000001755 vocal effect Effects 0.000 description 1
Images
Classifications
-
- G06F17/2247—
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F40/00—Handling natural language data
- G06F40/10—Text processing
- G06F40/12—Use of codes for handling textual entities
- G06F40/14—Tree-structured documents
- G06F40/143—Markup, e.g. Standard Generalized Markup Language [SGML] or Document Type Definition [DTD]
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F16/00—Information retrieval; Database structures therefor; File system structures therefor
- G06F16/90—Details of database functions independent of the retrieved data types
- G06F16/95—Retrieval from the web
- G06F16/957—Browsing optimisation, e.g. caching or content distillation
- G06F16/9577—Optimising the visualization of content, e.g. distillation of HTML documents
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F40/00—Handling natural language data
- G06F40/10—Text processing
- G06F40/12—Use of codes for handling textual entities
- G06F40/151—Transformation
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F40/00—Handling natural language data
- G06F40/10—Text processing
- G06F40/12—Use of codes for handling textual entities
- G06F40/151—Transformation
- G06F40/154—Tree transformation for tree-structured or markup documents, e.g. XSLT, XSL-FO or stylesheets
Definitions
- This technology generally relates to methods and devices for transforming and rendering documents and, more particularly, to methods for extending a document transformation server to process multiple documents from multiple sites and devices thereof.
- eXtensible Markup Language XML
- EXtensibleStylesheet Language XSL
- Each URL on a website is associated to a single XML file and to one or more XSL style sheets.
- the associated XML file and XSL style sheet(s) include the transformation rules used to customize the webpage into a desired format.
- a server receives an HTTP request.
- the server extracts the parts from the PATH and QUERY fields in the HTTP request to identify and obtain the document to be processed.
- step 104 the server determines whether the extracted parts in the PATH and QUERY fields of the HTTP request match an XML source for the document to be processed. If in step 104 the server determines the extracted parts in the PATH and QUERY fields of the HTTP request do not have an association with an XML source, then the No branch is taken to step 106 . In step 106 , the server generates an error page document. In step 108 the server returns the generated error page document in an HTTP response to the HTTP request.
- step 104 the server determines the extracted parts in the PATH and QUERY fields of the HTTP request do have an association with an XML source for the document to be processed, then the Yes branch is taken to step 110 .
- step 110 the server obtains the document to be processed from the XML source and generates an XML document.
- step 112 the server determines whether the extracted parts in the PATH and QUERY fields of the HTTP request match one of one or more stored XML processors. If in step 112 the server determines the extracted parts in the PATH and QUERY fields of the HTTP request do not match one of one or more stored XML processors, then the No branch is taken to step 114 . In step 114 , the server converts the XML document into a desired format. Next, in step 108 the returns the converted XML document in an HTTP response to the HTTP request.
- step 112 the server determines the extracted parts in the PATH and QUERY fields of the HTTP request do match one or more stored of the XML processors, then the Yes branch is taken to step 116 .
- step 116 the server runs the one or more matching XML processors on the previously generated XML document.
- step 114 the server converts the processed XML document into a desired format.
- step 108 the server returns the converted XML document in an HTTP response to the HTTP request.
- FIG. 3 an exemplary prior art fragment of a sitemap.xmap document which is a configuration file of Apache Cocoon is illustrated. This fragment has two sets of prior art instructions to process documents.
- the document is obtained by loading the XML file “welcome.xml” as the document or other file to be processed, then applying the XSL transformation described in welcome.xsl using XHTML format to return it to the browser because of the ⁇ map:serialize> instruction.
- the second set of instructions matches an entire set of web site pages: all pages whose PATH field starts with “static-site!” and ends with a name followed by “.xml” extension (for example, www.sample.com/static-site/news.xml).
- the first instruction loads the corresponding documents or other files from the xdocs directory (for example xdocs/news.xml).
- the second instruction applies an XSL transformation using one or more identified matching XML processors that transforms the original xml document into an HTML document adding web site user interface (web site navigation links, site logo etc).
- the last instruction returns the document to the browser in HTML format.
- the prior art provides methods for transforming and rendering documents.
- these transformation rules currently can not be utilized in an effective and efficient manner by a document transformation server in a single application instance to transform multiple documents from multiple websites.
- a method for extending a document transformation server to process multiple documents from multiple websites includes obtaining with a document transformation server a document to process based on at least a URL of the document to process in an HTTP request URL.
- An XML source representing the document to process is generated with the document transformation server.
- One or more XML processors associated with at least a portion of the HTTP request URL from a plurality of stored associations are identified with the document transformation server.
- the XML source is transformed by the document transformation server with each of the identified one identified XML processors.
- the generated document is provided in an HTTP response to the HTTP request URL by the document transformation server.
- a non-transitory computer readable medium having stored thereon instructions for extending a document transformation server to process multiple documents from multiple websites comprising machine executable code which when executed by at least one processor, causes the processor to perform steps including obtaining a document to process based on at least a URL of the document to process in an HTTP request URL.
- An XML source representing the obtained document to process is generated and one or more XML processors that are associated with at least a portion of the HTTP request URL from a plurality of stored associations are identified.
- the XML source is transformed with each of the identified one identified XML processors and the generated document is provided in an HTTP response to the HTTP request URL.
- a document transformation apparatus includes one or more processors and a memory coupled to the one or more processors which are configured to execute programmed instructions stored in the memory obtaining a document to process based on at least a URL of the document to process in an HTTP request URL.
- An XML source representing the obtained document to process is generated and one or more XML processors that are associated with at least a portion of the HTTP request URL from a plurality of stored associations are identified.
- the XML source is transformed with each of the identified one identified XML processors and the generated document is provided in an HTTP response to the HTTP request URL.
- This technology provides a number of advantages including providing a method, computer readable medium and an apparatus that extends a document transformation server to process multiple documents from multiple sites.
- an exemplary document transformation server can efficiently manage the transformation and rendering of documents using a single web application instance.
- FIG. 1 is a block diagram of an exemplary environment with an exemplary document transformation server configured to process multiple documents from multiple sites;
- FIG. 2 is a flow chart of a prior art method for transforming and rendering a document
- FIG. 3 is a prior art fragment of a configuration file
- FIG. 4 is an exemplary flow chart of a method for extending a document transformation server to process multiple documents from multiple sites;
- FIG. 5 is an exemplary flow chart of a method for obtaining a mapping file
- FIG. 6 is an exemplary implementation of a mapping file.
- FIG. 1 An exemplary environment 10 with a document transformation server 12 configured to process multiple documents from multiple websites is illustrated in FIG. 1 .
- the exemplary environment 10 includes the document transformation server or apparatus 12 , client devices 14 ( 1 )- 14 ( n ), web server devices 16 ( 1 )- 16 ( n ), and communication networks 18 ( 1 )- 18 ( 2 ), although other numbers and types of systems, devices, and/or elements in other configurations and environments with other communication network topologies can be used.
- This technology provides a number of advantages including providing a method, computer readable medium and an apparatus that extends a document transformation server to process multiple documents from multiple sites.
- the document transformation server 12 includes a central processing unit (CPU) or processor 13 , a memory 15 , and an interface system 17 which are coupled together by a bus 19 or other link, although other numbers and types of components, parts, devices, systems, and elements in other configurations and locations can be used. Additionally, other types and numbers of proxy servers or other computing devices could be configured to execute the exemplary methods illustrated and described herein.
- the processor 13 in the document transformation server 12 executes a program of stored instructions one or more aspects of the present invention as described and illustrated by way of the embodiments herein, although the processor could execute other numbers and types of programmed instructions.
- the memory 15 in the document transformation server 12 stores these programmed instructions for one or more aspects of the present invention as described and illustrated herein, although some or all of the programmed instructions could be stored and/or executed elsewhere.
- a variety of different types of memory storage devices such as a random access memory (RAM) or a read only memory (ROM) in the system or a floppy disk, hard disk, CD ROM, DVD ROM, or other computer readable medium which is read from and/or written to by a magnetic, optical, or other reading and/or writing system that is coupled to the processor 13 , can be used for the memory 15 in the document transformation server 12 .
- the interface system 17 in the document transformation server 12 is used to operatively couple and communicate between the document transformation server 12 and the client devices 14 ( 1 )- 14 ( n ) and the web server devices 16 ( 1 )- 16 ( n ) via the communication networks 18 ( 1 ) and 18 ( 2 ), although other types and numbers of communication networks with other types and numbers of connections and configurations can be used.
- the communication networks 18 ( 1 ) and 18 ( 2 ) can use TCP/IP over Ethernet and industry-standard protocols, including HTTP, HTTPS, WAP, and SOAP, although other types and numbers of communication networks, such as a direct connection, a local area network, a wide area network, modems and phone lines, e-mail, and wireless and hardwire communication technology, each having their own communications protocols, can be used.
- Each of the client devices 14 ( 1 )- 14 ( n ) enables a user to request, get and interact with documents and other files from one or more web sites hosted by the web server devices 16 ( 1 )- 16 ( n ) through the document transformation server 12 via one or more communication networks, although one or more of the client devices 14 ( 1 )- 14 ( n ) could access content and utilize other types and numbers of applications from other sources and could provide a wide variety of other functions for the user. Although multiple client devices 14 ( 1 )- 14 ( n ) are shown, other numbers and types of user computing systems could be used.
- Each of client devices 14 ( 1 )- 14 ( n ) in this example is a computing device that includes a central processing unit (CPU) or processor 20 , a memory 22 , user input device 24 , a display 26 , and an interface system 28 , and which are coupled together by a bus 30 or other link, although one or more of client devices 14 ( 1 )- 14 ( n ) can include other numbers and types of components, parts, devices, systems, and elements in other configurations.
- the processor 20 in each of client devices 14 ( 1 )- 14 ( n ) executes a program of stored instructions for one or more aspects of the present invention as described and illustrated herein, although the processor could execute other numbers and types of programmed instructions.
- the memory 22 in each of the client devices 14 ( 1 )- 14 ( n ) stores these programmed instructions for one or more aspects of the present invention as described and illustrated herein, although some or all of the programmed instructions could be stored and/or executed elsewhere.
- a variety of different types of memory storage devices such as a random access memory (RAM) or a read only memory (ROM) in the system or a floppy disk, hard disk, CD ROM, or other computer readable medium which is read from and/or written to by a magnetic, optical, or other reading and/or writing system that is coupled to processor 20 can be used for the memory 22 in each of the client devices 14 ( 1 )- 14 ( n.
- the user input device 24 in each of the client devices 14 ( 1 )- 14 ( n ) is used to input selections and other data, although the user input device could provide other functions and interact with other elements.
- the user input device can include keypads, touch screens, and/or vocal input processing systems although other types and numbers of user input devices can be used.
- the display 26 in each of the client devices 14 ( 1 )- 14 ( n ) is used to show data and information to the user, such as a website page by way of example only.
- the display in each of the client devices 14 ( 1 )- 14 ( n ) is a computer screen display, although other types and numbers of displays could be used depending on the particular type of client device.
- the interface system 28 in each of the client devices 14 ( 1 )- 14 ( n ) is used to operatively couple and communicate between the client devices 14 ( 1 )- 14 ( n ) and the document transformation server 12 and web server devices 16 ( 1 )- 16 ( n ) over the communication networks 18 ( 1 ) and 18 ( 2 ), although other types and numbers of communication networks with other types and numbers of connections and configurations can be used.
- the web server devices 16 ( 1 )- 16 ( n ) provide one or more pages from one or more web sites for use by one or more of the client devices 14 ( 1 )- 14 ( n ) via the document transformation server 12 , although the web server devices 16 ( 1 )- 16 ( n ) can provide other numbers and types of applications and/or content and can have provide other numbers and types of functions. Although web server devices 16 ( 1 )- 16 ( n ) are shown for ease of illustration and discussion, other numbers and types of web server systems and devices can be used.
- Each of the web server devices 16 ( 1 )- 16 ( n ) include a central processing unit (CPU) or processor, a memory, and an interface system which are coupled together by a bus or other link, although each of the web server devices 16 ( 1 )- 16 ( n ) could have other numbers and types of components, parts, devices, systems, and elements in other configurations and locations can be used.
- the processor in each of the web server devices 16 ( 1 )- 16 ( n ) executes a program of stored instructions one or more aspects of the present invention as described and illustrated by way of the embodiments herein, although the processor could execute other numbers and types of programmed instructions.
- each of the web server devices 16 ( 1 )- 16 ( n ) stores these programmed instructions for one or more aspects of the present invention as described and illustrated by way of the embodiments, although some or all of the programmed instructions could be stored and/or executed elsewhere.
- a variety of different types of memory storage devices such as a random access memory (RAM) or a read only memory (ROM) in the system or a floppy disk, hard disk, CD ROM, DVD ROM, or other computer readable medium which is read from and/or written to by a magnetic, optical, or other reading and/or writing system that is coupled to the processor, can be used for the memory in each of the web server devices 16 ( 1 )- 16 ( n ).
- the interface system in each of the web server devices 16 ( 1 )- 16 ( n ) is used to operatively couple and communicate between the web server devices 16 ( 1 )- 16 ( n ) and the document transformation server 12 and the client devices 14 ( 1 )- 14 ( n ) via communication networks 18 ( 1 ) and 18 ( 2 ), although other types and numbers of communication networks with other types and numbers of connections and configurations can be used.
- each of the client devices 14 ( 1 )- 14 ( n ), the document transformation server 12 , and the web server devices 16 ( 1 )- 16 ( n ), can be implemented on any suitable computer system or computing device. It is to be understood that the devices and systems of the embodiments described herein are for exemplary purposes, as many variations of the specific hardware and software used to implement the embodiments are possible, as will be appreciated by those skilled in the relevant art(s).
- each of the systems of the embodiments may be conveniently implemented using one or more general purpose computer systems, microprocessors, digital signal processors, and micro-controllers, programmed according to the teachings of the embodiments, as described and illustrated herein, and as will be appreciated by those ordinary skill in the art.
- two or more computing systems or devices can be substituted for any one of the systems in any embodiment of the embodiments. Accordingly, principles and advantages of distributed processing, such as redundancy and replication also can be implemented, as desired, to increase the robustness and performance of the devices and systems of the embodiments.
- the embodiments may also be implemented on computer system or systems that extend across any suitable network using any suitable interface mechanisms and communications technologies, including by way of example only telecommunications in any suitable form (e.g., voice and modem), wireless communications media, wireless communications networks, cellular communications networks, G3 communications networks, Public Switched Telephone Network (PSTNs), Packet Data Networks (PDNs), the Internet, intranets, and combinations thereof.
- PSTNs Public Switched Telephone Network
- PDNs Packet Data Networks
- the Internet intranets, and combinations thereof.
- the embodiments may also be embodied as non-transitory computer readable medium having instructions stored thereon for one or more aspects of the present invention as described and illustrated by way of the embodiments herein, as described herein, which when executed by a processor, cause the processor to carry out the steps necessary to implement the methods of the embodiments, as described and illustrated herein.
- step 200 the document transformation server 12 receives an HTTP request whose url contains the URI of the document to process, from one of the client computing devices 14 ( 1 )- 14 ( n ), although other types of requests could be received and from other types of devices.
- the document transformation server 12 will decode the URI of the document to process, although other manners for processing an encoded URI or other encoded portion of a URI HTTP request could be used. Since manners for encoding and decoding are well known to those of ordinary skill in the art, they will not be described in detail here.
- HTTP request from one of the client computing devices 14 ( 1 )- 14 ( n ) where the URL to be processed is embedded in the PATH field of the HTTP request url: http://processor.com/app/www.acme.com/anyproduct.html.
- the transformer server applications is identified by “processor.com/app”; the address www.acme.com/anyproduct.html is the resource to be processed.
- step 202 the document transformation server 12 extracts the domain in the URI of the document to process, although other fields of the URI could be extracted and used.
- step 204 the document transformation server 12 determines whether the transformation of the website in the URI of the document to process is allowed. If in step 204 , the document transformation server 12 determines the transformation of the website in the URI of the document to process is not allowed, then the No branch is taken to step 206 . In step 206 , the document transformation server 12 generates an error page document. In step 208 the document transformation server 12 returns the generated error page document in an HTTP response to the one of the client computing devices 14 ( 1 )- 14 ( n ) that provided the HTTP request in this example.
- step 204 the document transformation server 12 determines the transformation of the website in the URI of the document to process is allowed, then the Yes branch is taken to step 210 .
- step 210 the document transformation server 12 downloads the original document or other resource linked by the given URL and transforms the downloaded document into an XML source, although other manners for processing the obtained document or documents can be used.
- step 212 document transformation server 12 looks for a mapping or configuration file for the directory that matches the extracted domain. An exemplary method for locating a mapping file from manifest.xml is described herein with reference to FIG. 5 .
- step 214 the document transformation server 12 determines whether the mapping file for the extracted domain exists. If in step 214 the document transformation server 12 determines the mapping file does not exist, then the No branch is taken to step 216 . In step 216 , the document transformation server 12 converts the document into the desired format. Next, in step 208 the document transformation server 12 returns the converted document in an HTTP response to the one of the client computing devices 14 ( 1 )- 14 ( n ) that provided the HTTP request.
- step 214 the document transformation server 12 determines the mapping file for the extracted domain does exist, then the Yes branch is taken to step 218 .
- step 218 the document transformation server 12 use the mapping file to identify all of the XSL processors linked to the corresponding URL and applies the identified XSL processors to the document to be processed.
- the document transformation server 12 may apply one or more best matching rules to filter the identified one or more XML processors in the matching directory.
- one best matching rule is to take the XML processor with the longest matching pattern string, although other types and numbers of best matching rules can be used.
- step 216 the document transformation server 12 converts the processed document into the desired format.
- step 208 the document transformation server returns the converted document in an HTTP response to the one of the client computing devices 14 ( 1 )- 14 ( n ) that provided the HTTP request.
- step 300 the document transformation server 12 receives a URI to match from one of the client computing devices 14 ( 1 )- 14 ( n ), although other types of requests could be received and from other types of devices.
- step 302 the document transformation server 12 extracts from the URI the
- AUTHORITY portion corresponding to the associated domain and port for example “ssl.example.com:8443”, although other types and numbers of fields could be extracted.
- the string representing the authority corresponds to the domain portion of the URL.
- the ‘:’ character is substituted with ‘_’ in order to avoid potential problems in the file system (i.e. ssl.example.com — 8443).
- the string representing the authority is further stripped by the document transformation server 12 removing the ‘www.’ from the extracted string.
- the document transformation server 12 determines whether there is a directory with the same name as the extracted domain and containing the mapping file, although other manners for determining matches with other portions of the domain can be used.
- directories (1) “www.acme.com”; (2) “_.example.com”; and (3) “ssl.example.com”.
- the www.acme.com directory will match all the requests for www.acme.com and acme.com domains.
- the “_.example.com” directory will match all the requests for domains ending with “.example.com” that do not have more specific matching directories.
- “_.example.com” will match “products.example.com”, but it will not match “ssl.example.com” because an “ssl.example.com” directory exists.
- the “_” character in front of “.example.com” is used to make the directory visible when using file systems that use “.” characters in front of files to hide them to users.
- step 304 the document transformation server 12 determines there is no directory with the same name as the extracted domain, then the No branch is taken to step 306 .
- step 306 the document transformation server 12 determines whether the domain contains a valid subdomain. If in step 306 the document transformation server 12 determines the domain does contain a valid subdomain, then the Yes branch is taken to step 308 . In step 308 , the document transformation server 12 extracts the next level subdomain name and returns to step 304 as described earlier.
- step 304 the document transformation server 12 determines there is a directory with the same name as the extracted domain and containing the mapping file, then the Yes branch is taken to step 310 , although other manners for determining matches with other portions of the domain can be used.
- the document transformation server 12 may also use another optional mapping file that stores known aliases of domains. When a known alias of a domain is identified using this optional mapping file, the document transformation server 12 can use the same one or more stored directories for the known and identified aliases. As a result, this reduces the number of stored directories when handling domains with multiple aliases (i.e. defined with DNS records of type CNAME).
- step 310 the document transformation server 12 extracts the parts from the PATH and QUERY fields in the URI, although the parts can be extracted from other types and numbers of fields in the URI.
- step 312 the document transformation server 12 determines whether the extracted parts in the PATH and QUERY fields of the URI match or otherwise have an association with one of one or more XML processors in the identified mapping file, although other types of associations between other types and numbers of parts can be used. If in step 312 the document transformation server 12 determines the extracted parts in the PATH and QUERY fields of the URI match or otherwise have an association with one of one or more XML processors, then the Yes branch is taken to step 314 where the matching XML processors are collected. Next, in step 316 , the document transformation server 12 returns the collected XML processors to the requesting one of the client computing devices 14 ( 1 )- 14 ( n ).
- step 312 If in step 312 the document transformation server 12 determines the extracted parts in the PATH and QUERY fields of the URI do not match one of one or more XML processors, then the No branch is taken to step 316 where no matching XML processors are returned to the requesting one of the client computing devices 14 ( 1 )- 14 ( n ).
- mapping file “manifest.xml” an exemplary implementation of the mapping file “manifest.xml” is illustrated.
- Each map element identifies an XSL file (inside file element) and a substring to match a URL PATH component (inside the PATH element).
- the map element with the longest string matching the PATH component will be used to setup the XSL transformer identified by the level attribute.
- level 1 transformer two XSL transformers are defined: level 1 transformer; and level 2 transformer. If the request URL has the PATH field containing “/content/news/july.html”, then the original site web page is downloaded (for example, www.sample.com/content/news/july.html). Next, the level 1 transformer uses the news.xsl stylesheet document to transform the downloaded page. The level 2 transformer uses content2.xs1 stylesheet document to transform the document obtained from the level 1 transformer.
- the level 1 transformer uses the content.xsl stylesheet document to transform the downloaded page.
- the level 2 transformer uses the content2.xs1 stylesheet document to transform the document obtained from the level 1 transformer.
- this technology provides a number of advantages including providing a method, computer readable medium and an apparatus that extends a document transformation server to process multiple documents from multiple sites.
- One of the advantages of this technology is that a single association or match between a name of a directory and at least a portion of a domain name or other part of a URI can be used for hundreds or thousands of URIs. As a result, only a few associations with directories or other stored tables can be enough for the document transformation server to transform the content of an entire website.
Landscapes
- Engineering & Computer Science (AREA)
- Theoretical Computer Science (AREA)
- Physics & Mathematics (AREA)
- General Engineering & Computer Science (AREA)
- General Physics & Mathematics (AREA)
- Health & Medical Sciences (AREA)
- Artificial Intelligence (AREA)
- Audiology, Speech & Language Pathology (AREA)
- Computational Linguistics (AREA)
- General Health & Medical Sciences (AREA)
- Databases & Information Systems (AREA)
- Data Mining & Analysis (AREA)
- Information Transfer Between Computers (AREA)
- Document Processing Apparatus (AREA)
Abstract
A method, computer readable medium and device that extends a document transformation server to process multiple documents from multiple websites includes obtaining with a document transformation server a document to process based on at least a URL of the document to process in an HTTP request URL. An XML source representing the document to process is generated with the document transformation server. One or more XML processors associated with at least a portion of the HTTP request URL from a plurality of stored associations are identified with the document transformation server. The XML source is transformed by the document transformation server with each of the identified one identified XML processors. The generated document is provided in an HTTP response to the
Description
- This application is a continuation of U.S. patent application Ser. No. 12/807,766, filed Sep. 14, 2010, which is hereby incorporated by reference in its entirety.
- This technology generally relates to methods and devices for transforming and rendering documents and, more particularly, to methods for extending a document transformation server to process multiple documents from multiple sites and devices thereof.
- The introduction of eXtensible Markup Language (XML) and the EXtensibleStylesheet Language (XSL) specifications has provided an easy way to transform documents between various formats. This functionality has been included into Web development frameworks enabling them to automatically transform an XML file into a document with different format, such as HTML or XHTML, and integrate the original data with a graphic layout and user interface parts.
- This transformation process is based on the following basic scheme. Each URL on a website is associated to a single XML file and to one or more XSL style sheets. The associated XML file and XSL style sheet(s) include the transformation rules used to customize the webpage into a desired format.
- An example of a prior art method for transforming and rendering a single document is illustrated in
FIG. 2 . Instep 100, a server receives an HTTP request. Instep 102, the server extracts the parts from the PATH and QUERY fields in the HTTP request to identify and obtain the document to be processed. - In
step 104, the server determines whether the extracted parts in the PATH and QUERY fields of the HTTP request match an XML source for the document to be processed. If instep 104 the server determines the extracted parts in the PATH and QUERY fields of the HTTP request do not have an association with an XML source, then the No branch is taken tostep 106. Instep 106, the server generates an error page document. Instep 108 the server returns the generated error page document in an HTTP response to the HTTP request. - If in
step 104 the server determines the extracted parts in the PATH and QUERY fields of the HTTP request do have an association with an XML source for the document to be processed, then the Yes branch is taken tostep 110. Instep 110, the server obtains the document to be processed from the XML source and generates an XML document. - In step 112, the server determines whether the extracted parts in the PATH and QUERY fields of the HTTP request match one of one or more stored XML processors. If in step 112 the server determines the extracted parts in the PATH and QUERY fields of the HTTP request do not match one of one or more stored XML processors, then the No branch is taken to
step 114. Instep 114, the server converts the XML document into a desired format. Next, instep 108 the returns the converted XML document in an HTTP response to the HTTP request. - If in step 112 the server determines the extracted parts in the PATH and QUERY fields of the HTTP request do match one or more stored of the XML processors, then the Yes branch is taken to
step 116. Instep 116, the server runs the one or more matching XML processors on the previously generated XML document. Instep 114, the server converts the processed XML document into a desired format. Next, instep 108 the server returns the converted XML document in an HTTP response to the HTTP request. - Referring to
FIG. 3 , an exemplary prior art fragment of a sitemap.xmap document which is a configuration file of Apache Cocoon is illustrated. This fragment has two sets of prior art instructions to process documents. - The first set of instructions executed starts with XML element <map:match pattern=″″> and matches the document with an empty component in the PATH field that is the home page of a site (for example www.sample.com). The document is obtained by loading the XML file “welcome.xml” as the document or other file to be processed, then applying the XSL transformation described in welcome.xsl using XHTML format to return it to the browser because of the <map:serialize> instruction.
- The second set of instructions matches an entire set of web site pages: all pages whose PATH field starts with “static-site!” and ends with a name followed by “.xml” extension (for example, www.sample.com/static-site/news.xml). The first instruction loads the corresponding documents or other files from the xdocs directory (for example xdocs/news.xml). The second instruction applies an XSL transformation using one or more identified matching XML processors that transforms the original xml document into an HTML document adding web site user interface (web site navigation links, site logo etc). The last instruction returns the document to the browser in HTML format.
- Accordingly, as illustrated and described above, the prior art provides methods for transforming and rendering documents. Unfortunately, these transformation rules currently can not be utilized in an effective and efficient manner by a document transformation server in a single application instance to transform multiple documents from multiple websites.
- A method for extending a document transformation server to process multiple documents from multiple websites includes obtaining with a document transformation server a document to process based on at least a URL of the document to process in an HTTP request URL. An XML source representing the document to process is generated with the document transformation server. One or more XML processors associated with at least a portion of the HTTP request URL from a plurality of stored associations are identified with the document transformation server. The XML source is transformed by the document transformation server with each of the identified one identified XML processors. The generated document is provided in an HTTP response to the HTTP request URL by the document transformation server.
- A non-transitory computer readable medium having stored thereon instructions for extending a document transformation server to process multiple documents from multiple websites comprising machine executable code which when executed by at least one processor, causes the processor to perform steps including obtaining a document to process based on at least a URL of the document to process in an HTTP request URL. An XML source representing the obtained document to process is generated and one or more XML processors that are associated with at least a portion of the HTTP request URL from a plurality of stored associations are identified. The XML source is transformed with each of the identified one identified XML processors and the generated document is provided in an HTTP response to the HTTP request URL.
- A document transformation apparatus includes one or more processors and a memory coupled to the one or more processors which are configured to execute programmed instructions stored in the memory obtaining a document to process based on at least a URL of the document to process in an HTTP request URL. An XML source representing the obtained document to process is generated and one or more XML processors that are associated with at least a portion of the HTTP request URL from a plurality of stored associations are identified. The XML source is transformed with each of the identified one identified XML processors and the generated document is provided in an HTTP response to the HTTP request URL.
- This technology provides a number of advantages including providing a method, computer readable medium and an apparatus that extends a document transformation server to process multiple documents from multiple sites. With this technology, an exemplary document transformation server can efficiently manage the transformation and rendering of documents using a single web application instance.
-
FIG. 1 is a block diagram of an exemplary environment with an exemplary document transformation server configured to process multiple documents from multiple sites; -
FIG. 2 is a flow chart of a prior art method for transforming and rendering a document; -
FIG. 3 is a prior art fragment of a configuration file; -
FIG. 4 is an exemplary flow chart of a method for extending a document transformation server to process multiple documents from multiple sites; -
FIG. 5 is an exemplary flow chart of a method for obtaining a mapping file; and -
FIG. 6 is an exemplary implementation of a mapping file. - An
exemplary environment 10 with adocument transformation server 12 configured to process multiple documents from multiple websites is illustrated inFIG. 1 . - The
exemplary environment 10 includes the document transformation server orapparatus 12, client devices 14(1)-14(n), web server devices 16(1)-16(n), and communication networks 18(1)-18(2), although other numbers and types of systems, devices, and/or elements in other configurations and environments with other communication network topologies can be used. This technology provides a number of advantages including providing a method, computer readable medium and an apparatus that extends a document transformation server to process multiple documents from multiple sites. - Referring more specifically to
FIG. 1 , thedocument transformation server 12 includes a central processing unit (CPU) orprocessor 13, amemory 15, and aninterface system 17 which are coupled together by abus 19 or other link, although other numbers and types of components, parts, devices, systems, and elements in other configurations and locations can be used. Additionally, other types and numbers of proxy servers or other computing devices could be configured to execute the exemplary methods illustrated and described herein. Theprocessor 13 in thedocument transformation server 12 executes a program of stored instructions one or more aspects of the present invention as described and illustrated by way of the embodiments herein, although the processor could execute other numbers and types of programmed instructions. - The
memory 15 in thedocument transformation server 12 stores these programmed instructions for one or more aspects of the present invention as described and illustrated herein, although some or all of the programmed instructions could be stored and/or executed elsewhere. A variety of different types of memory storage devices, such as a random access memory (RAM) or a read only memory (ROM) in the system or a floppy disk, hard disk, CD ROM, DVD ROM, or other computer readable medium which is read from and/or written to by a magnetic, optical, or other reading and/or writing system that is coupled to theprocessor 13, can be used for thememory 15 in thedocument transformation server 12. - The
interface system 17 in thedocument transformation server 12 is used to operatively couple and communicate between thedocument transformation server 12 and the client devices 14(1)-14(n) and the web server devices 16(1)-16(n) via the communication networks 18(1) and 18(2), although other types and numbers of communication networks with other types and numbers of connections and configurations can be used. By way of example only, the communication networks 18(1) and 18(2) can use TCP/IP over Ethernet and industry-standard protocols, including HTTP, HTTPS, WAP, and SOAP, although other types and numbers of communication networks, such as a direct connection, a local area network, a wide area network, modems and phone lines, e-mail, and wireless and hardwire communication technology, each having their own communications protocols, can be used. - Each of the client devices 14(1)-14(n) enables a user to request, get and interact with documents and other files from one or more web sites hosted by the web server devices 16(1)-16(n) through the
document transformation server 12 via one or more communication networks, although one or more of the client devices 14(1)-14(n) could access content and utilize other types and numbers of applications from other sources and could provide a wide variety of other functions for the user. Although multiple client devices 14(1)-14(n) are shown, other numbers and types of user computing systems could be used. - Each of client devices 14(1)-14(n) in this example is a computing device that includes a central processing unit (CPU) or
processor 20, amemory 22,user input device 24, adisplay 26, and aninterface system 28, and which are coupled together by abus 30 or other link, although one or more of client devices 14(1)-14(n) can include other numbers and types of components, parts, devices, systems, and elements in other configurations. Theprocessor 20 in each of client devices 14(1)-14(n) executes a program of stored instructions for one or more aspects of the present invention as described and illustrated herein, although the processor could execute other numbers and types of programmed instructions. - The
memory 22 in each of the client devices 14(1)-14(n) stores these programmed instructions for one or more aspects of the present invention as described and illustrated herein, although some or all of the programmed instructions could be stored and/or executed elsewhere. A variety of different types of memory storage devices, such as a random access memory (RAM) or a read only memory (ROM) in the system or a floppy disk, hard disk, CD ROM, or other computer readable medium which is read from and/or written to by a magnetic, optical, or other reading and/or writing system that is coupled toprocessor 20 can be used for thememory 22 in each of the client devices 14(1)-14(n. - The
user input device 24 in each of the client devices 14(1)-14(n) is used to input selections and other data, although the user input device could provide other functions and interact with other elements. The user input device can include keypads, touch screens, and/or vocal input processing systems although other types and numbers of user input devices can be used. - The
display 26 in each of the client devices 14(1)-14(n) is used to show data and information to the user, such as a website page by way of example only. The display in each of the client devices 14(1)-14(n) is a computer screen display, although other types and numbers of displays could be used depending on the particular type of client device. - The
interface system 28 in each of the client devices 14(1)-14(n) is used to operatively couple and communicate between the client devices 14(1)-14(n) and thedocument transformation server 12 and web server devices 16(1)-16(n) over the communication networks 18(1) and 18(2), although other types and numbers of communication networks with other types and numbers of connections and configurations can be used. - The web server devices 16(1)-16(n) provide one or more pages from one or more web sites for use by one or more of the client devices 14(1)-14(n) via the
document transformation server 12, although the web server devices 16(1)-16(n) can provide other numbers and types of applications and/or content and can have provide other numbers and types of functions. Although web server devices 16(1)-16(n) are shown for ease of illustration and discussion, other numbers and types of web server systems and devices can be used. - Each of the web server devices 16(1)-16(n) include a central processing unit (CPU) or processor, a memory, and an interface system which are coupled together by a bus or other link, although each of the web server devices 16(1)-16(n) could have other numbers and types of components, parts, devices, systems, and elements in other configurations and locations can be used. The processor in each of the web server devices 16(1)-16(n) executes a program of stored instructions one or more aspects of the present invention as described and illustrated by way of the embodiments herein, although the processor could execute other numbers and types of programmed instructions.
- The memory in each of the web server devices 16(1)-16(n) stores these programmed instructions for one or more aspects of the present invention as described and illustrated by way of the embodiments, although some or all of the programmed instructions could be stored and/or executed elsewhere. A variety of different types of memory storage devices, such as a random access memory (RAM) or a read only memory (ROM) in the system or a floppy disk, hard disk, CD ROM, DVD ROM, or other computer readable medium which is read from and/or written to by a magnetic, optical, or other reading and/or writing system that is coupled to the processor, can be used for the memory in each of the web server devices 16(1)-16(n).
- The interface system in each of the web server devices 16(1)-16(n) is used to operatively couple and communicate between the web server devices 16(1)-16(n) and the
document transformation server 12 and the client devices 14(1)-14(n) via communication networks 18(1) and 18(2), although other types and numbers of communication networks with other types and numbers of connections and configurations can be used. - Although embodiments of the
document transformation server 12, the client devices 14(1)-14(n), and the web server devices 16(1)-16(n), are described and illustrated herein, each of the client devices 14(1)-14(n), thedocument transformation server 12, and the web server devices 16(1)-16(n), can be implemented on any suitable computer system or computing device. It is to be understood that the devices and systems of the embodiments described herein are for exemplary purposes, as many variations of the specific hardware and software used to implement the embodiments are possible, as will be appreciated by those skilled in the relevant art(s). - Furthermore, each of the systems of the embodiments may be conveniently implemented using one or more general purpose computer systems, microprocessors, digital signal processors, and micro-controllers, programmed according to the teachings of the embodiments, as described and illustrated herein, and as will be appreciated by those ordinary skill in the art.
- In addition, two or more computing systems or devices can be substituted for any one of the systems in any embodiment of the embodiments. Accordingly, principles and advantages of distributed processing, such as redundancy and replication also can be implemented, as desired, to increase the robustness and performance of the devices and systems of the embodiments. The embodiments may also be implemented on computer system or systems that extend across any suitable network using any suitable interface mechanisms and communications technologies, including by way of example only telecommunications in any suitable form (e.g., voice and modem), wireless communications media, wireless communications networks, cellular communications networks, G3 communications networks, Public Switched Telephone Network (PSTNs), Packet Data Networks (PDNs), the Internet, intranets, and combinations thereof.
- The embodiments may also be embodied as non-transitory computer readable medium having instructions stored thereon for one or more aspects of the present invention as described and illustrated by way of the embodiments herein, as described herein, which when executed by a processor, cause the processor to carry out the steps necessary to implement the methods of the embodiments, as described and illustrated herein.
- An exemplary method for extending a
document transformation server 12 to process multiple documents from multiple sites, such as web server devices 16(1)-16(n), in anexemplary environment 10 will now be described with reference to FIGS. 1 and 4-6. Referring more specifically toFIG. 4 , instep 200 thedocument transformation server 12 receives an HTTP request whose url contains the URI of the document to process, from one of the client computing devices 14(1)-14(n), although other types of requests could be received and from other types of devices. Optionally, if the URI of the document to process is encoded, thedocument transformation server 12 will decode the URI of the document to process, although other manners for processing an encoded URI or other encoded portion of a URI HTTP request could be used. Since manners for encoding and decoding are well known to those of ordinary skill in the art, they will not be described in detail here. By way of example only, consider an HTTP request from one of the client computing devices 14(1)-14(n) where the URL to be processed is embedded in the PATH field of the HTTP request url: http://processor.com/app/www.acme.com/anyproduct.html. The transformer server applications is identified by “processor.com/app”; the address www.acme.com/anyproduct.html is the resource to be processed. - In
step 202, thedocument transformation server 12 extracts the domain in the URI of the document to process, although other fields of the URI could be extracted and used. - In
step 204, thedocument transformation server 12 determines whether the transformation of the website in the URI of the document to process is allowed. If instep 204, thedocument transformation server 12 determines the transformation of the website in the URI of the document to process is not allowed, then the No branch is taken to step 206. Instep 206, thedocument transformation server 12 generates an error page document. Instep 208 thedocument transformation server 12 returns the generated error page document in an HTTP response to the one of the client computing devices 14(1)-14(n) that provided the HTTP request in this example. - If in
step 204, thedocument transformation server 12 determines the transformation of the website in the URI of the document to process is allowed, then the Yes branch is taken to step 210. Instep 210, thedocument transformation server 12 downloads the original document or other resource linked by the given URL and transforms the downloaded document into an XML source, although other manners for processing the obtained document or documents can be used. Instep 212,document transformation server 12 looks for a mapping or configuration file for the directory that matches the extracted domain. An exemplary method for locating a mapping file from manifest.xml is described herein with reference toFIG. 5 . - In
step 214, thedocument transformation server 12 determines whether the mapping file for the extracted domain exists. If instep 214 thedocument transformation server 12 determines the mapping file does not exist, then the No branch is taken to step 216. Instep 216, thedocument transformation server 12 converts the document into the desired format. Next, instep 208 thedocument transformation server 12 returns the converted document in an HTTP response to the one of the client computing devices 14(1)-14(n) that provided the HTTP request. - If in
step 214 thedocument transformation server 12 determines the mapping file for the extracted domain does exist, then the Yes branch is taken to step 218. Instep 218, thedocument transformation server 12 use the mapping file to identify all of the XSL processors linked to the corresponding URL and applies the identified XSL processors to the document to be processed. Optionally thedocument transformation server 12 may apply one or more best matching rules to filter the identified one or more XML processors in the matching directory. By way of example only, one best matching rule is to take the XML processor with the longest matching pattern string, although other types and numbers of best matching rules can be used. - In
step 216, thedocument transformation server 12 converts the processed document into the desired format. Next, instep 208 the document transformation server returns the converted document in an HTTP response to the one of the client computing devices 14(1)-14(n) that provided the HTTP request. - Referring to
FIG. 5 , an exemplary method for obtaining a mapping file with thedocument transformation server 12 is illustrated. Instep 300, thedocument transformation server 12 receives a URI to match from one of the client computing devices 14(1)-14(n), although other types of requests could be received and from other types of devices. Instep 302, thedocument transformation server 12 extracts from the URI the - AUTHORITY portion corresponding to the associated domain and port, for example “ssl.example.com:8443”, although other types and numbers of fields could be extracted.
- In this example, if the port is either 80 or 443 (default values for HTTP and HTTPS respectively) the string representing the authority corresponds to the domain portion of the URL. However, if the port does not correspond to a standard value, the ‘:’ character is substituted with ‘_’ in order to avoid potential problems in the file system (i.e. ssl.example.com—8443). The string representing the authority is further stripped by the
document transformation server 12 removing the ‘www.’ from the extracted string. - In
step 304, thedocument transformation server 12 determines whether there is a directory with the same name as the extracted domain and containing the mapping file, although other manners for determining matches with other portions of the domain can be used. By way of example only, consider the following directories: (1) “www.acme.com”; (2) “_.example.com”; and (3) “ssl.example.com”. The www.acme.com directory will match all the requests for www.acme.com and acme.com domains. With this technology, the “_.example.com” directory will match all the requests for domains ending with “.example.com” that do not have more specific matching directories. Accordingly, “_.example.com” will match “products.example.com”, but it will not match “ssl.example.com” because an “ssl.example.com” directory exists. The “_” character in front of “.example.com” is used to make the directory visible when using file systems that use “.” characters in front of files to hide them to users. - If in
step 304 thedocument transformation server 12 determines there is no directory with the same name as the extracted domain, then the No branch is taken to step 306. Instep 306, thedocument transformation server 12 determines whether the domain contains a valid subdomain. If instep 306 thedocument transformation server 12 determines the domain does contain a valid subdomain, then the Yes branch is taken to step 308. Instep 308, thedocument transformation server 12 extracts the next level subdomain name and returns to step 304 as described earlier. - If in
step 304 thedocument transformation server 12 determines there is a directory with the same name as the extracted domain and containing the mapping file, then the Yes branch is taken to step 310, although other manners for determining matches with other portions of the domain can be used. In another example, thedocument transformation server 12 may also use another optional mapping file that stores known aliases of domains. When a known alias of a domain is identified using this optional mapping file, thedocument transformation server 12 can use the same one or more stored directories for the known and identified aliases. As a result, this reduces the number of stored directories when handling domains with multiple aliases (i.e. defined with DNS records of type CNAME). - In
step 310, thedocument transformation server 12 extracts the parts from the PATH and QUERY fields in the URI, although the parts can be extracted from other types and numbers of fields in the URI. - In
step 312, thedocument transformation server 12 determines whether the extracted parts in the PATH and QUERY fields of the URI match or otherwise have an association with one of one or more XML processors in the identified mapping file, although other types of associations between other types and numbers of parts can be used. If instep 312 thedocument transformation server 12 determines the extracted parts in the PATH and QUERY fields of the URI match or otherwise have an association with one of one or more XML processors, then the Yes branch is taken to step 314 where the matching XML processors are collected. Next, instep 316, thedocument transformation server 12 returns the collected XML processors to the requesting one of the client computing devices 14(1)-14(n). - If in
step 312 thedocument transformation server 12 determines the extracted parts in the PATH and QUERY fields of the URI do not match one of one or more XML processors, then the No branch is taken to step 316 where no matching XML processors are returned to the requesting one of the client computing devices 14(1)-14(n). - Referring to
FIG. 6 , an exemplary implementation of the mapping file “manifest.xml” is illustrated. Each map element identifies an XSL file (inside file element) and a substring to match a URL PATH component (inside the PATH element). The map element with the longest string matching the PATH component will be used to setup the XSL transformer identified by the level attribute. - In these examples, two XSL transformers are defined:
level 1 transformer; andlevel 2 transformer. If the request URL has the PATH field containing “/content/news/july.html”, then the original site web page is downloaded (for example, www.sample.com/content/news/july.html). Next, thelevel 1 transformer uses the news.xsl stylesheet document to transform the downloaded page. Thelevel 2 transformer uses content2.xs1 stylesheet document to transform the document obtained from thelevel 1 transformer. - If the request URL has the PATH field containing “/content/privacy.html”, then the original site web page is downloaded (for example www.sample.com/content/privacy.html). Next, the
level 1 transformer uses the content.xsl stylesheet document to transform the downloaded page. Next, thelevel 2 transformer uses the content2.xs1 stylesheet document to transform the document obtained from thelevel 1 transformer. - Accordingly, as illustrated and described herein this technology provides a number of advantages including providing a method, computer readable medium and an apparatus that extends a document transformation server to process multiple documents from multiple sites. One of the advantages of this technology is that a single association or match between a name of a directory and at least a portion of a domain name or other part of a URI can be used for hundreds or thousands of URIs. As a result, only a few associations with directories or other stored tables can be enough for the document transformation server to transform the content of an entire website.
- Having thus described the basic concept of the invention, it will be rather apparent to those skilled in the art that the foregoing detailed disclosure is intended to be presented by way of example only, and is not limiting. Various alterations, improvements, and modifications will occur and are intended to those skilled in the art, though not expressly stated herein. These alterations, improvements, and modifications are intended to be suggested hereby, and are within the spirit and scope of the invention. Additionally, the recited order of processing elements or sequences, or the use of numbers, letters, or other designations therefore, is not intended to limit the claimed processes to any order except as may be specified in the claims. Accordingly, the invention is limited only by the following claims and equivalents thereto.
Claims (18)
1. A method for extending a document transformation server to process multiple documents from multiple websites, the method comprising:
obtaining by a document transformation server a document to process based on at least a URL of the document to process in an HTTP request URL;
identifying by the document transformation server one or more processors to transform the obtained document based on one or more rules and at least a portion of the HTTP request URL;
transforming by the document transformation server the obtained document with the identified one or more processors; and
providing with the document transformation server the transformed document in an HTTP response.
2. The method as set forth in claim 1 wherein the obtaining the document to process is further based on one or more of an HTTP header or an HTTP POST parameter in the HTTP request URL.
3. The method as set forth in claim 1 wherein the one or more rules comprise a best matching rule and the identifying further comprises selecting one of the one or more processors associated with a longest pattern string matching the at least a portion of the HTTP request URL.
4. The method as set forth in claim 1 wherein the obtaining the document to process further comprises decoding with the document transformation server the obtained URL of the document to process prior to obtaining the document to process.
5. The method as set forth in claim 1 , wherein the identifying further comprises:
identifying a data structure having an identifier corresponding to at least a portion of a particular domain in the HTTP request URL; and
retrieving a plurality of associations from the data structure, the plurality of associations comprising a mapping of one or more of the processors to one or more parts of one or more fields in the HTTP request URL.
6. The method as set forth in claim 1 further comprising:
generating by the document transformation server an XML source representing the obtained document;
transforming by the document transformation server the XML source with the identified one or more processors; and
providing with the document transformation server the transformed XML source in an HTTP response.
7. A non-transitory computer readable medium having stored thereon instructions for extending a document transformation server to process multiple documents from multiple websites comprising machine executable code which when executed by a processor, causes the processor to perform steps comprising:
obtaining a document to process based on at least a URL of the document to process in an HTTP request URL;
identifying one or more processors to transform the obtained document based on one or more rules and at least a portion of the HTTP request URL;
transforming the obtained document with the identified one or more processors; and
providing the transformed document in an HTTP response.
8. The medium as set forth in claim 7 wherein the obtaining the document to process is further based on one or more of an HTTP header or an HTTP POST parameter in the HTTP request URL.
9. The medium as set forth in claim 7 wherein the one or more rules comprise a best matching rule and the identifying further comprises selecting one of the one or more processors associated with a longest pattern string matching the at least a portion of the HTTP request URL.
10. The medium as set forth in claim 7 wherein the obtaining the document to process further comprises decoding with the document transformation server the obtained URL of the document to process prior to obtaining the document to process.
11. The medium as set forth in claim 7 wherein the identifying further comprises:
identifying a data structure having an identifier corresponding to at least a portion of a particular domain in the HTTP request URL; and
retrieving a plurality of associations from the data structure, the plurality of associations comprising a mapping of one or more of the processors to one or more parts of one or more fields in the HTTP request URL
12. The medium as set forth in claim 7 wherein the instructions further comprise machine executable code which when executed by the processor, causes the processor to perform steps further comprising:
generating an XML source representing the obtained document;
transforming the XML source with the identified one or more processors; and
providing the transformed XML source in an HTTP response.
13. A document transformation apparatus comprising:
a memory; and
a processor coupled to the memory and configured to execute programmed instructions stored in the memory comprising:
obtaining a document to process based on at least a URL of the document to process in an HTTP request URL;
identifying one or more processors to transform the obtained document based on one or more rules and at least a portion of the HTTP request URL;
transforming the obtained document with the identified one or more processors; and
providing the transformed document in an HTTP response.
14. The apparatus as set forth in claim 13 wherein the obtaining the document to process is further based on one or more of an HTTP header or an HTTP POST parameter in the HTTP request URL.
15. The apparatus as set forth in claim 13 wherein the one or more rules comprise a best matching rule and the identifying further comprises selecting one of the one or more processors associated with a longest pattern string matching the at least a portion of the HTTP request URL.
16. The apparatus as set forth in claim 13 wherein the obtaining the document to process further comprises decoding with the document transformation server the obtained URL of the document to process prior to obtaining the document to process.
17. The apparatus as set forth in claim 13 wherein the identifying further comprises:
identifying a data structure having an identifier corresponding to at least a portion of a particular domain in the HTTP request URL; and
retrieving a plurality of associations from the data structure, the plurality of associations comprising a mapping of one or more of the processors to one or more parts of one or more fields in the HTTP request URL.
18. The apparatus as set forth in claim 13 wherein the processor coupled to the memory is further configured to execute programmed instructions stored in the memory further comprising:
generating an XML source representing the obtained document;
transforming the XML source with the identified one or more processors; and
providing the transformed XML source in an HTTP response.
Priority Applications (2)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
US13/939,838 US20130305139A1 (en) | 2010-09-14 | 2013-07-11 | Methods for extending a document transformation server to process multiple documents from multiple sites and devices thereof29547.0164 |
US14/039,630 US9846686B2 (en) | 2010-09-14 | 2013-09-27 | Methods for extending a document transformation server to process multiple documents from multiple sites and devices thereof |
Applications Claiming Priority (2)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
US12/807,766 US8516362B2 (en) | 2010-09-14 | 2010-09-14 | Methods for extending a document transformation server to process multiple documents from multiple sites and devices thereof |
US13/939,838 US20130305139A1 (en) | 2010-09-14 | 2013-07-11 | Methods for extending a document transformation server to process multiple documents from multiple sites and devices thereof29547.0164 |
Related Parent Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
US12/807,766 Continuation US8516362B2 (en) | 2010-09-14 | 2010-09-14 | Methods for extending a document transformation server to process multiple documents from multiple sites and devices thereof |
Related Child Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
US14/039,630 Continuation US9846686B2 (en) | 2010-09-14 | 2013-09-27 | Methods for extending a document transformation server to process multiple documents from multiple sites and devices thereof |
Publications (1)
Publication Number | Publication Date |
---|---|
US20130305139A1 true US20130305139A1 (en) | 2013-11-14 |
Family
ID=45807868
Family Applications (3)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
US12/807,766 Active 2030-10-21 US8516362B2 (en) | 2010-09-14 | 2010-09-14 | Methods for extending a document transformation server to process multiple documents from multiple sites and devices thereof |
US13/939,838 Abandoned US20130305139A1 (en) | 2010-09-14 | 2013-07-11 | Methods for extending a document transformation server to process multiple documents from multiple sites and devices thereof29547.0164 |
US14/039,630 Active US9846686B2 (en) | 2010-09-14 | 2013-09-27 | Methods for extending a document transformation server to process multiple documents from multiple sites and devices thereof |
Family Applications Before (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
US12/807,766 Active 2030-10-21 US8516362B2 (en) | 2010-09-14 | 2010-09-14 | Methods for extending a document transformation server to process multiple documents from multiple sites and devices thereof |
Family Applications After (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
US14/039,630 Active US9846686B2 (en) | 2010-09-14 | 2013-09-27 | Methods for extending a document transformation server to process multiple documents from multiple sites and devices thereof |
Country Status (4)
Country | Link |
---|---|
US (3) | US8516362B2 (en) |
EP (1) | EP2616962A4 (en) |
CA (1) | CA2811207A1 (en) |
WO (1) | WO2012036833A2 (en) |
Cited By (5)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US9846686B2 (en) | 2010-09-14 | 2017-12-19 | Usablenet Inc. | Methods for extending a document transformation server to process multiple documents from multiple sites and devices thereof |
US10809877B1 (en) | 2016-03-18 | 2020-10-20 | Audioeye, Inc. | Modular systems and methods for selectively enabling cloud-based assistive technologies |
US10867120B1 (en) | 2016-03-18 | 2020-12-15 | Audioeye, Inc. | Modular systems and methods for selectively enabling cloud-based assistive technologies |
US10896286B2 (en) | 2016-03-18 | 2021-01-19 | Audioeye, Inc. | Modular systems and methods for selectively enabling cloud-based assistive technologies |
US11727195B2 (en) | 2016-03-18 | 2023-08-15 | Audioeye, Inc. | Modular systems and methods for selectively enabling cloud-based assistive technologies |
Families Citing this family (6)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US20140101280A1 (en) * | 2012-10-05 | 2014-04-10 | Olaf Schmidt | Generic serializer framework |
US9584436B1 (en) * | 2014-05-07 | 2017-02-28 | Skyport Systems, Inc. | Method and system for managing class of service in a network |
US10362146B1 (en) * | 2015-09-30 | 2019-07-23 | Open Text Corporation | Method and system for enforcing governance across multiple content repositories using a content broker |
US10116533B1 (en) | 2016-02-26 | 2018-10-30 | Skyport Systems, Inc. | Method and system for logging events of computing devices |
WO2018081525A1 (en) * | 2016-10-28 | 2018-05-03 | Ebay Inc. | Optimization of publication for target computing device |
CN110046309A (en) * | 2019-04-02 | 2019-07-23 | 北京字节跳动网络技术有限公司 | Processing method, device, electronic equipment and the storage medium of document input content |
Citations (28)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US5864852A (en) * | 1996-04-26 | 1999-01-26 | Netscape Communications Corporation | Proxy server caching mechanism that provides a file directory structure and a mapping mechanism within the file directory structure |
US5870546A (en) * | 1996-02-21 | 1999-02-09 | Infoseek Corporation | Method and apparatus for redirection of server external hyper-link reference |
EP0965914A2 (en) * | 1998-04-30 | 1999-12-22 | Phone.Com Inc. | Method and apparatus for implementing a tag-based display language utilizing a procedural instruction language |
US20020116534A1 (en) * | 2000-11-14 | 2002-08-22 | Doug Teeple | Personalized mobile device viewing system for enhanced delivery of multimedia |
US20020133569A1 (en) * | 2001-03-03 | 2002-09-19 | Huang Anita Wai-Ling | System and method for transcoding web content for display by alternative client devices |
US20020147747A1 (en) * | 1999-06-14 | 2002-10-10 | Zaharkin Michael S. | System for converting data to a markup language |
US20030028577A1 (en) * | 2001-04-30 | 2003-02-06 | Chia-Chu Dorland | HTTP distributed XML-based automated event polling for network and E-service management |
US20030065645A1 (en) * | 2001-08-29 | 2003-04-03 | International Business Machines Corporation | System and method for transcoding digital content |
US20030088639A1 (en) * | 2001-04-10 | 2003-05-08 | Lentini Russell P. | Method and an apparatus for transforming content from one markup to another markup language non-intrusively using a server load balancer and a reverse proxy transcoding engine |
US20030106025A1 (en) * | 2001-11-20 | 2003-06-05 | Soo Sun Cho | Method and system for providing XML-based web pages for non-pc information terminals |
US6589291B1 (en) * | 1999-04-08 | 2003-07-08 | International Business Machines Corporation | Dynamically determining the most appropriate location for style sheet application |
US6640240B1 (en) * | 1999-05-14 | 2003-10-28 | Pivia, Inc. | Method and apparatus for a dynamic caching system |
US20030212753A1 (en) * | 2002-05-09 | 2003-11-13 | Chien-Chou Lai | Method and system of data synchronization using HTTP |
US20040015891A1 (en) * | 2001-04-02 | 2004-01-22 | Arellano-Payne Anna M. | System and method for an interoperability framework |
US20040064469A1 (en) * | 2002-07-22 | 2004-04-01 | Seiji Takahashi | Information processing apparatus and information processing method |
US20040133635A1 (en) * | 2002-11-26 | 2004-07-08 | Axel Spriestersbach | Transformation of web description documents |
US20040205656A1 (en) * | 2002-01-30 | 2004-10-14 | Benefitnation | Document rules data structure and method of document publication therefrom |
US20040230660A1 (en) * | 2000-04-13 | 2004-11-18 | Abjanic John B. | Cascading network apparatus for scalability |
WO2005003998A1 (en) * | 2003-06-30 | 2005-01-13 | International Business Machines Corporation Ibm | A method and system for improving presentation of html pages in web devices |
US20050262063A1 (en) * | 2004-04-26 | 2005-11-24 | Watchfire Corporation | Method and system for website analysis |
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 |
US20060265689A1 (en) * | 2002-12-24 | 2006-11-23 | Eugene Kuznetsov | Methods and apparatus for processing markup language messages in a network |
US7171691B2 (en) * | 2002-04-10 | 2007-01-30 | International Business Machines Corporation | Content sanitation via transcoding |
US7275208B2 (en) * | 2002-02-21 | 2007-09-25 | International Business Machines Corporation | XML document processing for ascertaining match of a structure type definition |
US20080183902A1 (en) * | 2007-01-31 | 2008-07-31 | Nathaniel Cooper | Content transform proxy |
US7574486B1 (en) * | 2000-11-06 | 2009-08-11 | Telecommunication Systems, Inc. | Web page content translator |
US7590644B2 (en) * | 1999-12-21 | 2009-09-15 | International Business Machine Corporation | Method and apparatus of streaming data transformation using code generator and translator |
US20100161762A1 (en) * | 2000-08-16 | 2010-06-24 | Parallel Networks, Llc | Method and System for Uniform Resource Locator Transformation |
Family Cites Families (17)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US6549952B1 (en) * | 1997-01-28 | 2003-04-15 | International Business Machines Corporation | Passing environment variables from an hypertext protocol server application programming interface |
US20020032706A1 (en) * | 1999-12-23 | 2002-03-14 | Jesse Perla | Method and system for building internet-based applications |
WO2001057671A1 (en) * | 2000-01-31 | 2001-08-09 | Mobileq Canada Inc. | Method and system for testing internet-based applications |
US7076521B2 (en) * | 2000-06-26 | 2006-07-11 | Vertical Computer Systems, Inc. | Web-based collaborative data collection system |
US8578266B2 (en) * | 2000-06-26 | 2013-11-05 | Vertical Computer Systems, Inc. | Method and system for providing a framework for processing markup language documents |
FR2811782B1 (en) * | 2000-07-12 | 2003-09-26 | Jaxo Europ | DOCUMENT CONVERSION SYSTEM WITH TREE STRUCTURE BY SELECTIVE PATHWAY OF SAID STRUCTURE |
US6822663B2 (en) * | 2000-09-12 | 2004-11-23 | Adaptview, Inc. | Transform rule generator for web-based markup languages |
US6785707B2 (en) * | 2000-11-14 | 2004-08-31 | Bitfone Corp. | Enhanced multimedia mobile content delivery and message system using cache management |
US20020161802A1 (en) * | 2001-02-27 | 2002-10-31 | Gabrick Kurt A. | Web presentation management system |
KR101026210B1 (en) | 2001-11-23 | 2011-03-31 | 리서치 인 모션 리미티드 | System and method for processing extensible markup language documents |
CA2393035A1 (en) * | 2002-07-11 | 2004-01-11 | Ibm Canada Limited-Ibm Canada Limitee | Converting markup language files |
KR100461729B1 (en) | 2002-11-01 | 2004-12-16 | 한국전자통신연구원 | A Customized-XHTML document Converting Method And System of HTML document using device profile |
US7451392B1 (en) * | 2003-06-30 | 2008-11-11 | Microsoft Corporation | Rendering an HTML electronic form by applying XSLT to XML using a solution |
GB0524008D0 (en) * | 2005-11-25 | 2006-01-04 | Ibm | Method and system for controlling the processing of requests for web resources |
KR20080097579A (en) | 2007-05-02 | 2008-11-06 | 에스케이 텔레콤주식회사 | Service system and method for reading document and mobile communication terminal for the same |
KR100944894B1 (en) | 2008-03-31 | 2010-03-03 | 주식회사 엘지텔레콤 | Web service provision system and method |
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 |
-
2010
- 2010-09-14 US US12/807,766 patent/US8516362B2/en active Active
-
2011
- 2011-08-17 WO PCT/US2011/048060 patent/WO2012036833A2/en active Application Filing
- 2011-08-17 CA CA2811207A patent/CA2811207A1/en not_active Abandoned
- 2011-08-17 EP EP11825620.5A patent/EP2616962A4/en not_active Withdrawn
-
2013
- 2013-07-11 US US13/939,838 patent/US20130305139A1/en not_active Abandoned
- 2013-09-27 US US14/039,630 patent/US9846686B2/en active Active
Patent Citations (35)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US5870546A (en) * | 1996-02-21 | 1999-02-09 | Infoseek Corporation | Method and apparatus for redirection of server external hyper-link reference |
US5864852A (en) * | 1996-04-26 | 1999-01-26 | Netscape Communications Corporation | Proxy server caching mechanism that provides a file directory structure and a mapping mechanism within the file directory structure |
EP0965914A2 (en) * | 1998-04-30 | 1999-12-22 | Phone.Com Inc. | Method and apparatus for implementing a tag-based display language utilizing a procedural instruction language |
US6589291B1 (en) * | 1999-04-08 | 2003-07-08 | International Business Machines Corporation | Dynamically determining the most appropriate location for style sheet application |
US6640240B1 (en) * | 1999-05-14 | 2003-10-28 | Pivia, Inc. | Method and apparatus for a dynamic caching system |
US20020147747A1 (en) * | 1999-06-14 | 2002-10-10 | Zaharkin Michael S. | System for converting data to a markup language |
US7707492B2 (en) * | 1999-06-14 | 2010-04-27 | West Services, Inc. | System for converting data to a markup language |
US7590644B2 (en) * | 1999-12-21 | 2009-09-15 | International Business Machine Corporation | Method and apparatus of streaming data transformation using code generator and translator |
US20040230660A1 (en) * | 2000-04-13 | 2004-11-18 | Abjanic John B. | Cascading network apparatus for scalability |
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 |
US8352570B2 (en) * | 2000-08-16 | 2013-01-08 | Parallel Networks, Llc | Method and system for uniform resource locator transformation |
US20100161762A1 (en) * | 2000-08-16 | 2010-06-24 | Parallel Networks, Llc | Method and System for Uniform Resource Locator Transformation |
US7574486B1 (en) * | 2000-11-06 | 2009-08-11 | Telecommunication Systems, Inc. | Web page content translator |
US20020116534A1 (en) * | 2000-11-14 | 2002-08-22 | Doug Teeple | Personalized mobile device viewing system for enhanced delivery of multimedia |
US20020133569A1 (en) * | 2001-03-03 | 2002-09-19 | Huang Anita Wai-Ling | System and method for transcoding web content for display by alternative client devices |
US7120702B2 (en) * | 2001-03-03 | 2006-10-10 | International Business Machines Corporation | System and method for transcoding web content for display by alternative client devices |
US20040015891A1 (en) * | 2001-04-02 | 2004-01-22 | Arellano-Payne Anna M. | System and method for an interoperability framework |
US7047525B2 (en) * | 2001-04-02 | 2006-05-16 | American Express Travel Related Services Company, Inc. | System and method for an interoperability framework |
US20030088639A1 (en) * | 2001-04-10 | 2003-05-08 | Lentini Russell P. | Method and an apparatus for transforming content from one markup to another markup language non-intrusively using a server load balancer and a reverse proxy transcoding engine |
US20030028577A1 (en) * | 2001-04-30 | 2003-02-06 | Chia-Chu Dorland | HTTP distributed XML-based automated event polling for network and E-service management |
US20030065645A1 (en) * | 2001-08-29 | 2003-04-03 | International Business Machines Corporation | System and method for transcoding digital content |
US20030106025A1 (en) * | 2001-11-20 | 2003-06-05 | Soo Sun Cho | Method and system for providing XML-based web pages for non-pc information terminals |
US20040205656A1 (en) * | 2002-01-30 | 2004-10-14 | Benefitnation | Document rules data structure and method of document publication therefrom |
US7275208B2 (en) * | 2002-02-21 | 2007-09-25 | International Business Machines Corporation | XML document processing for ascertaining match of a structure type definition |
US7171691B2 (en) * | 2002-04-10 | 2007-01-30 | International Business Machines Corporation | Content sanitation via transcoding |
US20030212753A1 (en) * | 2002-05-09 | 2003-11-13 | Chien-Chou Lai | Method and system of data synchronization using HTTP |
US7373347B2 (en) * | 2002-07-22 | 2008-05-13 | Ricoh Company, Ltd. | Information processing apparatus and information processing method |
US20040064469A1 (en) * | 2002-07-22 | 2004-04-01 | Seiji Takahashi | Information processing apparatus and information processing method |
US20040133635A1 (en) * | 2002-11-26 | 2004-07-08 | Axel Spriestersbach | Transformation of web description documents |
US20060265689A1 (en) * | 2002-12-24 | 2006-11-23 | Eugene Kuznetsov | Methods and apparatus for processing markup language messages in a network |
US7774831B2 (en) * | 2002-12-24 | 2010-08-10 | International Business Machines Corporation | Methods and apparatus for processing markup language messages in a network |
WO2005003998A1 (en) * | 2003-06-30 | 2005-01-13 | International Business Machines Corporation Ibm | A method and system for improving presentation of html pages in web devices |
US20050262063A1 (en) * | 2004-04-26 | 2005-11-24 | Watchfire Corporation | Method and system for website analysis |
US20080183902A1 (en) * | 2007-01-31 | 2008-07-31 | Nathaniel Cooper | Content transform proxy |
US7647404B2 (en) * | 2007-01-31 | 2010-01-12 | Edge Technologies, Inc. | Method of authentication processing during a single sign on transaction via a content transform proxy service |
Cited By (20)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US9846686B2 (en) | 2010-09-14 | 2017-12-19 | Usablenet Inc. | Methods for extending a document transformation server to process multiple documents from multiple sites and devices thereof |
US10809877B1 (en) | 2016-03-18 | 2020-10-20 | Audioeye, Inc. | Modular systems and methods for selectively enabling cloud-based assistive technologies |
US10845946B1 (en) | 2016-03-18 | 2020-11-24 | Audioeye, Inc. | Modular systems and methods for selectively enabling cloud-based assistive technologies |
US10845947B1 (en) | 2016-03-18 | 2020-11-24 | Audioeye, Inc. | Modular systems and methods for selectively enabling cloud-based assistive technologies |
US10860173B1 (en) | 2016-03-18 | 2020-12-08 | Audioeye, Inc. | Modular systems and methods for selectively enabling cloud-based assistive technologies |
US10867120B1 (en) | 2016-03-18 | 2020-12-15 | Audioeye, Inc. | Modular systems and methods for selectively enabling cloud-based assistive technologies |
US10866691B1 (en) | 2016-03-18 | 2020-12-15 | Audioeye, Inc. | Modular systems and methods for selectively enabling cloud-based assistive technologies |
US10896286B2 (en) | 2016-03-18 | 2021-01-19 | Audioeye, Inc. | Modular systems and methods for selectively enabling cloud-based assistive technologies |
US10928978B2 (en) | 2016-03-18 | 2021-02-23 | Audioeye, Inc. | Modular systems and methods for selectively enabling cloud-based assistive technologies |
US10997361B1 (en) | 2016-03-18 | 2021-05-04 | Audioeye, Inc. | Modular systems and methods for selectively enabling cloud-based assistive technologies |
US11029815B1 (en) | 2016-03-18 | 2021-06-08 | Audioeye, Inc. | Modular systems and methods for selectively enabling cloud-based assistive technologies |
US11061532B2 (en) | 2016-03-18 | 2021-07-13 | Audioeye, Inc. | Modular systems and methods for selectively enabling cloud-based assistive technologies |
US11080469B1 (en) | 2016-03-18 | 2021-08-03 | Audioeye, Inc. | Modular systems and methods for selectively enabling cloud-based assistive technologies |
US11151304B2 (en) | 2016-03-18 | 2021-10-19 | Audioeye, Inc. | Modular systems and methods for selectively enabling cloud-based assistive technologies |
US11157682B2 (en) | 2016-03-18 | 2021-10-26 | Audioeye, Inc. | Modular systems and methods for selectively enabling cloud-based assistive technologies |
US11455458B2 (en) | 2016-03-18 | 2022-09-27 | Audioeye, Inc. | Modular systems and methods for selectively enabling cloud-based assistive technologies |
US11727195B2 (en) | 2016-03-18 | 2023-08-15 | Audioeye, Inc. | Modular systems and methods for selectively enabling cloud-based assistive technologies |
US11836441B2 (en) | 2016-03-18 | 2023-12-05 | Audioeye, Inc. | Modular systems and methods for selectively enabling cloud-based assistive technologies |
US12045560B2 (en) | 2016-03-18 | 2024-07-23 | Audioeye, Inc. | Modular systems and methods for selectively enabling cloud-based assistive technologies |
US12175186B2 (en) | 2016-03-18 | 2024-12-24 | Audioeye, Inc. | Modular systems and methods for selectively enabling cloud-based assistive technologies |
Also Published As
Publication number | Publication date |
---|---|
US20140033022A1 (en) | 2014-01-30 |
US9846686B2 (en) | 2017-12-19 |
WO2012036833A2 (en) | 2012-03-22 |
EP2616962A2 (en) | 2013-07-24 |
US20120066582A1 (en) | 2012-03-15 |
US8516362B2 (en) | 2013-08-20 |
CA2811207A1 (en) | 2012-03-22 |
EP2616962A4 (en) | 2018-01-17 |
WO2012036833A3 (en) | 2012-08-09 |
WO2012036833A9 (en) | 2012-12-20 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
US9846686B2 (en) | Methods for extending a document transformation server to process multiple documents from multiple sites and devices thereof | |
US8660976B2 (en) | Web content rewriting, including responses | |
US8195767B2 (en) | Method and software for reducing server requests by a browser | |
US10120847B2 (en) | Methods for transforming requests for web content and devices thereof | |
US20110145299A1 (en) | Offline Gadgets IDE | |
CA2839006C (en) | Methods for making ajax web applications bookmarkable and crawlable and devices thereof | |
US10282401B2 (en) | Methods for processing cascading style sheets and devices thereof | |
US10198414B2 (en) | Methods for optimizing interaction with a form in a website page and systems thereof | |
US20110154187A1 (en) | Methods, software and devices for providing server hosted web applications | |
US9984052B2 (en) | Verifying content of resources in markup language documents | |
US20150128028A1 (en) | Methods for extending a selector application programming interface and devices thereof | |
US10116726B2 (en) | Methods for bundling images and devices thereof | |
Lathkar | Getting started with FastAPI | |
US9275023B2 (en) | Methods for further adapting XSL to HTML document transformations and devices thereof | |
CN101753537A (en) | Server and web sending and displaying method | |
CN111680247A (en) | Local calling method, device, equipment and storage medium of webpage character string | |
US20020138526A1 (en) | Javascript code optimizer | |
JP2009026013A (en) | Content registration / provision device, content registration / provision control method, and content registration / provision control program | |
CN102567404A (en) | Method and device for wireless application protocol (WAP) website online webpage conversion | |
TWI263149B (en) | A URL dataflow path re-scheduling system and the method thereof | |
JP2011197840A (en) | Apparatus and method for processing web page and program | |
Miyashita et al. | Web browsers as service-oriented clients integrated with web services |
Legal Events
Date | Code | Title | Description |
---|---|---|---|
STCB | Information on status: application discontinuation |
Free format text: ABANDONED -- FAILURE TO RESPOND TO AN OFFICE ACTION |