java.security.AccessControlException: access denied ("java.util.PropertyPermission" "java.net.preferIPv4Stack" "read") is thrown after upgrading JDK and Oracle JDBC driver
Issue
After upgrading JDK and Oracle JDBC, my application isn't unable to access the Oracle Database due to the following exception. Is the JDK upgrade the cause?
Exception in thread "main" java.lang.ExceptionInInitializerError
at oracle.net.nt.TcpNTAdapter.connect(TcpNTAdapter.java:285)
at oracle.net.nt.ConnOption.connect(ConnOption.java:198)
at oracle.net.nt.ConnStrategy.execute(ConnStrategy.java:675)
at oracle.net.resolver.AddrResolution.resolveAndExecute(AddrResolution.java:588)
at oracle.net.ns.NSProtocol.establishConnection(NSProtocol.java:729)
at oracle.net.ns.NSProtocol.connect(NSProtocol.java:340)
at oracle.jdbc.driver.T4CConnection.connect(T4CConnection.java:1714)
at oracle.jdbc.driver.T4CConnection.logon(T4CConnection.java:627)
at oracle.jdbc.driver.PhysicalConnection.connect(PhysicalConnection.java:821)
at oracle.jdbc.driver.T4CDriverExtension.getConnection(T4CDriverExtension.java:80)
at oracle.jdbc.driver.OracleDriver.connect(OracleDriver.java:820)
at oracle.jdbc.driver.OracleDriver.connect(OracleDriver.java:624)
at java.sql/java.sql.DriverManager.getConnection(DriverManager.java:683)
at java.sql/java.sql.DriverManager.getConnection(DriverManager.java:230)
at com.redhat.gss.example.OracleDbTest.main(OracleDbTest.java:13)
Caused by: java.security.AccessControlException: access denied ("java.util.PropertyPermission" "java.net.preferIPv4Stack" "read")
at java.base/java.security.AccessControlContext.checkPermission(AccessControlContext.java:488)
at java.base/java.security.AccessController.checkPermission(AccessController.java:1071)
at java.base/java.lang.SecurityManager.checkPermission(SecurityManager.java:411)
at java.base/java.lang.SecurityManager.checkPropertyAccess(SecurityManager.java:1146)
at java.base/java.lang.System.getProperty(System.java:967)
at oracle.net.nt.TcpFastOpen.lambda$init$1(TcpFastOpen.java:98)
at java.base/java.security.AccessController.doPrivileged(AccessController.java:571)
at oracle.net.nt.TcpFastOpen.init(TcpFastOpen.java:95)
at oracle.net.nt.TimeoutSocketChannel.<clinit>(TimeoutSocketChannel.java:99)
... 15 more
Environment
- Red Hat build of OpenJDK
- 8, 11, 17, 21
- Security Manager enabled
- Oracle JDBC
- 19.23+
Subscriber exclusive content
A Red Hat subscription provides unlimited access to our knowledgebase, tools, and much more.