Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
openanolis
dragonwell8_jdk
提交
c28d73ad
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看板
提交
c28d73ad
编写于
3月 18, 2013
作者:
D
dfuchs
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
8001043: Clarify definition restrictions
Reviewed-by: alanb, skoivu, smarks
上级
7565cf52
变更
1
隐藏空白更改
内联
并排
Showing
1 changed file
with
28 addition
and
4 deletion
+28
-4
src/share/classes/sun/rmi/server/LoaderHandler.java
src/share/classes/sun/rmi/server/LoaderHandler.java
+28
-4
未找到文件。
src/share/classes/sun/rmi/server/LoaderHandler.java
浏览文件 @
c28d73ad
...
...
@@ -55,6 +55,7 @@ import java.util.IdentityHashMap;
import
java.util.Map
;
import
java.util.StringTokenizer
;
import
java.util.WeakHashMap
;
import
sun.reflect.misc.ReflectUtil
;
import
sun.rmi.runtime.Log
;
import
sun.security.action.GetPropertyAction
;
...
...
@@ -170,7 +171,7 @@ public final class LoaderHandler {
if
(
defaultLoader
!=
null
)
{
try
{
Class
<?>
c
=
Class
.
f
orName
(
name
,
false
,
defaultLoader
);
Class
<?>
c
=
loadClassF
orName
(
name
,
false
,
defaultLoader
);
if
(
loaderLog
.
isLoggable
(
Log
.
VERBOSE
))
{
loaderLog
.
log
(
Log
.
VERBOSE
,
"class \""
+
name
+
"\" found via defaultLoader, "
+
...
...
@@ -422,7 +423,7 @@ public final class LoaderHandler {
* resolved without the security-offending codebase anyway;
* if so, return successfully (see bugids 4191926 & 4349670).
*/
Class
<?>
c
=
Class
.
f
orName
(
name
,
false
,
parent
);
Class
<?>
c
=
loadClassF
orName
(
name
,
false
,
parent
);
if
(
loaderLog
.
isLoggable
(
Log
.
VERBOSE
))
{
loaderLog
.
log
(
Log
.
VERBOSE
,
"class \""
+
name
+
"\" found via "
+
...
...
@@ -448,7 +449,7 @@ public final class LoaderHandler {
}
try
{
Class
<?>
c
=
Class
.
f
orName
(
name
,
false
,
loader
);
Class
<?>
c
=
loadClassF
orName
(
name
,
false
,
loader
);
if
(
loaderLog
.
isLoggable
(
Log
.
VERBOSE
))
{
loaderLog
.
log
(
Log
.
VERBOSE
,
"class \""
+
name
+
"\" "
+
"found via codebase, "
+
...
...
@@ -726,7 +727,7 @@ public final class LoaderHandler {
for
(
int
i
=
0
;
i
<
interfaces
.
length
;
i
++)
{
Class
<?>
cl
=
(
classObjs
[
i
]
=
Class
.
f
orName
(
interfaces
[
i
],
false
,
loader
));
(
classObjs
[
i
]
=
loadClassF
orName
(
interfaces
[
i
],
false
,
loader
));
if
(!
Modifier
.
isPublic
(
cl
.
getModifiers
()))
{
ClassLoader
current
=
cl
.
getClassLoader
();
...
...
@@ -1195,5 +1196,28 @@ public final class LoaderHandler {
public
String
toString
()
{
return
super
.
toString
()
+
"[\""
+
annotation
+
"\"]"
;
}
@Override
protected
Class
<?>
loadClass
(
String
name
,
boolean
resolve
)
throws
ClassNotFoundException
{
if
(
parent
==
null
)
{
ReflectUtil
.
checkPackageAccess
(
name
);
}
return
super
.
loadClass
(
name
,
resolve
);
}
}
private
static
Class
<?>
loadClassForName
(
String
name
,
boolean
initialize
,
ClassLoader
loader
)
throws
ClassNotFoundException
{
if
(
loader
==
null
)
{
ReflectUtil
.
checkPackageAccess
(
name
);
}
return
Class
.
forName
(
name
,
initialize
,
loader
);
}
}
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录