- iOS/Objective-C 元类和类别
- objective-c - -1001 错误,当 NSURLSession 通过 httpproxy 和/etc/hosts
- java - 使用网络类获取 url 地址
- ios - 推送通知中不播放声音
我正在弄清楚如何在没有权限的情况下运行外部代码(来自不同的 JAR),这样它就不会损害我自己的系统。我几乎可以正常工作了,但是我发现了一个奇怪的情况,即调用 System.exit(0)
仍然会杀死整个系统。
想法是不同的 JAR 将在多线程环境中加载,因此 System.exit(0)
成功是可能发生的最坏情况,还有许多其他安全风险在服务器上。
我有以下代码(在 SSCEE 中):
public class RestrictAccessControlContext {
private static final PermissionCollection ALLOWED_PERMISSIONS = new Permissions();
static {
//add permissions
}
private static final AccessControlContext RESTRICTED_ACCESS_CONTROL_CONTEXT =
new AccessControlContext(new ProtectionDomain[] { new ProtectionDomain(null, ALLOWED_PERMISSIONS)});
private static void executeSandboxed(final Runnable runnable) {
ExecutorService executorService = Executors.newSingleThreadExecutor();
Future<?> future = executorService.submit(() -> {
AccessController.doPrivileged((PrivilegedAction<Void>)() -> {
runnable.run();
return null;
}, RESTRICTED_ACCESS_CONTROL_CONTEXT);
});
try {
future.get();
} catch (InterruptedException ex) {
Thread.currentThread().interrupt();
} catch (ExecutionException ex) {
throw new RuntimeException(ex.getCause());
} finally {
executorService.shutdown();
}
}
public static void main(String[] args) {
executeSandboxed(() -> {
AccessController.doPrivileged((PrivilegedAction<Void>)() -> {
System.exit(0);
return null;
});
});
}
}
您需要将其作为 VM 参数运行:
-Djava.security.manager -Djava.security.policy=src/java.policy
java.policy
是:
grant {
permission java.security.AllPermission;
};
我的想法是,我自己的代码仍然具有完全权限,但沙盒代码具有受限(在本例中:无)权限。
但是在给定的示例中它只是退出,请注意主要方法的以下变体确实起作用:
public static void main(String[] args) {
executeSandboxed(() -> System.exit(0));
}
和
public static void main(String[] args) {
executeSandboxed(() -> new Thread(() -> System.exit(0)).start());
}
我在这里做错了什么,为什么可以执行提升权限的 AccessController.doPrivileged
调用,而之前权限已被限制?我希望以下情况之一为真:
AccessController.doPrivileged
的特定权限。AccessController.doPrivileged
block 中,权限将是“父级”AccessControlContext
和给定权限的交集。这两个选项都会导致给定的代码正确地抛出一个 AccessControlException
,但它并没有发生,为什么会这样?
最佳答案
您没有任何沙盒代码。您的代码具有完全权限,正在使用它们。没有相关权限的代码将无法退出。解决方案应该是使用不受信任的 ProtectionDomain
加载不受信任的代码。
拥有提高权限的权限是没有意义的。这相当于拥有所有权限。
在 OpenJDK 内部有一个 doPrivileged
的变体,它允许权限交叉,但这是为了在存在多个不信任源时降低权限。
关于java - 为什么我可以使用 AccessController.doPrivileged 突破受限的 AccessControlContext?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/26329793/
我想跳出 .each() 迭代,但它不允许我这样做。这是我的代码。感谢您的帮助!欣赏它。 $('#btn-submit-add').click(function(){ var answerFi
假设我们有 Seq val ourSeq = Seq(10,5,3,5,4)。 我想返回一个新的列表,它从左边读取并在看到重复的数字时停止(例如 Seq(10,5,3) 因为 5 是重复的)。 我正在
当满足这样的条件时,我需要打破 seq 映射,其中 foo将返回一个对象列表,其中大小取决于找到 targetId 所需的时间 def foo(ids: Seq[String], targetId:
正在研究如何防止 iframe 跳出下一页。 http://www.virginaustralia.com/au/en/ 该页面在 iframe 中加载正常,但当我去搜索航类时,由于反 iframe
在斯卡拉 2.8 ,在 scala.collection.package.scala 中有一个对象: def breakOut[From, T, To](implicit b : CanBuildFr
我有以下疑问:是否可以使用鼠标监听器将“鼠标左键单击事件”超出组件的限制?或者我应该用另一种方法尝试这个? 我的问题如下。我正在创建一个适合我的项目的所见即所得面板。该面板与另一个面板是同级的,后者显
我在我的 Mac 上使用了两个 emacs(Aquamcs 和基于文本的 emacs)。我通常使用基于文本的 emacs 只是编辑一些东西,所以我不想用它加载任何东西。 我想出的是让 .emacs 中
请耐心等待,因为这是我的第一个主要 Python 项目。 我正尝试在 Python 中创建一个实用程序来协助 SteamCMD 功能。对于那些不了解 SteamCMD 或其功能的人来说,它本质上是一个
有没有办法绕过 MySQL 中 1024 字节的 key 大小限制?基本上,这在尝试执行复合索引时会造成严重破坏。 最佳答案 虽然我犹豫是否建议您做错了什么(因为我没有完整的细节),但单个 key (
所以我想弄清楚如何完全打破 C++ 中的递归函数。 在示例中,我有一个二维数组,其中包含正确的必要信息。在没有递归的情况下,一切都按预期工作 - 返回 time[start] 的部分中断了函数。 在递
我有这个简单的代码可以从控制台读取所有输入: input := bufio.NewScanner(os.Stdin) //Creating a Scanner that will read the i
我有一个 foreach 循环和一个 if 语句。如果找到匹配项,我需要最终突破 foreach。 foreach ($equipxml as $equip) { $current_devic
我正在关注文章中链接的以下 youtube 视频,该视频允许 docker 容器在主机上获得 root 访问权限。 有几个步骤不清楚,有人可以解释一下它们是如何进一步工作的吗? https://www
_.filter(this.pluck(key),function(item){ return item ? value.toLowerCase() === item.toLowerCase(
好吧,我的设置工作方式是这样的。 将新子项添加到数据库后 .on("child_added"...像这样被解雇: ref.on("child_added", function(snapshot, pr
receiveResponse 调用处于阻塞状态,当我在单独的线程上运行代码时,我希望能够随时干净地停止线程。文档显示 abort() 可能是我需要的,但我找不到任何信息表明它是否是线程安全的。谢谢,
我正在学习 XNA Break Out 克隆教程,我正在为 Windows Phone 编程。本教程在球和砖 block 的碰撞检测完成之前结束。积木按行和列放在屏幕上。我得到了 Racket 的边界
-- 编辑-- 我最近遇到了一件关于 promises 的奇怪事情,但我想这可能是因为它违反了 promises 的哲学。 考虑以下代码: // Assuming Auth is just a sim
我目前正在开发一个 Chrome 扩展程序,它模仿 Firefox 响应式设计 View 的行为和功能。 一切都快完成了,并且总体运行良好。然而,我遇到了一个问题,如果可能的话,我想避免它。我使用了一
关闭。这个问题需要更多 focused .它目前不接受答案。 想要改进这个问题吗? 更新问题,使其只关注一个问题 editing this post . 关闭 7 年前。 Improve this q
我是一名优秀的程序员,十分优秀!