在我的自定义数据集中,我使用RMI服务器中的构造函数来创建我的类的新实例。反射AccessControlException
Constructor<?> constructor = dynTable.getDeclaredConstructor(Class.class);
constructor.setAccessible(true); // <-- Exception here
... = constructor.newInstance(type);
constructor.setAccessible(false);
但是,如果我设置了SecurityManager
,则会在下面引发预期。
java.security.AccessControlException: access denied ("java.lang.reflect.ReflectPermission" "suppressAccessChecks")
at java.security.AccessControlContext.checkPermission(AccessControlContext.java:457)
at java.security.AccessController.checkPermission(AccessController.java:884)
at java.lang.SecurityManager.checkPermission(SecurityManager.java:549)
at java.lang.reflect.AccessibleObject.setAccessible(AccessibleObject.java:128)
at net.sviglas.meridian.task.DefaultDatasetConstructor$1.constructDataset(DefaultDatasetConstructor.java:45)
...
服务器端和客户端的策略文件:
grant {
permission java.security.AllPermission;
};
我给了允许的一切,但我仍然收到此安全异常。你知道为什么吗?
请勿对不是代码的文本使用代码格式。 – EJP