成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

漲知識,原來可以這樣用CSS來追蹤用戶

開發 前端
除了使用 JS 追蹤用戶,現在有人提出了還可以使用 CSS 進行網頁追蹤和分析,譯者認為,這種方式更為 優雅,更為 簡潔,且 不好屏蔽,值得嘗試一波。

 [[217862]]

除了使用 JS 追蹤用戶,現在有人提出了還可以使用 CSS 進行網頁追蹤和分析,譯者認為,這種方式更為 優雅,更為 簡潔,且 不好屏蔽,值得嘗試一波,了解更多,可查看 倉庫地址(https://github.com/jbtronics/CrookedStyleSheets) 和 demo(http://crookedss.bplaced.net/)

我們可以用它來做什么

我們可以收集關于用戶的一些基本信息,例如 屏幕分辨率(當瀏覽器***化時)以及用戶使用的什么瀏覽器(引擎)

此外,我們可以監測用戶是否點擊某個鏈接或鼠標懸停在某個元素上,用來 追蹤用戶懸停的鏈接,甚至可以 追蹤用戶如何移動鼠標(在頁面使用不可見的字段),然而,使用目前我的方法只能追蹤用戶的***次點擊或懸停,我相信,修改我的方法最終可以實現追蹤用戶的每次點擊

***,我們還可以監測用戶是否安裝了某個特殊的字體,基于這個信息,我們可以追蹤用戶使用的 操作系統,因為不同操作系統使用的字體也稍有不同,例如 Windows 的 Calibri

這又是如何實現的

普通的做法

用 CSS 你可以使用 url("foo.bar") 屬性引用外部資源添加圖像,有趣的是,這個資源只在需要的時候被加載(例如,當鏈接被點擊時)

所以,我們可以用 CSS 創建一個選擇器,當用戶點擊某個鏈接時調用某個特定的 UPL

 

  1. #link2:active::after { 
  2.  
  3.   content: url('track.php?action=link2_clicked'); 
  4.  

服務端,php 腳本會在調用 URL 時保存時間戳

瀏覽器監測

瀏覽器監 測是基于 @supports Media-Query 的,我們可以監測瀏覽器的一些特殊的屬性,例如 -webkit-appearance

 

  1. @supports (-webkit-appearance: none) { 
  2.  
  3.   #chrome_detect::after { 
  4.  
  5.     content: url('track.php?action=browser_chrome'); 
  6.  
  7.   } 
  8.  

字體監測

對于 字體監測,需要定義一個新的字體,如果一個字體存在,文本會嘗試使用該字體進行樣式設置,然而,當用戶在系統上找不到該字體時,定義的字體會作為備用,在這種情況下,瀏覽器會嘗試去加載定義的字體并在服務器上調用追蹤腳本

 

  1. /** Font detection **/ 
  2.  
  3. @font-face { 
  4.  
  5.   font-family: Font1; 
  6.  
  7.   src: url('track.php?action=font1'); 
  8.  
  9.   
  10.  
  11. #font_detection1 { 
  12.  
  13.   font-family: Calibri, Font1; 
  14.  

懸停監測

對于 懸停監測(基于 jeyroik 的想法),我們需定義一個關鍵幀,每次使用這個關鍵幀都要去請求一個 URL

 

  1. @keyframes pulsate { 
  2.  
  3.   0% { 
  4.  
  5.     background-image: url('track.php?duration=00'); 
  6.  
  7.   } 
  8.  
  9.   20% { 
  10.  
  11.     background-image: url('track.php?duration=20'); 
  12.  
  13.   } 
  14.  
  15.   40% { 
  16.  
  17.     background-image: url('track.php?duration=40'); 
  18.  
  19.   } 
  20.  
  21.   60% { 
  22.  
  23.     background-image: url('track.php?duration=60'); 
  24.  
  25.   } 
  26.  
  27.   80% { 
  28.  
  29.     background-image: url('track.php?duration=80'); 
  30.  
  31.   } 
  32.  
  33.   100% { 
  34.  
  35.     background-image: url('track.php?duration=100'); 
  36.  
  37.   } 
  38.  

然后,我們使用定義的關鍵幀創建動畫,我們可以定義動畫持續的時間,這也是我們測量的***時間

 

  1. #duration:hover::after { 
  2.  
  3.   -moz-animation: pulsate 5s infinite; 
  4.  
  5.   -webkit-animation: pulsate 5s infinite; 
  6.  
  7.   /*animation: pulsate 5s infinite;*/ 
  8.  
  9.   animation-name: pulsate; 
  10.  
  11.   animation-duration: 10s; 
  12.  
  13.   content: url('track.php?duration=-1'); 
  14.  

我們可以通過補充關鍵幀的設置,來優化分辨率的監測

輸入監測

監測用戶選中了某個復選框,我們可以使用 CSS 提供的 :selected 選擇器

 

  1. #checkbox:checked { 
  2.  
  3.   content: url('track.php?action=checkbox'); 
  4.  

為了監測字符串,我們結合了 HTML pattern 屬性,它可以幫助我們解決一些基本的輸入驗證,再結合 :valid 選擇器,瀏覽器當輸入匹配成功時會去請求我們的追蹤站點

 

  1. <input type="text" id="text_input" pattern="^test$" required=""/> 
  2.  
  3. #text_input:valid { 
  4.  
  5.   background: green; 
  6.  
  7.   background-image: url('track.php?action=text_input'); 
  8.  

Demo

點擊 這里(http://crookedss.bplaced.net/) 你可以查看該倉庫的一個 demo。index.html 實踐了的上述的方法,訪問 results.php 可以查看結果

如果屬性后面沒有任何 content 或有 php 警告 出現,這就意味著這個屬性的值為 false 或用戶還沒訪問頁面或鏈接(這個,確實很煩,但你可以知道這些方法的原理)

此外,分辨率監測還不是特別的準確,因為目前只能監測最常用的屏幕寬度。***還想說的是,監測用戶實際屏幕的寬度并沒有想象中的那么簡單,因為 CSS 監測的高度為瀏覽器窗口的高度,而通常由于系統面板 / 任務欄的原因,使得瀏覽器窗口要小于顯示器

有什么辦法可以防止使用上面的方法進行追蹤

目前我知道的唯一辦法就是 完全禁用 CSS(你可以使用像 uMatrix 的插件來實現),但它的代價也是十分巨大的,沒有 CSS,網頁就沒有之前那么賞心悅目了,甚至導致無法正常使用,所以,禁用 CSS 算不上一個真正的選擇,除非,你實在擔心你的隱私(例如,當你在使用 Tor 瀏覽器,也許你應該禁用 CSS)

一個更好的解決方案是,在網頁加載時,瀏覽器不會去加載需要的外部資源,這樣,就不可能監測到用戶的個人行為,這種對內容加載的修改可以通過瀏覽器來實現,也可以通過插件來實現(類似 NoScript 或 uMatrix)

上述方法也存在一個明顯的問題,那就是 對性能會造成一定的影響,因為瀏覽器會在初始化頁面時加載大量的內容(有些內容是頁面根本不需要的)

責任編輯:龐桂玉 來源: 前端大全
相關推薦

2024-05-17 09:37:26

format屬性Spring

2019-01-29 10:00:59

GitHub開源搜索

2024-07-10 11:26:18

2023-12-11 13:57:00

RFM模型激勵機制

2022-08-12 08:25:33

Python異常信息代碼

2013-09-18 10:44:01

搜狗輸入法詞語

2024-11-19 09:15:40

搜索類型MySQL

2017-01-16 13:34:21

2012-10-11 09:46:20

2017-01-05 15:07:33

2016-12-02 20:43:28

Android

2024-12-30 00:24:46

2023-03-30 11:38:56

機器學習邏輯規則數量

2021-02-01 13:35:28

微信Python技巧

2020-12-28 08:36:30

C語言編程泛型

2024-09-04 08:27:15

2025-05-28 08:25:00

JavaScript代碼開發

2021-07-09 05:52:36

架構開發緩存

2023-07-17 09:19:20

CSSCSS 漸變

2012-10-12 10:13:26

eclips代碼編寫Editplus
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 亚洲一区二区欧美 | 亚洲欧美在线免费观看 | 国产三级一区二区 | 精品久久久久久亚洲国产800 | 成人在线网址 | 午夜手机在线视频 | 中文字幕乱码视频32 | 91久久久久久久 | 二区欧美 | 久久久成人免费一区二区 | 91久久精品一区二区二区 | 九九综合九九 | 国产精品色 | jizz在线免费观看 | 天天曰天天曰 | 国产二区视频 | 天天综合91 | 嫩草视频网 | 日韩精品免费在线观看 | 国产乱码久久久 | 91久久精品国产91久久性色tv | 精品国产欧美一区二区三区不卡 | 精品一区二区三区在线观看国产 | 在线一区| 狠狠久 | 五月婷婷丁香 | 国产精品免费一区二区三区四区 | 综合九九 | 6996成人影院网在线播放 | 日本三级播放 | 国产乱码精品一区二区三区忘忧草 | 日本在线一区二区三区 | 国产精品不卡 | 超碰伊人| 91欧美| 欧美日韩一 | 日韩中文在线观看 | jlzzjlzz欧美大全 | 亚洲欧美网 | 在线观看一区 | 成人国产在线观看 |