The Internet, which started in the late 1960s, is a vast computer network consisting of many smaller networks that span the entire globe. The Internet has grown exponentially, and millions of users ranging from individuals to corporations now use permanent and dial-up connections to use the Internet on a daily basis worldwide. The computers or networks of computers connected within the Internet, known as “hosts”, allow public access to databases featuring information in nearly every field of expertise and are supported by entities ranging from universities and government to many commercial organizations.
The information on the Internet is made available to the public through “servers”. A server is a system running on an Internet host for making available files or documents contained within that host. Such files are typically stored on magnetic storage devices, such as tape drives or fixed disks, local to the host. An Internet server may distribute information to any computer that requests the files on a host. The computer making such a request is known as the “client”, which may be an Internet-connected workstation, bulletin board system or home personal computer (PC).
TCP/IP (Transmission Control Protocol/Internet Protocol) is one networking protocol that permits full use of the Internet. All computers on a TCP/IP network need unique ID codes. Therefore, each computer or host on the Internet is identified by a unique number code, known as the IP (Internet Protocol) number or address, and corresponding network and computer names. In the past, an Internet user gained access to its resources only by identifying the host computer and a path through directories within the host's storage to locate a requested file. Although various navigating tools have helped users to search resources on the Internet without knowing specific host addresses, these tools still require a substantial technical knowledge of the Internet.
The World-Wide Web (Web) is a method of accessing information on the Internet which allows a user to navigate the Internet resources intuitively, without IP addresses or other technical knowledge. The Web dispenses with command-line utilities which typically require a user to transmit sets of commands to communicate with an Internet server. Instead, the Web is made up of hundreds of thousands of interconnected “pages”, or documents, which can be displayed on a computer monitor. The Web pages are provided by hosts running special servers. Software which runs these Web servers is relatively simple and is available on a wide range of computer platforms including PC's. Equally available is a form of client software, known as a Web “browser”, which is used to display Web pages as well as traditional non-Web files on the client system. Today, the Internet hosts which provide Web servers are increasing at a rate of more than 300 per month, en route to becoming the preferred method of Internet communication.
Created in 1991, the Web is based on the concept of “hypertext” and a transfer method known as “HTTP” (Hypertext Transfer Protocol). HTTP is designed to run primarily over TCP/IP and uses the standard Internet setup, where a server issues the data and a client displays or processes it. One format for information transfer is to create documents using Hypertext Markup Language (HTML). HTML pages are made up of standard text as well as formatting codes which indicate how the page should be displayed. The Web client, a browser, reads these codes in order to display the page. The hypertext conventions and related functions of the world wide web are described in the appendices of U.S. patent application Ser. No. 08/328,133, filed on Oct. 24, 1994, by Payne et al. which is incorporated herein by reference.
Each Web page may contain pictures and sounds in addition to text. Hidden behind certain text, pictures or sounds are connections, known as “hypertext links” (“links”), to other pages within the same server or even on other computers within the Internet. For example, links may be visually displayed as words or phrases that may be underlined or displayed in a second color. Each link is directed to a web page by using a special name called a URL (Uniform Resource Locator). URLs enable a Web browser to go directly to any file held on any Web server. A user may also specify a known URL by writing it directly into the command line on a Web page to jump to another Web page.
The URL naming system consists of three parts: the transfer format, the host name of the machine that holds the file, and the path to the file. An example of a URL may be:
http://www.college.univ.edu/Adir/Bdir/Cdir/page.html,
where “http” represents the transfer protocol; a colon and two forward slashes (://) are used to separate the transfer format from the host name; “www.college.univ.edu” is the host name in which “www” denotes that the file being requested is a Web page; “/Adir/Bdir/Cdir” is a set of directory names in a tree structure, or a path, on the host machine; and “page.html” is the file name with an indication that the file is written in HTML.
The Internet maintains an open structure in which exchanges of information are made cost-free without restriction. The free access format inherent to the Internet, however, presents difficulties for those information providers requiring control over their Internet servers. Consider for example, a research organization that may want to make certain technical information available on its Internet server to a large group of colleagues around the globe, but the information must be kept confidential. Without means for identifying each client, the organization would not be able to provide information on the network on a confidential or preferential basis. In another situation, a company may want to provide highly specific service tips over its Internet server only to customers having service contracts or accounts.
Access control by an Internet server is difficult for at least two reasons. First, when a client sends a request for a file on a remote Internet server, that message is routed or relayed by a web of computers connected through the Internet until it reaches its destination host. The client does not necessarily know how its message reaches the server. At the same time, the server makes responses without ever knowing exactly who the client is or what its IP address is. While the server may be programmed to trace its clients, the task of tracing is often difficult, if not impossible. Secondly, to prevent unwanted intrusion into private local area networks (LAN), system administrators implement various data-flow control mechanisms, such as the Internet “firewalls”, within their networks. An Internet firewall allows a user to reach the Internet anonymously while preventing intruders of the outside world from accessing the user's LAN.
The present invention relates to methods of processing service requests from a client to a server through a network. In particular the present invention is applicable to processing client requests in an HTTP (Hypertext Transfer Protocol) environment, such as the World-Wide Web (Web). One aspect of the invention involves forwarding a service request from the client to the server and appending a session identification (SID) to the request and to subsequent service requests from the client to the server within a session of requests. In a preferred embodiment, the present method involves returning the SID from the server to the client upon an initial service request made by the client. A valid SID may include an authorization identifier to allow a user to access controlled files.
In a preferred embodiment, a client request is made with a Uniform Resource Locator (URL) from a Web browser. Where a client request is directed to a controlled file without an SID, the Internet server subjects the client to an authorization routine prior to issuing the SID, the SID being protected from forgery. A content server initiates the authorization routine by redirecting the client's request to an authentication server which may be at a different host. Upon receiving a redirected request, the authentication server returns a response to interrogate the client and then issues an SID to a qualified client. For a new client, the authentication server may open a new account and issue an SID thereafter. A valid SID typically comprises a user identifier, an accessible domain, a key identifier, an expiration time such as date, the IP address of the user computer, and an unforgeable digital signature such as a cryptographic hash of all of the other items in the SID encrypted with a secret key. The authentication server then forwards a new request consisting of the original URL appended by the SID to the client in a REDIRECT. The modified request formed by a new URL is automatically forwarded by the client browser to the content server.
When the content server receives a URL request accompanied by an SID, it logs the URL with the SID and the user IP address in a transaction log and proceeds to validate the SID. When the SID is so validated, the content server sends the requested document for display by the client's Web browser.
In the preferred embodiment, a valid SID allows the client to access all controlled files within a protection domain without requiring further authorization. A protection domain is defined by the service provider and is a collection of controlled files of common protection within one or more servers.
When a client accesses a controlled Web page with a valid SID, the user viewing the page may want to traverse a link to view another Web page. There are several possibilities. The user may traverse a link to another page in the same path. This is called a “relative link”. A relative link may be made either within the same domain or to a different domain. The browser on the client computer executes a relative link by rewriting the current URL to replace the old controlled page name with a new one. The new URL retains all portions of the old, including the SID, except for the new page name. If the relative link points to a page in the same protection domain, the SID remains valid, and the request is honored. However, if the relative link points to a controlled page in a different protection domain, the SID is no longer valid, and the client is automatically redirected to forward the rewritten URL to the authentication server to update the SID. The updated or new SID provides access to the new domain if the user is qualified.
The user may also elect to traverse a link to a document in a different path. This is called an “absolute link”. In generating a new absolute link, the SID is overwritten by the browser. In the preferred embodiment, the content server, in each serving of a controlled Web page within the domain, filters the page to include the current SID in each absolute URL on the page. Hence, when the user elects to traverse an absolute link, the browser is facilitated with an authenticated URL which is directed with its SID to a page in a different path. In another embodiment, the content server may forego the filtering procedure as above-described and redirect an absolute URL to the authentication server for an update.
An absolute link may also be directed to a controlled file in a different domain. Again, such a request is redirected to the authentication server for processing of a new SID. An absolute link directed to an uncontrolled file is accorded an immediate access.
In another embodiment, a server access control may be maintained by programming the client browser to store an SID or a similar tag for use in each URL call to that particular server. This embodiment, however, requires a special browser which can handle such communications and was generally not suitable for early browser formats common to the Web. However, it may now be implemented in cookie compatible browsers.
Another aspect of the invention is to monitor the frequency and duration of access to various pages both controlled and uncontrolled. A transaction log within a content server keeps a history of each client access to a page including the link sequence through which the page was accessed. Additionally, the content server may count the client requests exclusive of repeated requests from a common client. Such records provide important marketing feedback including user demand, access pattern, and relationships between customer demographics and accessed pages and access patterns.
The above and other features of the invention including various novel details of construction and combinations of parts will now be more particularly described with reference to the accompanying drawings and pointed out in the claims. It will be understood that the particular devices and methods embodying the invention are shown by way of illustration only and not as limitations of the invention. The principles and features of this invention may be employed in varied and numerous embodiments without departing from the scope of the invention.
Referring now to the drawings,
If the request is directed to a controlled page, the content server determines whether the URL contains an SID 102. For example, a URL may be directed to a controlled page name “report”, such as “http://content.com/report”, that requires an SID. If no SID is present, as in this example, the content server sends a “REDIRECT” response 122 to the browser 100 to redirect the user's initial request to an authentication server 200 to obtain a valid SID. The details of the authentication process are described in
If the initial GET URL contains a SID, the content server determines whether the request is directed to a page within the current domain 106. If the request having a SID is directed to a controlled page of a different domain, the SID is no longer valid and, again, the user is redirected to the authentication server 122.
If the request is for a controlled page within the current domain, the content server proceeds to log the request URL, tagged with SID, and the user IP address in the transaction log 108. The content server then validates the SID 110. Such validation includes the following list of checks: (1) the SID's digital signature is compared against the digital signature computed from the remaining items in the SID and the user IP address using the secret key shared by the authentication and content servers; (2) the domain field of the SID is checked to verify that it is within the domain authorized; and (3) the EXP field of the SID is checked to verify that it is later than the current time.
If the validation passes, the content server searches the page to be forwarded for any absolute URL links contained therein 112, that is, any links directed to controlled documents in different content servers. The content server augments each absolute URL with the current SID to facilitate authenticated accesses across multiple content servers. The requested page as processed is then transmitted to the client browser for display 117. The user viewing the requested Web page may elect to traverse any link on that page to trigger the entire sequence again 100.
Whenever the content server redirects the client to the authentication server 200, the authentication server initiates the authorization process by validating that it is for an approved content server and determining the level of authentication required for the access requested 210. Depending on this level, the server may challenge the user 212 for credentials. If the request is for a low level document, the authentication may issue an appropriate SID immediately 228 and forego the credential check procedures. If the document requires credentials, the authentication server sends a “CHALLENGE” response which causes the client browser to prompt the user for credentials 214. A preferred credential query typically consists of a request for user name and password. If the user is unable to provide a password, the access is denied. The browser forms an authorization header 300 from the information provided, and resends a GET request to the authentication server using the last URL along with an authorization header. For example, a URL of such a GET request may be: “http://auth.com/authenticate?domain=[domain]&URL=http://content.com/report and the authorization header may be: “AUTHORIZE: [authorization]”.
Upon receiving the GET request, the authentication server queries an account database 216 to determine whether the user is authorized 218 to access the requested document. A preferred account database may contain a user profile which includes information for identifying purposes, such as client IP address and password, as well as user demographic information, such as user age, home address, hobby, or occupation, for later use by the content server. If the user is authorized, an SID is generated 228 as previously described. If the user is not cleared for authorization, the authentication server checks to see if the user qualifies for a new account 220. If the user is not qualified to open a new account, a page denying access 222 is transmitted to the client browser 100. If the user is qualified, the new user is sent a form page such as illustrated in
An SID for an authorized user is appended (“tagged”) 230 to the original URL directed to a controlled page on the content server. The authentication server then transmits a REDIRECT response 232 based on the tagged URL to the client browser 100. The modified URL, such as “http://content.com/[SID]/report” is automatically forwarded to the content server 120.
In Step 3, the user on the client machine may elect to traverse a link in the advertisement page directed to a controlled page (CP). For example, the advertisement page may contain a link to a controlled page called “report”. Selecting this link causes the client browser 50 to forward a GET request through a URL which is associated with the report file “http://content.com/report”. The content server 52 determines that the request is to a controlled page and that the URL does not contain an SID. In Step 4, the content server transmits a REDIRECT response to the client, and, in Step 5, the browser automatically sends the REDIRECT URL to the authentication server 54. The REDIRECT URL sent to the authentication server may contain the following string:
“http://auth.com/authenticate?domain=[domain]&URL=http://content.com/report”
The authentication server processes the REDIRECT and determines whether user credentials (CRED) are needed for authorization. In Step 6, the authentication server transmits a “CHALLENGE” response to the client. As previously described, typical credentials consist of user name and password. An authorization header based on the credential information is then forwarded by the client browser to the authentication server. For example, a GET URL having such an authorization header is: “http://autho.com/authenticate?domain=[domain]&URL=http://content.com/report and the authorization header may be: “AUTHORIZE: [authorization]”. The authentication server processes the GET request by checking the Account Database 58. If a valid account exists for the user, an SID is issued which authorizes access to the controlled page “report” and all the other pages within the domain.
As previously described, the preferred SID comprises a compact ASCII string that encodes a user identifier, the current domain, a key identifier, an expiration time, the client IP address, and an unforgeable digital signature. In Step 8, the authentication server redirects the client to the tagged URL, “http://content.com/[SID]/report”, to the client. In Step 9, the tagged URL is automatically forwarded by the browser as a GET request to the content server. The content server logs the GET request in the Transaction database 56 by recording the tagged URL, the client IP address, and the current time. In Step 10, the content server, upon validating the SID, transmits the requested controlled page “report” for display on the client browser.
According to one aspect of the present invention, the content server periodically evaluates the record contained in the transaction log 56 to determine the frequency and duration of accesses to the associated content server. The server counts requests to particular pages exclusive of repeated requests from a common client in order to determine the merits of the information on different pages for ratings purposes. By excluding repeated calls, the system avoids distortions by users attempting to “stuff the ballot box.”
In one embodiment, the time intervals between repeated requests by a common client are measured to exclude those requests falling within a defined period of time.
Additionally, the server may, at any given time, track access history within a client-server session. Such a history profile informs the service provider about link traversal frequencies and link paths followed by users. This profile is produced by filtering transaction logs from one or more servers to select only transactions involving a particular user ID (UID). Two subsequent entries, A and B, corresponding to requests from a given user in these logs represent a link traversal from document A to document B made by the user in question. This information may be used to identify the most popular links to a specific page and to suggest where to insert new links to provide more direct access. In another embodiment, the access history is evaluated to determine traversed links leading to a purchase of a product made within commercial pages. This information may be used, for example, to charge for advertising based on the number of link traversals from an advertising page to a product page or based on the count of purchases resulting from a path including the advertisement. In this embodiment, the server can gauge the effectiveness of advertising by measuring the number of sales that resulted from a particular page, link, or path of links. The system can be configured to charge the merchant for an advertising page based on the number of sales that resulted from that page.
According to another aspect of the present invention, a secondary server, such as the authentication server 200 in
In another aspect of the invention, the user may gain access to domain of servers containing journals or publications through a subscription. In such a situation, the user may purchase the subscription in advance to gain access to on-line documents through the Internet. The user gains access to a subscribed document over the Internet through the authorization procedure as described above where an authorization indicator is preferably embedded in a session identifier. In another embodiment, rather than relying on a prepaid subscription, a user may be charged and billed each time he or she accesses a particular document through the Internet. In that case, authorization may not be required so long as the user is fully identified in order to be charged for the service. The user identification is most appropriately embedded in the session identifier described above.
In another aspect of the invention, facilities are provided to allow users to utilize conventional telephone numbers or other identifiers to access merchant services. These merchant services can optionally be protected using SIDs. In a preferred embodiment, as shown in
In another embodiment, implemented with a conventional browser, client 601 uses a form page provided by directory server 601 that prompts for a telephone number or other identifier in place of a “dial” command, and Message 1 is a POST message to a URL specified by this form page.
Once NUMBER is received by directory server 601, the directory server uses database 604 to translate the NUMBER to a target URL that describes the merchant server and document that implements the service corresponding to NUMBER. This translation can ignore the punctuation of the number, therefore embedded parenthesis or dashes are not significant.
In another embodiment an identifier other than a number may be provided. For example, a user may enter a company name or product name without exact spelling. In such a case a “soundex” or other phonetic mapping can be used to permit words that sound alike to map to the same target URL. Multiple identifiers can also be used, such as a telephone number in conjunction with a product name or extension.
In Message 2, Directory server 602 sends a REDIRECT to client 601, specifying the target URL for NUMBER as computed from database 604. The client browser 601 then automatically sends Message 3 to GET the contents of this URL. Merchant server 603 returns this information in Message 4. The server 602 might have returned a Web page to the client to provide an appropriate link to the required document. However, because server 602 makes a translation to a final URL and sends a REDIRECT rather than a page to client 601, the document of message 4 is obtained without any user action beyond the initial dial input.
The Target URL contained in Message 3 can be an ordinary URL to an uncontrolled page, or it can be a URL that describes a controlled page. If the Target URL describes a controlled page then authentication is performed as previously described. The Target URL can also describe a URL that includes an SID that provides a preauthorized means of accessing a controlled page.
Among benefits of the “dial” command and its implementation is an improved way of accessing the Internet that is compatible with conventional telephone numbers and other identifiers. Merchants do not need to alter their print or television advertising to provide an Internet specific form of contact information, and users do not need to learn about URLs.
In the approach a single merchant server can provide multiple services that correspond to different external “telephone numbers” or other identifiers. For example, if users dial the “flight arrival” number they could be directed to the URL for the arrival page, while, if they dial the “reservations” number, they would be directed to the URL for the reservations page. A “priority gold” number could be directed to a controlled page URL that would first authenticate the user as belonging to the gold users group, and then would provide access to the “priority gold” page. An unpublished “ambassador” number could be directed to a tagged URL that permits access to the “priority gold” page without user authentication.
This invention has particular application to network sales systems such as presented in U.S. patent application Ser. No. 08/328,133, filed Oct. 24, 1994, by Payne et al. which is incorporated herein by reference.
Those skilled in the art will know, or be able to ascertain using no more than routine experimentation, many equivalents to the specific embodiments or the invention described herein. These and all other equivalents are intended to be encompassed by the following claims.
This application is a Continuation of U.S. Ser. No. 08/474,096, filed Jun. 7, 1995, now U.S. Pat. No. 5,708,780 the entire teachings of which are incorporated herein by reference.
Number | Name | Date | Kind |
---|---|---|---|
4305059 | Benton | Dec 1981 | A |
4528643 | Freeny, Jr. | Jul 1985 | A |
4529870 | Chaum | Jul 1985 | A |
4578530 | Zeidler | Mar 1986 | A |
4734858 | Schlafly | Mar 1988 | A |
4755940 | Brachtl et al. | Jul 1988 | A |
4759063 | Chaum | Jul 1988 | A |
4759064 | Chaum | Jul 1988 | A |
4775935 | Yourick | Oct 1988 | A |
4795890 | Goldman | Jan 1989 | A |
4799156 | Shavit et al. | Jan 1989 | A |
4812628 | Boston et al. | Mar 1989 | A |
4827508 | Shear | May 1989 | A |
4891503 | Jewell | Jan 1990 | A |
4922521 | Krikke et al. | May 1990 | A |
4926480 | Chaum | May 1990 | A |
4935870 | Burk, Jr. et al. | Jun 1990 | A |
4947028 | Gorog | Aug 1990 | A |
4947430 | Chaum | Aug 1990 | A |
4949380 | Chaum | Aug 1990 | A |
4972318 | Brown et al. | Nov 1990 | A |
4977595 | Ohta et al. | Dec 1990 | A |
4982346 | Girouard et al. | Jan 1991 | A |
4987593 | Chaum | Jan 1991 | A |
4991210 | Chaum | Feb 1991 | A |
4992940 | Dworkin | Feb 1991 | A |
4996711 | Chaum | Feb 1991 | A |
5025373 | Keyser, Jr. et al. | Jun 1991 | A |
5060153 | Nakagawa | Oct 1991 | A |
5077607 | Johnson et al. | Dec 1991 | A |
5105184 | Pirani et al. | Apr 1992 | A |
5220501 | Lawlor et al. | Jun 1993 | A |
5247575 | Sprague et al. | Sep 1993 | A |
5276736 | Chaum | Jan 1994 | A |
5305195 | Murphy | Apr 1994 | A |
5311594 | Penzias | May 1994 | A |
5319542 | King, Jr. et al. | Jun 1994 | A |
5321751 | Ray et al. | Jun 1994 | A |
5336870 | Hughes et al. | Aug 1994 | A |
5341429 | Stringer et al. | Aug 1994 | A |
5347632 | Filepp et al. | Sep 1994 | A |
5351186 | Bullock et al. | Sep 1994 | A |
5351293 | Michener et al. | Sep 1994 | A |
5383113 | Kight et al. | Jan 1995 | A |
5414833 | Hershey et al. | May 1995 | A |
5475585 | Bush | Dec 1995 | A |
5521631 | Budow et al. | May 1996 | A |
5530852 | Meske, Jr. et al. | Jun 1996 | A |
5535229 | Hain, Jr. et al. | Jul 1996 | A |
5544322 | Cheng et al. | Aug 1996 | A |
5557516 | Hogan | Sep 1996 | A |
5557518 | Rosen | Sep 1996 | A |
5557798 | Skeen et al. | Sep 1996 | A |
5560008 | Johnson et al. | Sep 1996 | A |
5577209 | Boyle et al. | Nov 1996 | A |
5590197 | Chen et al. | Dec 1996 | A |
5592378 | Cameron et al. | Jan 1997 | A |
5594910 | Filepp et al. | Jan 1997 | A |
5596642 | Davis et al. | Jan 1997 | A |
5596643 | Davis et al. | Jan 1997 | A |
5604802 | Holloway | Feb 1997 | A |
5621797 | Rosen | Apr 1997 | A |
5623547 | Jones et al. | Apr 1997 | A |
5623656 | Lyons | Apr 1997 | A |
5642419 | Rosen | Jun 1997 | A |
5664110 | Green et al. | Sep 1997 | A |
5664111 | Nahan et al. | Sep 1997 | A |
5694551 | Doyle et al. | Dec 1997 | A |
5708780 | Levergood et al. | Jan 1998 | A |
5710884 | Dedrick | Jan 1998 | A |
5715314 | Payne et al. | Feb 1998 | A |
5724424 | Gifford | Mar 1998 | A |
5727164 | Kaye et al. | Mar 1998 | A |
5734719 | Tsevdos et al. | Mar 1998 | A |
5761662 | Dasan | Jun 1998 | A |
5768521 | Dedrick | Jun 1998 | A |
5774670 | Montulli | Jun 1998 | A |
5784565 | Lewine | Jul 1998 | A |
5806077 | Wecker | Sep 1998 | A |
5812776 | Gifford | Sep 1998 | A |
5819092 | Ferguson et al. | Oct 1998 | A |
5826241 | Stein et al. | Oct 1998 | A |
5826242 | Montulli | Oct 1998 | A |
5848399 | Burke | Dec 1998 | A |
5895454 | Harrington | Apr 1999 | A |
5897622 | Binn et al. | Apr 1999 | A |
5909492 | Payne et al. | Jun 1999 | A |
5920847 | Kolling et al. | Jul 1999 | A |
6006199 | Berlin et al. | Dec 1999 | A |
6023683 | Johnson et al. | Feb 2000 | A |
6041316 | Allen | Mar 2000 | A |
6049785 | Gifford | Apr 2000 | A |
6134592 | Montulli | Oct 2000 | A |
6195649 | Gifford | Feb 2001 | B1 |
6199051 | Gifford | Mar 2001 | B1 |
6205437 | Gifford | Mar 2001 | B1 |
6449599 | Payne et al. | Sep 2002 | B1 |
6708157 | Stefik et al. | Mar 2004 | B2 |
Number | Date | Country |
---|---|---|
0172670 | Feb 1986 | EP |
0 456 920 | Nov 1991 | EP |
0542298 | May 1993 | EP |
0 645 688 | Mar 1995 | EP |
2102606 | Feb 1983 | GB |
3278230 | Dec 1991 | JP |
410191 | Jan 1992 | JP |
05-158983 | Jun 1993 | JP |
5274275 | Oct 1993 | JP |
6162059 | Jun 1994 | JP |
6291776 | Oct 1994 | JP |
WO 9116691 | Oct 1991 | WO |
WO 9310503 | May 1993 | WO |
WO 9403859 | Feb 1994 | WO |
Number | Date | Country | |
---|---|---|---|
Parent | 08474096 | Jun 1995 | US |
Child | 09005479 | US |