8344065: Remove SecurityManager uses from the java.datatransfer module

Reviewed-by: serb
This commit is contained in:
Phil Race 2024-11-15 04:51:55 +00:00
parent db56266ad1
commit 99070658fd
3 changed files with 14 additions and 32 deletions

View File

@ -313,7 +313,6 @@ module java.base {
java.desktop; java.desktop;
exports sun.reflect.misc to exports sun.reflect.misc to
java.desktop, java.desktop,
java.datatransfer,
java.management, java.management,
java.management.rmi, java.management.rmi,
java.rmi, java.rmi,

View File

@ -45,7 +45,6 @@ import java.util.Collections;
import java.util.Objects; import java.util.Objects;
import sun.datatransfer.DataFlavorUtil; import sun.datatransfer.DataFlavorUtil;
import sun.reflect.misc.ReflectUtil;
/** /**
* A {@code DataFlavor} provides meta information about data. {@code DataFlavor} * A {@code DataFlavor} provides meta information about data. {@code DataFlavor}
@ -131,32 +130,22 @@ public class DataFlavor implements Externalizable, Cloneable {
ClassLoader fallback) ClassLoader fallback)
throws ClassNotFoundException throws ClassNotFoundException
{ {
ReflectUtil.checkPackageAccess(className); ClassLoader loader = ClassLoader.getSystemClassLoader();
try { try {
@SuppressWarnings("removal") // bootstrap class loader and system class loader if present
SecurityManager sm = System.getSecurityManager(); return Class.forName(className, true, loader);
if (sm != null) { }
sm.checkPermission(new RuntimePermission("getClassLoader")); catch (ClassNotFoundException exception) {
} // thread context class loader if and only if present
ClassLoader loader = ClassLoader.getSystemClassLoader(); loader = Thread.currentThread().getContextClassLoader();
try { if (loader != null) {
// bootstrap class loader and system class loader if present try {
return Class.forName(className, true, loader); return Class.forName(className, true, loader);
} }
catch (ClassNotFoundException exception) { catch (ClassNotFoundException e) {
// thread context class loader if and only if present // fallback to user's class loader
loader = Thread.currentThread().getContextClassLoader();
if (loader != null) {
try {
return Class.forName(className, true, loader);
}
catch (ClassNotFoundException e) {
// fallback to user's class loader
}
} }
} }
} catch (SecurityException exception) {
// ignore secured class loaders
} }
return Class.forName(className, true, fallback); return Class.forName(className, true, fallback);
} }

View File

@ -30,8 +30,6 @@ import java.io.IOException;
import java.io.InputStream; import java.io.InputStream;
import java.io.InputStreamReader; import java.io.InputStreamReader;
import java.lang.ref.SoftReference; import java.lang.ref.SoftReference;
import java.security.AccessController;
import java.security.PrivilegedAction;
import java.util.ArrayList; import java.util.ArrayList;
import java.util.Collections; import java.util.Collections;
import java.util.HashMap; import java.util.HashMap;
@ -202,12 +200,8 @@ public final class SystemFlavorMap implements FlavorMap, FlavorTable {
} }
isMapInitialized = true; isMapInitialized = true;
@SuppressWarnings("removal") InputStream is = SystemFlavorMap.class.getResourceAsStream(
InputStream is = AccessController.doPrivileged(
(PrivilegedAction<InputStream>) () -> {
return SystemFlavorMap.class.getResourceAsStream(
"/sun/datatransfer/resources/flavormap.properties"); "/sun/datatransfer/resources/flavormap.properties");
});
if (is == null) { if (is == null) {
throw new InternalError("Default flavor mapping not found"); throw new InternalError("Default flavor mapping not found");
} }