- Java 双重比较
- java - 比较器与 Apache BeanComparator
- Objective-C 完成 block 导致额外的方法调用?
- database - RESTful URI 是否应该公开数据库主键?
我正在查看一个被大量从 JavaScript 调用的签名 Applet。显然,与直接从 Java 内部启动的任何线程相比,源自 JavaScript 的线程受到更严格的沙箱化处理。例如,如果 JavaScript 线程调用 Applet 并记录导致日志文件滚动的内容,则会抛出安全异常。直接在 Applet 中启动的任何线程都不会遇到此安全异常。 log4j 的解决方案是使用异步附加程序。
但是对于其他安全异常(exception)情况(例如,在已签名的 Applet 中但在 JavaScript 线程中使用 Apache Axis),没有明显的方法来拥有一些异步线程。假设我有以下代码,如果从 Java 线程调用将有效,如果通过 JavaScript 调用将失败并抛出 SecurityException:
public void someMethodCalledFromJavaScript() {
// Stuff that would throw a SecurityException
}
我看到以下三个选项,但它们可能并不都有效。为了便于讨论,忽略执行是同步的还是异步的,因为这很容易管理。我很难理解安全模型的细节。这是我的三个可能的选择:
开始一个新线程(这个线程还能工作吗?):
public void someMethodCalledFromJavaScript() {
new Thread(new Runnable() {
public void run() {
// Stuff that would throw a SecurityException
}
}).start();
}
让 Applet 有一个随时准备运行的线程,通过 JavaScript 源线程(此处高度简化的代码)触发:
private volatile boolean doit = false;
// This code is running in a Thread, started @ Applet init time
public void alwaysWaiting() {
while (true) {
if (doit) {
doit = false;
// Stuff that would throw a SecurityException
}
}
}
public void someMethodCalledFromJavaScript() {
doit = true;
}
使用 AccessController.doPrivileged:
public void someMethodCalledFromJavaScript() {
AccessController.doPrivileged(new PrivilegedAction() {
public Object run() {
// Stuff that would throw a SecurityException
return null;
}
});
}
根据我对 AccessController.doPrivileged
的了解,您在当前安全权限与您正在调用的代码的安全域权限的交集下运行。这对我来说没有意义,就好像您在低安全域和高安全域的交集 上运行一样,您将只有低安全域。很明显我不明白什么。
我看到的具体 SecurityException
是这个:
java.security.AccessControlException: access denied (java.lang.RuntimePermission accessDeclaredMembers)
但是我当然很好奇在 JavaScript 调用已签名的 Applet 的上下文中的一般情况,以及我如何允许 JavaScript 发起的线程以已签名的 Applet 的特权运行,就好像它是一个线程一样完全起源于 Applet。
以上哪些选择甚至会起作用,哪些比其他选择更好,为什么。
最佳答案
由于以下原因无法工作
当然可以,但这比调用 doPrivileged
更痛苦,但在语义上具有相同的效果。
是的,这会起作用。
每次访问控制检查都会检查当前线程堆栈上所有堆栈帧的集合(包括递归地导致当前线程实例化的堆栈帧)。如果存在 doPrivileged
帧,则该帧之前的帧不包含在集合中(但包含实际的 doPrivileged
帧)。
如果正在检查的特权不在该集合中的每一帧中,则检查失败。
换句话说,一个线程的当前权限是这个集合中权限的交集。
因此,例如,如果特权代码 doPrivileged
尝试打开文件的一些非特权代码,则检查将失败。同样,如果非特权代码doPrivileged
打开文件的特权代码,检查将失败。但是,如果非特权代码调用特权代码,而特权代码依次调用 doPrivileged
来打开文件,则检查将成功。
理论上,您应该只能授予您的 Java 代码库所需的权限(可能访问某个独立目录),然后授予相同权限给将使用此特权代码的 JavaScript 代码,但我怀疑任何浏览器都具有此类功能。我很惊讶 JavaScript 甚至在 Java 之外的另一个保护域中运行。
我从未做过 JavaScript<->Java 互操作,但似乎无论您要做什么,都必须让 JavaScript 调用的方法在其整个主体上使用 doPrivileged
block 。
编辑:正如 Sami 所说,在特权代码中调用 doPrivileged
block 时要小心(并阅读他的回答)。
关于java - AccessController.doPrivileged 是否为 JavaScript 线程提供已签名 Applet 的权限?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/3632283/
我得到了这个printHashKey函数,它运行良好。 fun printHashKey() { try { val info : PackageInfo = packageM
如何使用正确的签名 key 为我的 Android 应用包签名? 最佳答案 我尝试在此处和 this question 中使用多个答案, 但不知何故我收到了这个错误,因为我的 android/app/
我的 gradle 文件中有这个: android { signingConfigs { mySigningConfig { keyAlias 'the
请至少选择一个签名版本以在 Android Studio 2.3 中使用 现在在 Android Studio 中生成一个签名的 APK 时,它显示了两个选项(复选框),即 1. V1(Jar 签名)
我想表示一些标量值(例如整数或字符串)通过它的实际值或一些 NA 值,然后存储它们在集合中(例如列表)。目的是处理缺失值。 为此,我实现了一个签名 module type Scalar = sig
为什么这不完全有效? sum :: (Num a, Num b) => a -> b -> c sum a b = a + b 当然,错误消息与签名有关,但我仍然不明白原因。 Couldn't mat
谢谢帮助,我的问题是关于从下面的代码中收到的 ax 值? mov al,22h mov cl,0fdh imul cl 真机结果:ff9a 我的预期:00:9a(通过二进制相乘) 第一个数字是 22h
我有一个注释: import java.lang.annotation.ElementType; import java.lang.annotation.Retention; import java.
我从对物体的思考中得出了一个术语。当我们扩展一个类时,扩展类将具有与父类相同的签名,因此术语 IS-A 来自...示例 class Foo{ } class Foo2 extends Foo{ } c
我需要在有符号整数和它们作为字节序列的内部表示之间进行转换。在 C 中,我使用的函数如下: unsigned char hibyte(unsigned short i) {return i>>8;}
我正在尝试使用给定的 RSA 参数对一些数据进行签名。 我给出了模数、指数、D、DP、DQ、P、Q 和 InverseQ。什么库或方法最容易使用来计算此签名。在 C# 中,一旦您提供参数,它们就会有一
这些签名之间有什么区别? T * f(T & identifier); T & f(T & identifier); T f(T & identifier); void f(T * identifie
这个问题在这里已经有了答案: 关闭 11 年前。 Possible Duplicate: Where and why do I have to put the “template” and “typ
我有一个签名,我需要在签名旁边添加图片。但我不确定 css 的确切程度和内容。目前它显示在文字下方,我应该把图片放在哪里?在相同的 tr 或 td 中?
查看 LinkedHashMap 的 JDK 源代码,我注意到这个类被声明为: public class LinkedHashMap extends HashMap im
背景:我继承了一个基于 linux 的嵌入式系统,其中包含一个 SMTP 代理和一些我不得不忍受的古怪限制。它位于 SMTP 客户端和服务器之间。当 SMTP 客户端连接时,代理会打开与服务器的连接,
这是 C++17 形式的规则 ([basic.lval]/8),但它在其他标准中看起来很相似(在 C++98 中是“lvalue”而不是“glvalue”): 8 If a program attem
我有一个注释: import java.lang.annotation.ElementType; import java.lang.annotation.Retention; import java.
我即将开展一个项目,希望使用电子签名板使用 C# 捕获客户的签名、在设备上显示文本等。 现在,在我开始做进一步的研究之前,我想向你们征求一些意见/建议,我应该使用哪些设备.. 我现在的要求非常笼统:我
呢喃自己在心中开始扩张地盘,仿佛制式地广播了三次。 漾起的涟绮,用谈不上精腻的手段。 拒绝天亮,却又贪恋着贪恋多情的日光。 川流不息的画面是他们,而我的落幕停在右脚,它渴望着下台,而我只剩自言
我是一名优秀的程序员,十分优秀!