8271611: Use SecurityConstants.ACCESS_PERMISSION in MethodHandles

Reviewed-by: rriggs
This commit is contained in:
Claes Redestad 2021-08-02 15:34:56 +00:00
parent e74537f924
commit 7a4c754e5d

View File

@ -230,7 +230,7 @@ public class MethodHandles {
@SuppressWarnings("removal") @SuppressWarnings("removal")
SecurityManager sm = System.getSecurityManager(); SecurityManager sm = System.getSecurityManager();
if (sm != null) sm.checkPermission(ACCESS_PERMISSION); if (sm != null) sm.checkPermission(SecurityConstants.ACCESS_PERMISSION);
if (targetClass.isPrimitive()) if (targetClass.isPrimitive())
throw new IllegalArgumentException(targetClass + " is a primitive class"); throw new IllegalArgumentException(targetClass + " is a primitive class");
if (targetClass.isArray()) if (targetClass.isArray())
@ -443,13 +443,10 @@ public class MethodHandles {
public static <T extends Member> T reflectAs(Class<T> expected, MethodHandle target) { public static <T extends Member> T reflectAs(Class<T> expected, MethodHandle target) {
@SuppressWarnings("removal") @SuppressWarnings("removal")
SecurityManager smgr = System.getSecurityManager(); SecurityManager smgr = System.getSecurityManager();
if (smgr != null) smgr.checkPermission(ACCESS_PERMISSION); if (smgr != null) smgr.checkPermission(SecurityConstants.ACCESS_PERMISSION);
Lookup lookup = Lookup.IMPL_LOOKUP; // use maximally privileged lookup Lookup lookup = Lookup.IMPL_LOOKUP; // use maximally privileged lookup
return lookup.revealDirect(target).reflectAs(expected, lookup); return lookup.revealDirect(target).reflectAs(expected, lookup);
} }
// Copied from AccessibleObject, as used by Method.setAccessible, etc.:
private static final java.security.Permission ACCESS_PERMISSION =
new ReflectPermission("suppressAccessChecks");
/** /**
* A <em>lookup object</em> is a factory for creating method handles, * A <em>lookup object</em> is a factory for creating method handles,