Jump to content

Evercookie

From Wikipedia, the free encyclopedia

This is an old revision of this page, as edited by Gurgle528 (talk | contribs) at 00:48, 13 November 2020 (fix grammar pt 2). The present address (URL) is a permanent link to this revision, which may differ significantly from the current revision.

'Tor Stinks' NSA presentation

Evercookie (also known as supercookie[1]) is a JavaScipt code that identifies and reproduces intentionally deleted cookies on the clients' browser storage.[2] Websites that have adopted this mechanism can identify users even if they attempt to delete the previously stored cookies.[3] It was created by Samy Kamkar in 2010 to demonstrate the possible infiltration from the websites that use respawning. [4]

In 2013, Edward Snowden leaked a top-secret NSA document that showed Evercookie can track Tor (anonymity networks) users.[5] Many popular companies use functionality similar to Evercookie to collect user information and track users. [1] Further research on fingerprinting and search engines also draws inspiration from Evercookie's ability to persistently track a user. [3][5]

Background

A traditional HTTP cookie is a relatively small amount of textual data that is stored by the user's browser. Cookies can be used to save preferences and login session information; however, they can also be employed to track users for marketing purposes. Due to concerns over privacy, all major browsers include mechanisms for deleting and/or refusing to accept cookies from websites.

Adobe Systems claimed that the size restrictions, likelihood of eventual deletion, and simple textual nature of traditional cookies motivated it to add the local shared object (LSO) mechanism to the Adobe Flash Player.[6] While Adobe has published a mechanism for deleting LSO cookies (which can store 100 KB of data per website, by default),[7] it has met with some criticism from security and privacy experts.[8] Since version 4, Firefox has treated LSO cookies the same way as traditional HTTP cookies, so they can be deleted together.[9][10]

Description

Samy Kamkar released v0.4 beta of the Evercookie on September 13, 2010, as open source.[11][12][13] According to the project's website:

Evercookie is designed to make persistent data just that, persistent. By storing the same data in several locations that a client can access, if any of the data is ever lost (for example, by clearing cookies), the data can be recovered and then reset and reused.

Simply think of it as cookies that just won't go away.

Evercookie is a javascript API available that produces extremely persistent cookies in a browser. Its goal is to identify a client even after they've removed standard cookies, Flash cookies (Local Shared Objects or LSOs), and others.

Evercookie accomplishes this by storing the cookie data in several types of storage mechanisms that are available on the local browser. Additionally, if Evercookie has found the user has removed any of the types of cookies in question, it recreates them using each mechanism available.

An Evercookie is not merely difficult to delete ⁠— ⁠it actively "resists" deletion by copying itself in different forms on the user's machine and resurrecting itself if it notices that some of the copies are missing or expired.[14] Specifically, when creating a new cookie, Evercookie uses the following storage mechanisms when available:

The developer is looking to add the following features, among others:[15]

See also

References

  1. ^ a b Bujlow, Tomasz; Carela-Espanol, Valentin; Lee, Beom-Ryeol; Barlet-Ros, Pere (2017). "A Survey on Web Tracking: Mechanisms, Implications, and Defenses". Proceedings of the IEEE. 105 (8): 1476–1510. doi:10.1109/jproc.2016.2637878. hdl:2117/108437. ISSN 0018-9219. S2CID 2662250.
  2. ^ Acar, Gunes; Eubank, Christian; Englehardt, Steven; Juarez, Marc; Narayanan, Arvind; Diaz, Claudia (2014). "The Web Never Forgets". Proceedings of the 2014 ACM SIGSAC Conference on Computer and Communications Security - CCS '14. New York, New York, USA: ACM Press: 674–689. doi:10.1145/2660267.2660347. ISBN 978-1-4503-2957-6. S2CID 8127620.
  3. ^ a b Kramár, Tomáš; Barla, Michal; Bieliková, Mária (2013-02-01). "Personalizing search using socially enhanced interest model, built from the stream of user's activity". Journal of Web Engineering. 12 (1–2): 65–92. ISSN 1540-9589.
  4. ^ Bashir, Muhammad Ahmad; Wilson, Christo (2018-10-01). "Diffusion of User Tracking Data in the Online Advertising Ecosystem". Proceedings on Privacy Enhancing Technologies. 2018 (4): 85–103. doi:10.1515/popets-2018-0033. ISSN 2299-0984. S2CID 52088002.
  5. ^ a b Kobusińska, Anna; Pawluczuk, Kamil; Brzeziński, Jerzy (2018). "Big Data fingerprinting information analytics for sustainability". Future Generation Computer Systems. 86: 1321–1337. doi:10.1016/j.future.2017.12.061. ISSN 0167-739X.
  6. ^ "What are local shared objects?". Archived from the original on 2010-05-29.
  7. ^ "How to manage and disable Local Shared Objects".
  8. ^ "Local Shared Objects -- 'Flash Cookies'".
  9. ^ Mike Beltzner (2011-01-13). "Bugzilla entry 625495 - Clear Adobe Flash Cookies (LSOs) when Clear Cookies is selected in the Privacy > Custom > Clear History". Retrieved 2011-09-28. Change to the "on close" firefox behavior to use the new NPAPI ClearSiteData API.
  10. ^ Mike Beltzner (2011-01-13). "Bugzilla entry 625496 - Clear Adobe Flash Cookies (LSOs) when Cookies is selected in Clear Recent History". Retrieved 2011-09-28. Change to the "clear recent history" firefox behavior to use the new NPAPI ClearSiteData API.
  11. ^ "Samy Kamkar - Evercookie".
  12. ^ "Evercookie source code". 2010-10-13. Retrieved 2010-10-28.
  13. ^ "Schneier on Security - Evercookies". 2010-09-23. Retrieved 2010-10-28.
  14. ^ "It is possible to kill the evercookie". 2010-10-27.
  15. ^ "samyk/evercookie". GitHub. Retrieved 2020-02-11.