Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
openanolis
dragonwell8_jdk
提交
74914b1d
D
dragonwell8_jdk
项目概览
openanolis
/
dragonwell8_jdk
通知
4
Star
2
Fork
0
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
D
dragonwell8_jdk
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
提交
Issue看板
提交
74914b1d
编写于
10月 22, 2013
作者:
M
mullan
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
8021191: Add isAuthorized check to limited doPrivileged methods
Reviewed-by: weijun, xuelei
上级
6ca2973a
变更
2
隐藏空白更改
内联
并排
Showing
2 changed file
with
52 addition
and
8 deletion
+52
-8
src/share/classes/java/security/AccessControlContext.java
src/share/classes/java/security/AccessControlContext.java
+4
-0
src/share/classes/java/security/AccessController.java
src/share/classes/java/security/AccessController.java
+48
-8
未找到文件。
src/share/classes/java/security/AccessControlContext.java
浏览文件 @
74914b1d
...
@@ -350,6 +350,10 @@ public final class AccessControlContext {
...
@@ -350,6 +350,10 @@ public final class AccessControlContext {
return
combiner
;
return
combiner
;
}
}
boolean
isAuthorized
()
{
return
isAuthorized
;
}
/**
/**
* Determines whether the access request indicated by the
* Determines whether the access request indicated by the
* specified permission should be allowed or denied, based on
* specified permission should be allowed or denied, based on
...
...
src/share/classes/java/security/AccessController.java
浏览文件 @
74914b1d
...
@@ -344,9 +344,10 @@ public final class AccessController {
...
@@ -344,9 +344,10 @@ public final class AccessController {
* If the action's {@code run} method throws an (unchecked) exception,
* If the action's {@code run} method throws an (unchecked) exception,
* it will propagate through this method.
* it will propagate through this method.
* <p>
* <p>
* If a security manager is installed and the {@code AccessControlContext}
* If a security manager is installed and the specified
* was not created by system code and the caller's {@code ProtectionDomain}
* {@code AccessControlContext} was not created by system code and the
* has not been granted the {@literal "createAccessControlContext"}
* caller's {@code ProtectionDomain} has not been granted the
* {@literal "createAccessControlContext"}
* {@link java.security.SecurityPermission}, then the action is performed
* {@link java.security.SecurityPermission}, then the action is performed
* with no permissions.
* with no permissions.
*
*
...
@@ -384,6 +385,13 @@ public final class AccessController {
...
@@ -384,6 +385,13 @@ public final class AccessController {
* <p>
* <p>
* If the action's {@code run} method throws an (unchecked) exception,
* If the action's {@code run} method throws an (unchecked) exception,
* it will propagate through this method.
* it will propagate through this method.
* <p>
* If a security manager is installed and the specified
* {@code AccessControlContext} was not created by system code and the
* caller's {@code ProtectionDomain} has not been granted the
* {@literal "createAccessControlContext"}
* {@link java.security.SecurityPermission}, then the action is performed
* with no permissions.
*
*
* @param <T> the type of the value returned by the PrivilegedAction's
* @param <T> the type of the value returned by the PrivilegedAction's
* {@code run} method.
* {@code run} method.
...
@@ -438,6 +446,13 @@ public final class AccessController {
...
@@ -438,6 +446,13 @@ public final class AccessController {
*
*
* <p> This method preserves the current AccessControlContext's
* <p> This method preserves the current AccessControlContext's
* DomainCombiner (which may be null) while the action is performed.
* DomainCombiner (which may be null) while the action is performed.
* <p>
* If a security manager is installed and the specified
* {@code AccessControlContext} was not created by system code and the
* caller's {@code ProtectionDomain} has not been granted the
* {@literal "createAccessControlContext"}
* {@link java.security.SecurityPermission}, then the action is performed
* with no permissions.
*
*
* @param <T> the type of the value returned by the PrivilegedAction's
* @param <T> the type of the value returned by the PrivilegedAction's
* {@code run} method.
* {@code run} method.
...
@@ -571,8 +586,18 @@ public final class AccessController {
...
@@ -571,8 +586,18 @@ public final class AccessController {
AccessControlContext
parent
,
AccessControlContext
context
,
AccessControlContext
parent
,
AccessControlContext
context
,
Permission
[]
perms
)
Permission
[]
perms
)
{
{
return
new
AccessControlContext
(
getCallerPD
(
caller
),
combiner
,
parent
,
ProtectionDomain
callerPD
=
getCallerPD
(
caller
);
context
,
perms
);
// check if caller is authorized to create context
if
(
context
!=
null
&&
!
context
.
isAuthorized
()
&&
System
.
getSecurityManager
()
!=
null
&&
!
callerPD
.
impliesCreateAccessControlContext
())
{
ProtectionDomain
nullPD
=
new
ProtectionDomain
(
null
,
null
);
return
new
AccessControlContext
(
new
ProtectionDomain
[]
{
nullPD
});
}
else
{
return
new
AccessControlContext
(
callerPD
,
combiner
,
parent
,
context
,
perms
);
}
}
}
private
static
ProtectionDomain
getCallerPD
(
final
Class
<?>
caller
)
{
private
static
ProtectionDomain
getCallerPD
(
final
Class
<?>
caller
)
{
...
@@ -597,9 +622,10 @@ public final class AccessController {
...
@@ -597,9 +622,10 @@ public final class AccessController {
* If the action's {@code run} method throws an <i>unchecked</i>
* If the action's {@code run} method throws an <i>unchecked</i>
* exception, it will propagate through this method.
* exception, it will propagate through this method.
* <p>
* <p>
* If a security manager is installed and the {@code AccessControlContext}
* If a security manager is installed and the specified
* was not created by system code and the caller's {@code ProtectionDomain}
* {@code AccessControlContext} was not created by system code and the
* has not been granted the {@literal "createAccessControlContext"}
* caller's {@code ProtectionDomain} has not been granted the
* {@literal "createAccessControlContext"}
* {@link java.security.SecurityPermission}, then the action is performed
* {@link java.security.SecurityPermission}, then the action is performed
* with no permissions.
* with no permissions.
*
*
...
@@ -641,6 +667,13 @@ public final class AccessController {
...
@@ -641,6 +667,13 @@ public final class AccessController {
* <p>
* <p>
* If the action's {@code run} method throws an (unchecked) exception,
* If the action's {@code run} method throws an (unchecked) exception,
* it will propagate through this method.
* it will propagate through this method.
* <p>
* If a security manager is installed and the specified
* {@code AccessControlContext} was not created by system code and the
* caller's {@code ProtectionDomain} has not been granted the
* {@literal "createAccessControlContext"}
* {@link java.security.SecurityPermission}, then the action is performed
* with no permissions.
*
*
* @param <T> the type of the value returned by the
* @param <T> the type of the value returned by the
* PrivilegedExceptionAction's {@code run} method.
* PrivilegedExceptionAction's {@code run} method.
...
@@ -697,6 +730,13 @@ public final class AccessController {
...
@@ -697,6 +730,13 @@ public final class AccessController {
*
*
* <p> This method preserves the current AccessControlContext's
* <p> This method preserves the current AccessControlContext's
* DomainCombiner (which may be null) while the action is performed.
* DomainCombiner (which may be null) while the action is performed.
* <p>
* If a security manager is installed and the specified
* {@code AccessControlContext} was not created by system code and the
* caller's {@code ProtectionDomain} has not been granted the
* {@literal "createAccessControlContext"}
* {@link java.security.SecurityPermission}, then the action is performed
* with no permissions.
*
*
* @param <T> the type of the value returned by the
* @param <T> the type of the value returned by the
* PrivilegedExceptionAction's {@code run} method.
* PrivilegedExceptionAction's {@code run} method.
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录