Magic cookie

From Wikipedia, the free encyclopedia
  (Redirected from Http cookie)
Jump to: navigation, search

A magic cookie, or just cookie for short, is a token or short packet of data passed between communicating programs, where the data is typically not meaningful to the recipient program. The contents are opaque and not usually interpreted until the recipient passes the cookie data back to the sender or perhaps another program at a later time. The cookie is often used like a ticket – to identify a particular event or transaction.[1]

In some cases, recipient programs are able to meaningfully compare two cookies for equality.

Early use[edit]

The term magic cookie appears in the man page for the fseek routine in the C standard library, dating back at least to 1979, where it was stated:

  • "ftell returns the current value of the offset relative to the beginning of the file associated with the named stream. It is measured in bytes on UNIX; on some other systems it is a magic cookie, and the only foolproof way to obtain an offset for fseek."[2][3]

Cookie as token[edit]

An analogy is the token supplied at a coat check (cloakroom) counter in real life. The token has no intrinsic meaning, but its uniqueness allows it to be exchanged for the correct coat when returned to the coat check counter. The coat check token is opaque because the way in which the counter staff are able to find the correct coat when the token is presented is immaterial to the person who wishes their coat returned. In other cases (as is possible with HTTP cookies), the actual data of interest can be stored as name–value pairs directly on the cookie.

Cookies are used as identifying tokens in many computer applications.[4] When one visits a website, the remote server may leave an HTTP cookie on one's computer, where they are often used to authenticate identity upon returning to the website.[5]

Cookies are a component of the most common authentication method used by the X Window System.[6]

See also[edit]

References[edit]

  1. ^ Raymond, Eric. "Cookie". The Jargon File. Retrieved 2014-02-03. 
  2. ^ UNIX Programmer's Manual, 7th Edition, Vol. 1, FSEEK (3S), Bell Telephone Laboratories, Murray Hill, New Jersey, January 1979.
  3. ^ UNIX Programmer's Manual, Vol. II (Library), FSEEK (3S), 4.2 BSD, 12 Feb 1983.
  4. ^ "Distributed Erlang". erlang.org. Retrieved 2014-02-03. 
  5. ^ "RFC 6265 - HTTP State Management Mechanism". Tools.ietf.org. Retrieved 2014-02-03. 
  6. ^ "Xsecurity". X.org. Retrieved 2014-02-03. 

This article is based on material taken from the Free On-line Dictionary of Computing prior to 1 November 2008 and incorporated under the "relicensing" terms of the GFDL, version 1.3 or later.