Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
openanolis
dragonwell8_jdk
提交
652c6717
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看板
提交
652c6717
编写于
10月 01, 2010
作者:
A
alexp
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
6622002: UIDefault.ProxyLazyValue has unsafe reflection usage
Reviewed-by: malenkov
上级
060faea6
变更
2
隐藏空白更改
内联
并排
Showing
2 changed file
with
78 addition
and
0 deletion
+78
-0
src/share/classes/javax/swing/UIDefaults.java
src/share/classes/javax/swing/UIDefaults.java
+14
-0
test/javax/swing/UIDefaults/6622002/bug6622002.java
test/javax/swing/UIDefaults/6622002/bug6622002.java
+64
-0
未找到文件。
src/share/classes/javax/swing/UIDefaults.java
浏览文件 @
652c6717
...
...
@@ -52,6 +52,7 @@ import java.security.AccessControlContext;
import
java.security.PrivilegedAction
;
import
sun.reflect.misc.MethodUtil
;
import
sun.reflect.misc.ReflectUtil
;
import
sun.util.CoreResourceBundleControl
;
/**
...
...
@@ -1078,6 +1079,9 @@ public class UIDefaults extends Hashtable<Object,Object>
// In order to pick up the security policy in effect at the
// time of creation we use a doPrivileged with the
// AccessControlContext that was in place when this was created.
if
(
acc
==
null
&&
System
.
getSecurityManager
()
!=
null
)
{
throw
new
SecurityException
(
"null AccessControlContext"
);
}
return
AccessController
.
doPrivileged
(
new
PrivilegedAction
<
Object
>()
{
public
Object
run
()
{
try
{
...
...
@@ -1093,7 +1097,9 @@ public class UIDefaults extends Hashtable<Object,Object>
cl
=
ClassLoader
.
getSystemClassLoader
();
}
}
ReflectUtil
.
checkPackageAccess
(
className
);
c
=
Class
.
forName
(
className
,
true
,
(
ClassLoader
)
cl
);
checkAccess
(
c
.
getModifiers
());
if
(
methodName
!=
null
)
{
Class
[]
types
=
getClassArray
(
args
);
Method
m
=
c
.
getMethod
(
methodName
,
types
);
...
...
@@ -1101,6 +1107,7 @@ public class UIDefaults extends Hashtable<Object,Object>
}
else
{
Class
[]
types
=
getClassArray
(
args
);
Constructor
constructor
=
c
.
getConstructor
(
types
);
checkAccess
(
constructor
.
getModifiers
());
return
constructor
.
newInstance
(
args
);
}
}
catch
(
Exception
e
)
{
...
...
@@ -1115,6 +1122,13 @@ public class UIDefaults extends Hashtable<Object,Object>
},
acc
);
}
private
void
checkAccess
(
int
modifiers
)
{
if
(
System
.
getSecurityManager
()
!=
null
&&
!
Modifier
.
isPublic
(
modifiers
))
{
throw
new
SecurityException
(
"Resource is not accessible"
);
}
}
/*
* Coerce the array of class types provided into one which
* looks the way the Reflection APIs expect. This is done
...
...
test/javax/swing/UIDefaults/6622002/bug6622002.java
0 → 100644
浏览文件 @
652c6717
/*
* Copyright (c) 2010, Oracle and/or its affiliates. All rights reserved.
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
*
* This code is free software; you can redistribute it and/or modify it
* under the terms of the GNU General Public License version 2 only, as
* published by the Free Software Foundation.
*
* This code is distributed in the hope that it will be useful, but WITHOUT
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
* version 2 for more details (a copy is included in the LICENSE file that
* accompanied this code).
*
* You should have received a copy of the GNU General Public License version
* 2 along with this work; if not, write to the Free Software Foundation,
* Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
*
* Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
* or visit www.oracle.com if you need additional information or have any
* questions.
*/
/**
* @test
* @bug 6622002
* @author Alexander Potochkin
* @summary UIDefault.ProxyLazyValue has unsafe reflection usage
*/
import
javax.swing.*
;
public
class
bug6622002
{
public
static
void
main
(
String
[]
args
)
{
if
(
createPrivateValue
()
==
null
)
{
throw
new
RuntimeException
(
"The private value unexpectedly wasn't created"
);
}
if
(
createPublicValue
()
==
null
)
{
throw
new
RuntimeException
(
"The public value unexpectedly wasn't created"
);
}
System
.
setSecurityManager
(
new
SecurityManager
());
if
(
createPrivateValue
()
!=
null
)
{
throw
new
RuntimeException
(
"The private value was unexpectedly created"
);
}
if
(
createPublicValue
()
==
null
)
{
throw
new
RuntimeException
(
"The public value unexpectedly wasn't created"
);
}
}
private
static
Object
createPrivateValue
()
{
return
new
UIDefaults
.
ProxyLazyValue
(
"javax.swing.MultiUIDefaults"
).
createValue
(
null
);
}
private
static
Object
createPublicValue
()
{
return
new
UIDefaults
.
ProxyLazyValue
(
"javax.swing.UIDefaults"
).
createValue
(
null
);
}
}
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录