有另一種方法可以跟蹤用戶而不使用cookies或Javascript。這種方法 已經(jīng)被用于無數(shù)網(wǎng)站,但幾乎沒人人們知道。本頁(yè)解釋這種方法是如何運(yùn)作的,以及是如何保護(hù)你自己的。
這種跟蹤方式
無需使用:
- Cookies
- Javascript
- LocalStorage/SessionStorage/GlobalStorage
- Flash、Java或其他組件
- 你的IP地址或是用戶代理字符串(User Agent String )
- 任何Panopticlick所使用的方式
相反,它使用另一種存儲(chǔ)方式,在瀏覽器重啟的時(shí)候也可以保持持久性,這就是:
caching.
即使你完全禁用cookies、關(guān)閉Javascript功能并且使用VPN,這種技術(shù)依然可以追蹤到你。
在線示例:http://lucb1e.com/rp/cookielesscookies/
我們繼續(xù),輸入一些東西然后保存。接著關(guān)閉你的瀏覽器再一次打開這個(gè)頁(yè)面。它是不是還在那兒呢?
檢查你的cookies,有沒有?當(dāng)然沒有,因?yàn)樗晖耆谝粡埣賵D片的校驗(yàn)和里,幾乎沒人能意識(shí)到。看到頁(yè)面頂部右邊的眼睛了嗎?這就是我們的跟蹤器。
那么它是怎么運(yùn)作的呢?
這是一張概覽圖
圖片中的ETag是一種校驗(yàn)和。當(dāng)圖片改變時(shí),校驗(yàn)和也會(huì)改變。所以當(dāng)瀏覽器有圖片并且知道校驗(yàn)和時(shí),它可以將校驗(yàn)和傳送給web服務(wù)器來驗(yàn)證。然后web服務(wù)器驗(yàn)證圖片是否改變。如果沒有,就不用重新傳送圖片了,省下了不少數(shù)據(jù)流量。
細(xì)心的讀者或許已經(jīng)注意到,可以這樣追蹤人群:瀏覽器發(fā)送回給服務(wù)器的信息就是它之前所接收到的(ETag)。這聽起來和cookies十分相似。服務(wù)器可以給每個(gè)瀏覽器一個(gè)唯一的ETag,瀏覽器再次連接時(shí)ETag可以從數(shù)據(jù)庫(kù)中找出來。
本例的技術(shù)要點(diǎn)(以及bug)
為了描述它是如何不必使用Javascript就可以生效的,我必須找一些專屬與你的信息,ETag除外。圖片在頁(yè)面加載完后加載,但只有圖片包含ETag。我要怎樣在頁(yè)面上顯示實(shí)時(shí)信息呢?結(jié)果是在不動(dòng)態(tài)刷新頁(yè)面的情況下,我不能做到這一點(diǎn),但動(dòng)態(tài)刷新要用到Javascript,這又是我所想避免的。
這個(gè)雞生蛋,蛋生雞的問題引出了一些bug:
- 所有能見的信息都是之前頁(yè)面加載的。只有按F5可以看到新的數(shù)據(jù)。
- 當(dāng)你瀏覽一個(gè)頁(yè)面而你沒有ETag的時(shí)(比如匿名模式),你的session會(huì)被清空。只有重載時(shí)才能再次看到。
我沒見過有簡(jiǎn)單的方案可以解決這些問題。當(dāng)然事在人為,但不像其他網(wǎng)站,而且我想盡量保持代碼簡(jiǎn)單并貼近現(xiàn)實(shí)。
注意在你真的要追蹤用戶時(shí),這些bug一般不會(huì)存在。因?yàn)槟悴粫?huì)想讓用戶知道他們?cè)诒蛔粉櫋?
源代碼
什么項(xiàng)目沒有源代碼呢? 哦對(duì),是微軟的Windows。
https://github.com/lucb1e/cookielesscookies
我們?cè)撛趺慈プ柚顾?
有一個(gè)方法我強(qiáng)烈推薦你做的就是, 任何時(shí)候你想更安全的瀏覽一個(gè)網(wǎng)頁(yè)的話, 請(qǐng)開啟一個(gè)隱私瀏覽窗口, 并僅使用https連接方式. 這么做能夠單方面地消除形如 BREACH (最新的https攻擊方式)攻擊的影響, 禁止任何可能會(huì)產(chǎn)生的追蹤cookie, 并且也能消除我在本頁(yè)面所展示的緩存追蹤的問題的影響, 我在網(wǎng)上購(gòu)物的時(shí)候會(huì)使用隱私瀏覽模式. 在 Firefox 下(我想IE應(yīng)該也是)快捷方式是 Ctrl+Shift+P, 在 Chrome 下則是 Ctrl+Shift+N.
除此以外, 這也取決于你的偏執(zhí)級(jí)別.
由于緩存追蹤實(shí)際上無法被偵測(cè), 所以當(dāng)前我還沒有很直觀的解決方法, 更因?yàn)榫彺孀陨砗苡杏?包括對(duì)你)并能夠節(jié)省時(shí)間和金錢. 網(wǎng)站管理員們將會(huì)消耗更少的帶寬(你可以想象一下, 終端用戶最終將為這份因?yàn)楦嗟膸挾_具的賬單埋單), 你的網(wǎng)頁(yè)會(huì)更快加載, 尤其是在移動(dòng)設(shè)備上會(huì)更加明顯如果說你沒有辦理不限流量的4G套餐的話. 若你居住在有著高延遲, 低帶寬的農(nóng)村地區(qū), 那就更糟糕了.
如果你非常疑神疑鬼,最好禁用所有緩存。這會(huì)阻止任何追蹤的發(fā)生,但我個(gè)人認(rèn)為得不償失。
Firefox插件Self-Destructing Cookies,能在你不使用瀏覽器一段時(shí)間后,清空你的緩存。這也許是個(gè)不用禁用緩存的好選擇;你 只會(huì)在訪問時(shí)被追蹤,但他們通過看哪個(gè)IP訪問哪個(gè)頁(yè)面的方法早就做到了這一點(diǎn),所以這種方法很合算。以后任何訪問都仿佛來自另一個(gè)用戶,如果所有其他的追蹤方式也已經(jīng)被阻止。
我不知道任何一款插件可以定期刪除緩存(比如每72小時(shí)一次),但也許有。這對(duì)99%的用戶來說會(huì)是個(gè)好主意,因?yàn)樗拗谱粉櫣δ艿耐瑫r(shí),對(duì)性能影響較小。
更新: 我聽說Firefox插件SecretAgent也使用ETag蓋寫來防止這種追蹤手段。如果你是根據(jù)域名來阻止追蹤,可以添加白名單來重新開啟緩存。這款插件可以阻止追蹤的功能已經(jīng)得到 確認(rèn)。 SecretAgent的網(wǎng)站.
該文章在 2013/8/30 17:43:55 編輯過