很多嚐鮮 iOS 14 的用戶,在升級完成後會遇到 App 請求一個名叫「Local Network(本地網絡)」的權限。

iOS 14 新增的「Local Network(本地網絡)」權限提醒

相信大家對這個權限有很多疑問:本地網絡權限是什麼?爲什麼要對它做出限制?以及哪些應用真的需要這個權限?這三個問題將在本文裏得到解答。

本地網絡權限是什麼,爲什麼要限制?

本地網絡(局域網)

本地網絡也叫局域網,是將設備接入路由器以後形成的網絡,設備可以通過這張網絡互相通信,讓你可以在手機上將歌曲從無線音響裏播放出來,在公司用公共打印機打印文檔,在朋友家一起用 Switch 聯機打遊戲。

從 iOS 13 開始,應用想要獲得當前連接到的 Wi-Fi 名稱,那就必須要獲得定位權限。因爲通過識別 Wi-Fi 名稱, 應用就能輕鬆地在你和周圍的人之間建立大數據網絡。但是不給定位權限不代表應用就沒有辦法跟蹤你了,因爲應用可以通過本地網絡裏的設備進行跟蹤。

可以通過 MAC 地址識別特定的局域網

在過去的 iOS 版本中,應用可以隨意掃描本地網絡中的設備,因此應用就可以很輕鬆地得到本地網絡裏所有設備的名稱和 MAC 地址。MAC 地址是一種確認網絡設備位置的地址,每個網卡都有一個唯一的 MAC 地址,加上 MAC 地址也具有唯一性,設備廠商會按照一定的規律分配 MAC,所以不同的局域網都是獨一無二可以識別的。

這樣就通過 MAC 地址和設備的名字以生成一個特定的「指紋」,持續地、跨應用地、跨設備地跟蹤用戶的行爲,並對用戶畫像持續進行調整。

比方說,你從線下渠道買了個新相機,拍完照片利用相機自帶的 Wi-Fi 將照片導入到手機上。這時候帶有某個推廣模塊的應用對局域網發起了一次掃描,識別到了一個新的設備,推廣模塊會將相機的 MAC 地址上傳了雲端,進行簡單的識別對比以後,很容易知道這個 MAC 地址屬於相機。這樣帶有推廣模塊的應用都會在畫像裏給你加上「相機用戶」這樣的標籤,當你下次打開帶有同一個推廣模塊的購物應用時,你就會看到推薦了一堆和相機有關的東西。

程序 A 在和相機交換數據時,程序 B 也可以掃描這個相機

所以在 iOS 14 裏,Apple 開始對本地網絡權限做出了更加嚴格的限制。

哪些 App 需要開本地網絡權限?

那麼到底哪些 App 我們需要給本地網絡權限呢?

就大部分應用而言,它們都不需要給本地網絡權限。 因爲它們沒有功能會使用到本地網絡,請求這個權限的主要目的就是爲了跟蹤用戶並推送廣告。

HomeKit、AirDrop、AirPlay 和 AirPrint 都是不需要網絡權限的

使用 HomeKit、AirDrop、AirPlay 和 AirPrint 的應用也不需要給出本地網絡權限 ,使用這類 API 的時候蘋果會以保護隱私的前提下傳輸和交換數據。

智能家居 App (非 HomeKit 型,比如米家等)、 在線流媒體投屏類 App (比如 Spotify、騰訊視頻等)會相對複雜一點: 配對時需要授予權限,控制時可以選擇性授予權限。

配對智能家居和電視時,對應的 App 只有先在本地找到對應的設備,才能進行配對,所以這個過程是必須要授予本地網絡權限的,配對完成以後大部分的智能家居服務會把設備記錄到雲端。

而到了控制時,由於在雲端存有智能家居的信息,用戶在控制時 App 會先嚐試從本地提交請求,如果無法連接的話再從雲端向設備推送請求,即可以選擇性授予權限。

簡單的延遲測試

從本地推送和從雲端推送,簡單的開關命令、調節命令延遲實際上沒有特別大的區別,所以不給本地網絡權限是完全可以的。只有在網絡環境較差時,推送和播放內容的時纔會感覺到明顯延遲和卡頓。所以我認爲,智能家居類 App 還是在線流媒體的投屏推送類 App 只需要在配對時短暫打開一段時間,日常使用的時候完全沒有必要給本地網絡權限。

最後 這三類 App 是必須要授予本地網絡權限 的,它們包括:

  1. 利用本地網絡進行設備發現
  2. 利用本地網絡進行數據傳輸
  3. 網絡調試工具

利用本地網絡發現設備的應用我接觸的也不是很多,大部分都是和智能家居有關的 App。其他和這方面有關的應用有:邀請同一網絡下的好友一起加入遊戲的應用和路由器的管理應用等。

而利用本地網絡傳輸數據的應用還是挺多的,比如你用本地視頻播放器 nPlayer 播放 NAS 裏的視頻時就需要本地網絡權限;又比如你想要把手機裏的照片利用第三方軟件投射到電視上,這也是需要本地網絡權限的;再比如你經常使用 TIM 裏的面對面快傳,這項功能也需要本地網絡權限才能正常工作。利用本地網絡傳輸數據的場景還有很多,這裏我只是舉出了三個常見的例子。

最後一個就是極客用得比較多的網絡調試工具,比如 HE Network Tools,如果不給本地網絡權限的話所有和本地網絡有關的測試工具都會失敗。不過我相信使用這類應用的人都知道要打開這個權限。

相關文章