切換語言為:簡體

Eelctron升級到v32後wasm載入本地資源報錯

  • 爱糖宝
  • 2024-09-27
  • 2038
  • 0
  • 0

某個同事說,現有的Electron內建瀏覽器在F12的效能測試裡,發現JS檔案無法定位,或者定位錯誤,問我怎麼辦。

看了下,在MacOS中是沒問題的,只有Windows下莫名其妙有。但我就這點兒能耐,又能怎麼辦?

只能升級Electron試試唄。於是,將electron的依賴包從v31升級到最新穩定版本v32

Eelctron升級到v32後wasm載入本地資源報錯

開始以為挺順利,沒想到看到專案的網路裡報錯了:

Eelctron升級到v32後wasm載入本地資源報錯

控制檯也是提示本地資原始檔載入失敗:

Eelctron升級到v32後wasm載入本地資源報錯

這就有點兒讓人懵逼了。

我下意識以為是瀏覽器改變了什麼安全策略,但追蹤後發現瀏覽器中直接載入的file:///是沒問題的,只是WebAssembly(wasm)載入的有毛病。

為什麼有的資源會用wasm載入呢?原因是這些資源進行了加密,用wasm進行解密,可以有效增加外界破解難度。

再看了下,Electron v31用的126Chromium核心,v32用的是128的核心(在這裏Chromium核心版本)。

Eelctron升級到v32後wasm載入本地資源報錯

Eelctron升級到v32後wasm載入本地資源報錯

但其實在瀏覽器裡是無法直接載入本地檔案的,這個功能只有ElectronTauri這種App才能做到,所以一時無法確定是瀏覽器的鍋,還是Electron的鍋。

走投無路之際,我問了下GPT

Eelctron升級到v32後wasm載入本地資源報錯

GPT說的這句看著是有道理的:

在新版本的 Electron 中,可能對 file:// 或其他自定義 URL scheme 的支援做了一些修改。例如,WebAssembly 載入本地檔案可能涉及到資源路徑的解析,而 Electron 132 版本可能對非標準的 URL scheme 進行了更嚴格的驗證,導致無法正確識別 file://

下面第三條其實我開始Google搜尋見到過,確實可以攔截到file:///的檔案請求:

Eelctron升級到v32後wasm載入本地資源報錯

但給的示例是用的interceptFileProtocol,導致所有file請求都報錯了:

protocol.interceptFileProtocol('file', (req, callback) => {
    const url = req.url.substr(8)
    callback(decodeURI(url))
})

現在修改成registerFileProtocol,試上一下:

protocol.registerFileProtocol('file', (request, callback) => {
  const filePath = request.url.replace(/^file:\/\//, '')
  callback({ path: filePath })
})

居然好了!

Eelctron升級到v32後wasm載入本地資源報錯

由於這個API已經被提示不推薦使用:

Eelctron升級到v32後wasm載入本地資源報錯

所以又找了下替代方案,這樣看起來優雅多了:

protocol.handle('file', (req) => {
  return net.fetch(req.url, { bypassCustomProtocolHandlers: true })
})

問題解決了,但回到我們開始的問題,到底是Chromium的鍋,還是Electron的鍋呢?

我還是不確定。去掉這段程式碼,嘗試將Electron降到v32的第一個版本32.0.0,仍然是報錯;降到v31的最後一個版本31.6.0,是沒問題的。

Electron v32的發版日誌裡,破壞性變更僅有移除上傳檔案File的不標準的path

Eelctron升級到v32後wasm載入本地資源報錯

而看Chromium v127 的發版日誌 和 v128 的發版日誌也沒看出個所以然來,有安全層面的更新,不清楚是否有關。希望有大佬解答下。

搞客戶端開發有時候不得不升級依賴,但一升級又可能有這樣那樣的問題,無奈。

0則評論

您的電子郵件等資訊不會被公開,以下所有項目均必填

OK! You can skip this field.