How Can I Resolve 'Illegal Reflective Access' Warnings in Java 9?
Illegal Reflective Access in Java 9: A Detailed Examination
Java 9 introduced the concept of illegal reflective access, which triggered zahlreichen on how to solve it Questions about this error message. This article will delve into the nature of illegal reflective access, the circumstances that trigger alerts, and possible solutions.
The module system in Java 9 introduces the concept of modularity#relaxing strong encapsulation, which is the key to understanding illegal reflective access. Access by code in a module to other module code and visible packages is strictly controlled. However, for облегчить переход на Java 9, the strong encapsulation of modules can be relaxed.
The runtime system can provide the following operations:
- Static access: Provided through compiled bytecode.
- Runtime calls: allows calling its runtime system with one or more packages of one or more modules as code in all unnamed modules Open.
The concept of illegal access
If the reflection API is successfully called under the following circumstances, "illegal" reflection access will be triggered:
- Normally the call will fail.
- "Illegal access" is enabled in the runtime system.
Mechanism for triggering alerts
Relaxation of encapsulation in Java 9 can be controlled at compile time via the new startup option --illegal-access. By default, this option is set to Allow. In this mode, the first reflected access operation to any such package will trigger an alert, but no further warnings will be issued. This warning contains information on how to enable further warnings.
Configuration options
The --illegal-access option can be configured in the following modes:
- debug: print for each such access Messages and stack traces.
- warn: Print a message for each such access.
- deny: Disable this type of operation.
Debugging and Repair Recommendations
- Run the application with --illegal-access=deny to find out and avoid module declarations without any ( "opens" a package from one module to another, including opens of such a directive, or explicitly using the --add-opens VM argument.
- Use the jdeps tool with the --jdk-internals option to identify static references to JDK internal APIs in compiled code.
Warning message example
A warning message that is emitted when an illegal reflective access operation is detected follows the following format:
WARNING: Illegal reflective access by $PERPETRATOR to $VICTIM
where:
- $PERPETRATOR: the qualified name of the type containing the code that triggers the reflection operation, and the available source of the code (i.e. JAR file path).
- $VICTIM: A string describing the member being accessed, including the qualified name of the enclosing type.
Precautions
To avoid such warnings and ensure future security, you need to ensure that modules do not make these illegal reflective accesses.
The above is the detailed content of How Can I Resolve 'Illegal Reflective Access' Warnings in Java 9?. For more information, please follow other related articles on the PHP Chinese website!

Hot AI Tools

Undresser.AI Undress
AI-powered app for creating realistic nude photos

AI Clothes Remover
Online AI tool for removing clothes from photos.

Undress AI Tool
Undress images for free

Clothoff.io
AI clothes remover

Video Face Swap
Swap faces in any video effortlessly with our completely free AI face swap tool!

Hot Article

Hot Tools

Notepad++7.3.1
Easy-to-use and free code editor

SublimeText3 Chinese version
Chinese version, very easy to use

Zend Studio 13.0.1
Powerful PHP integrated development environment

Dreamweaver CS6
Visual web development tools

SublimeText3 Mac version
God-level code editing software (SublimeText3)

Hot Topics

Troubleshooting and solutions to the company's security software that causes some applications to not function properly. Many companies will deploy security software in order to ensure internal network security. ...

Field mapping processing in system docking often encounters a difficult problem when performing system docking: how to effectively map the interface fields of system A...

When using MyBatis-Plus or other ORM frameworks for database operations, it is often necessary to construct query conditions based on the attribute name of the entity class. If you manually every time...

Solutions to convert names to numbers to implement sorting In many application scenarios, users may need to sort in groups, especially in one...

Start Spring using IntelliJIDEAUltimate version...

Conversion of Java Objects and Arrays: In-depth discussion of the risks and correct methods of cast type conversion Many Java beginners will encounter the conversion of an object into an array...

Detailed explanation of the design of SKU and SPU tables on e-commerce platforms This article will discuss the database design issues of SKU and SPU in e-commerce platforms, especially how to deal with user-defined sales...

When using TKMyBatis for database queries, how to gracefully get entity class variable names to build query conditions is a common problem. This article will pin...
