mirror of
https://github.com/EsotericSoftware/reflectasm.git
synced 2025-01-07 18:30:22 +08:00
Fixed classes not have protected domain.
This commit is contained in:
parent
db3e7d7c78
commit
3841c03c99
@ -2,6 +2,7 @@
|
|||||||
package com.esotericsoftware.reflectasm;
|
package com.esotericsoftware.reflectasm;
|
||||||
|
|
||||||
import java.lang.reflect.Method;
|
import java.lang.reflect.Method;
|
||||||
|
import java.security.ProtectionDomain;
|
||||||
import java.util.ArrayList;
|
import java.util.ArrayList;
|
||||||
|
|
||||||
class AccessClassLoader extends ClassLoader {
|
class AccessClassLoader extends ClassLoader {
|
||||||
@ -46,9 +47,10 @@ class AccessClassLoader extends ClassLoader {
|
|||||||
try {
|
try {
|
||||||
// Attempt to load the access class in the same loader, which makes protected and default access members accessible.
|
// Attempt to load the access class in the same loader, which makes protected and default access members accessible.
|
||||||
Method method = ClassLoader.class.getDeclaredMethod("defineClass", new Class[] {String.class, byte[].class, int.class,
|
Method method = ClassLoader.class.getDeclaredMethod("defineClass", new Class[] {String.class, byte[].class, int.class,
|
||||||
int.class});
|
int.class, ProtectionDomain.class});
|
||||||
method.setAccessible(true);
|
method.setAccessible(true);
|
||||||
return (Class)method.invoke(getParent(), new Object[] {name, bytes, Integer.valueOf(0), Integer.valueOf(bytes.length)});
|
return (Class)method.invoke(getParent(), new Object[] {name, bytes, Integer.valueOf(0), Integer.valueOf(bytes.length),
|
||||||
|
getClass().getProtectionDomain()});
|
||||||
} catch (Exception ignored) {
|
} catch (Exception ignored) {
|
||||||
}
|
}
|
||||||
return defineClass(name, bytes, 0, bytes.length);
|
return defineClass(name, bytes, 0, bytes.length);
|
||||||
|
Loading…
Reference in New Issue
Block a user