Systems and methods for using an HTTP-aware client agent

US9692725B2 · US · B2

Patent metadata
FieldValue
Publication numberUS-9692725-B2
Application numberUS-201414448265-A
CountryUS
Kind codeB2
Filing dateJul 31, 2014
Priority dateMay 26, 2005
Publication dateJun 27, 2017
Grant dateJun 27, 2017

How to read this patent

A practical reading order for non-experts. Skip the full description unless you need deep technical detail.

  1. Title

    What the patent document calls the invention.

  2. Abstract

    A short plain-language summary of the technical disclosure.

  3. Assignees and inventors

    Who owns or filed the patent and who is credited as inventor.

  4. Key dates

    Filing, priority, publication, and grant dates set the timeline.

  5. First independent claim

    The legal scope of protection — read this for what is actually claimed.

  6. CPC / IPC classifications

    Technology tags used to group this patent with similar filings.

  7. Citations and related patents

    Prior art links and similar publications in this corpus.

Abstract

Official abstract text for this publication.

Systems and methods are described for using a client agent operating in a virtual private network environment to intercept HTTP communications. Methods include: intercepting at the network layer, by a client agent executing on a client, an HTTP request from an application executing on the client; modifying the HTTP request; and transmitting, via a transport layer connection, the modified HTTP request to a server. Additional methods may comprise adding, removing, or modifying at least one cookie in the HTTP request. Still other methods may comprise modifying at least one name-value pair contained in the HTTP request. Corresponding systems are also described.

First claim

Opening claim text (preview).

What is claimed: 1. A method comprising: (a) intercepting, by a client agent executing on a processor of a client device, one or more transport layer packets below an application layer of a network stack of the client device, the one or more transport layer packets comprising application layer content data of a web page from a server for a request from a user agent executing on the client device; (b) identifying, by the client agent while operating below the application layer of the network stack of the client device, request object data from uniform resource locators (URLs) embedded in application layer content data contained in a payload of the intercepted one or more transport layer packets; and (c) placing, by the client device, the request object data on a request object list; (d) querying, by the client device, a data cache of the client device to determine whether the request object data of the request object list in stored in the data cache; (e) marking, by the client device responsive to determining that request object data is not stored in the cache, in the request object list the request object data as to be downloaded to the client device; and (f) transmitting, by the client device, the request object list including the request object data marked as to be downloaded to the client device to a second device. 2. The method of claim 1 , wherein (a) further comprises intercepting, by the client agent, the one or more transport layer packets, at a network layer of the network stack. 3. The method of claim 1 , wherein (a) further comprises intercepting, by the client agent, the one or more transport layer packets, at a transport layer of the network stack. 4. The method of claim 1 , wherein (b) further comprises inserting, in the application layer content data, information identifying a version of the request object data identified by the URL stored in the data cache. 5. The method of claim 1 , wherein (b) further comprises modifying a URL identified in the application layer content data. 6. The method of claim 1 , wherein (d) further comprises determining that a second requested object data of the request object list is stored in the data cache and is fresh and wherein (e) further comprises marking the second requested object data in the request object list as being fresh. 7. The method of claim 1 , wherein (d) further comprises determining that a second requested object data of the request object list is stored in the data cache and is stale; and wherein (e) further comprises marking the second requested object data in the request object list as being stale. 8. The method of claim 1 , wherein (e) further comprises determining that the requested object data marked as being stale or to be downloaded matches stored predicted request data in a predicted response cache. 9. The method of claim 8 , further comprising marking the requested object data in the request object list as not to be downloaded. 10. The method of claim 1 , wherein the second device is intermediary to the client device and a content server, the second device configured to obtain one or more requested object data in the request object list from one or more content servers. 11. A system comprising: a client agent configured to execute on a processer of a client device and to intercept one or more transport layer packets below an application layer of a network stack of the client device, the one or more transport layer packets comprising application layer content data of a web page from a server for a request from a user agent executing on the client device; wherein the client agent is configured to operate below the application layer of the network stack of the client device and to identify, while operating below the application layer of the network stack of the client device, request object data from uniform resource locators (URLs) embedded in application layer content data contained in a payload of the intercepted one or more transport layer packets; and wherein the client device is configured to place the request object data on a request object list and query a data cache of the client device to determine whether the request object data of the request object list in stored in the data cache; and responsive to determining that request object data is not stored in the cache, the client device is configured to mark in the request object list the request object data as to be downloaded to the client device; and wherein the client device is configured to transmit the request object list including the request object data marked as to be downloaded to the client device to a second device. 12. The system of claim 11 , wherein the client agent is further configured to intercept the one or more transport layer packets, at a network layer of the network stack. 13. The system of claim 11 , wherein the client agent is further configured to intercept the one or more transport layer packets, at a transport layer of the network stack. 14. The system of claim 11 , wherein the client agent is further configured to insert in the application layer content data information identifying a version of the request object data identified by the URL stored in the data cache. 15. The system of claim 11 , wherein the client agent is further configured to modify a URL identified in the application layer content data. 16. The system of claim 11 , wherein the client device is further configured to determine that a second requested object data of the request object list is stored in the data cache and is fresh and mark the second requested object data in the request object list as being fresh. 17. The system of claim 11 , wherein the client device is further configured to determine that a second requested object data of the request object list is stored in the data cache and is stale and mark the second requested object data in the request object list as being stale. 18. The system of claim 11 , wherein the client device is further configured to determine that the requested object data marked as being stale or to be downloaded matches stored predicted request data in a predicted response cache. 19. The system of claim 18 , wherein the client device is further configured to mark the requested object data in the request object list as not to be downloaded. 20. The system of claim 11 , wherein the second device is intermediary to the client device and a content server, the second device is configured to obtain one or more requested object data in the request object list from one or more content servers.

Assignees

Inventors

Classifications

  • Intermediate processing functionally located close to the data consumer application, e.g. in same machine, in same home or in same sub-network · CPC title

  • Interlayer communication protocols or service data unit [SDU] definitions; Interfaces between layers · CPC title

  • based on web technology, e.g. hypertext transfer protocol [HTTP] · CPC title

  • Electricity · mapped topic

  • Electricity · mapped topic

Patent family

Related publications grouped by family.

External sources

Frequently asked questions

Answers are generated from the same data shown on this page.

What does patent US9692725B2 cover?
Systems and methods are described for using a client agent operating in a virtual private network environment to intercept HTTP communications. Methods include: intercepting at the network layer, by a client agent executing on a client, an HTTP request from an application executing on the client; modifying the HTTP request; and transmitting, via a transport layer connection, the modified HTTP r…
Who is the assignee on this patent?
Citrix Systems Inc
What technology area does this patent fall under?
Primary CPC classification H04L61/6009. Mapped technology areas include Electricity.
When was this patent published?
Publication date Tue Jun 27 2017 00:00:00 GMT+0000 (Coordinated Universal Time) (B2). Legal status and post-grant events are not shown on this page.
What related patents are in patentsdb?
We list 1 related publication on this page (citations in our corpus or others sharing the same primary CPC).