首頁 > Java > java教程 > 如何解決 Java 9 中的「非法反射存取」警告?

如何解決 Java 9 中的「非法反射存取」警告?

Mary-Kate Olsen
發布: 2024-12-15 03:06:11
原創
564 人瀏覽過

How Can I Resolve

Illegal Reflective Access in Java 9:​​ A Detailed Examination

Java 9 introduced the concept of illeir reflective illeich此錯誤訊息的疑問。本文將深入探討非法反射存取的本質,觸發警報的情況以及可能的解決方案。

Java 9 中的模組系統引入了模組化#放鬆強封裝的概念,這是理解非法反射存取的關鍵。模組中程式碼對其他模組程式碼和可見包的存取受到嚴格的控制。然而,為了 облегчить переход на Java 9,模組的強封裝可以被放鬆。

runtime系統可以提供以下操作:

  • 靜態存取: 透過編譯後的字節碼提供。
  • 運行時呼叫: 允許呼叫其運行時系統,並將一個或多個模組的一個或多個套件作為所有未命名模組中的程式碼打開。

非法存取的概念

如果在以下情況下使用反射API 成功調用,則會觸發「非法」的反射存取:

  • 通常情況下呼叫會失敗。
  • 運行時系統已啟用「非法存取」。

觸發警報的機制

Java 9 中封裝的放鬆可以透過新的啟動選項 --illegal-access 在編譯時控制。預設情況下,此選項設定為“允許”。在這種模式下,第一次對任何此類套件的反射存取操作將觸發警報,但此後不再發出警告。此警告包含有關如何啟用進一步警告的資訊。

設定選項

--illegal-access 選項可以設定為以下模式:

  • debug:為每次此類存取列印訊息和堆疊追蹤。
  • warn:為每次此類存取列印訊息。
  • deny:停用此類操作。

調試和修復建議

  • 使用--illegal-access=deny 運行應用程式以找出並避免在沒有任何模組聲明(包含此類指令的opens)或明確使用--add-opens VM 參數的情況下,從一個模組向另一個模組「開啟」套件。
  • 使用 jdeps 工具和 --jdk-internals 選項識別編譯程式碼中對 JDK 內部 API 的靜態引用。

警告訊息範例

非法反射存取操作偵測到時發出的警告訊息遵循以下格式:

WARNING: Illegal reflective access by $PERPETRATOR to $VICTIM
登入後複製

其中:

  • $PERPETRATOR:包含觸發反射操作的程式碼的類型的限定名稱,以及可用的程式碼來源(即JAR 檔案路徑)。
  • $VICTIM:描述所存取成員的字串,包括封閉類型的限定名稱。

預防措施

為了避免此類警告並確保將來的安全性,需要確保模組不會進行這些非法反射訪問。

以上是如何解決 Java 9 中的「非法反射存取」警告?的詳細內容。更多資訊請關注PHP中文網其他相關文章!

來源:php.cn
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
作者最新文章
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板