Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
openanolis
dragonwell8_jdk
提交
fb96db84
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看板
提交
fb96db84
编写于
8月 24, 2012
作者:
M
mchung
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
7193339: Prepare system classes be defined by a non-null module loader
Reviewed-by: alanb, dholmes, dsamersoff, sspitsyn, psandoz
上级
b1da5910
变更
13
隐藏空白更改
内联
并排
Showing
13 changed file
with
82 addition
and
21 deletion
+82
-21
src/share/classes/com/sun/jmx/mbeanserver/MXBeanMapping.java
src/share/classes/com/sun/jmx/mbeanserver/MXBeanMapping.java
+1
-1
src/share/classes/com/sun/jmx/remote/internal/IIOPHelper.java
...share/classes/com/sun/jmx/remote/internal/IIOPHelper.java
+2
-1
src/share/classes/java/lang/Class.java
src/share/classes/java/lang/Class.java
+4
-4
src/share/classes/java/lang/ClassLoader.java
src/share/classes/java/lang/ClassLoader.java
+19
-2
src/share/classes/java/lang/Thread.java
src/share/classes/java/lang/Thread.java
+1
-2
src/share/classes/java/lang/management/ManagementFactory.java
...share/classes/java/lang/management/ManagementFactory.java
+6
-6
src/share/classes/java/lang/management/PlatformComponent.java
...share/classes/java/lang/management/PlatformComponent.java
+2
-1
src/share/classes/java/util/prefs/Preferences.java
src/share/classes/java/util/prefs/Preferences.java
+2
-1
src/share/classes/javax/script/ScriptEngineManager.java
src/share/classes/javax/script/ScriptEngineManager.java
+1
-1
src/share/classes/sun/management/MappedMXBeanType.java
src/share/classes/sun/management/MappedMXBeanType.java
+1
-1
src/share/classes/sun/misc/Unsafe.java
src/share/classes/sun/misc/Unsafe.java
+1
-1
src/share/classes/sun/misc/VM.java
src/share/classes/sun/misc/VM.java
+8
-0
src/share/classes/sun/reflect/misc/ReflectUtil.java
src/share/classes/sun/reflect/misc/ReflectUtil.java
+34
-0
未找到文件。
src/share/classes/com/sun/jmx/mbeanserver/MXBeanMapping.java
浏览文件 @
fb96db84
...
@@ -169,7 +169,7 @@ public abstract class MXBeanMapping {
...
@@ -169,7 +169,7 @@ public abstract class MXBeanMapping {
return
(
Class
<?>)
javaType
;
return
(
Class
<?>)
javaType
;
try
{
try
{
String
className
=
openType
.
getClassName
();
String
className
=
openType
.
getClassName
();
return
Class
.
forName
(
className
,
false
,
null
);
return
Class
.
forName
(
className
,
false
,
MXBeanMapping
.
class
.
getClassLoader
()
);
}
catch
(
ClassNotFoundException
e
)
{
}
catch
(
ClassNotFoundException
e
)
{
throw
new
RuntimeException
(
e
);
// should not happen
throw
new
RuntimeException
(
e
);
// should not happen
}
}
...
...
src/share/classes/com/sun/jmx/remote/internal/IIOPHelper.java
浏览文件 @
fb96db84
...
@@ -52,7 +52,8 @@ public final class IIOPHelper {
...
@@ -52,7 +52,8 @@ public final class IIOPHelper {
AccessController
.
doPrivileged
(
new
PrivilegedAction
<
IIOPProxy
>()
{
AccessController
.
doPrivileged
(
new
PrivilegedAction
<
IIOPProxy
>()
{
public
IIOPProxy
run
()
{
public
IIOPProxy
run
()
{
try
{
try
{
Class
<?>
c
=
Class
.
forName
(
IMPL_CLASS
,
true
,
null
);
Class
<?>
c
=
Class
.
forName
(
IMPL_CLASS
,
true
,
IIOPHelper
.
class
.
getClassLoader
());
return
(
IIOPProxy
)
c
.
newInstance
();
return
(
IIOPProxy
)
c
.
newInstance
();
}
catch
(
ClassNotFoundException
cnf
)
{
}
catch
(
ClassNotFoundException
cnf
)
{
return
null
;
return
null
;
...
...
src/share/classes/java/lang/Class.java
浏览文件 @
fb96db84
...
@@ -228,7 +228,8 @@ public final
...
@@ -228,7 +228,8 @@ public final
* ensure it's ok to access the bootstrap class loader.
* ensure it's ok to access the bootstrap class loader.
*
*
* @param name fully qualified name of the desired class
* @param name fully qualified name of the desired class
* @param initialize whether the class must be initialized
* @param initialize if {@code true} the class will be initialized.
* See Section 12.4 of <em>The Java Language Specification</em>.
* @param loader class loader from which the class must be loaded
* @param loader class loader from which the class must be loaded
* @return class object representing the desired class
* @return class object representing the desired class
*
*
...
@@ -605,7 +606,7 @@ public final
...
@@ -605,7 +606,7 @@ public final
SecurityManager
sm
=
System
.
getSecurityManager
();
SecurityManager
sm
=
System
.
getSecurityManager
();
if
(
sm
!=
null
)
{
if
(
sm
!=
null
)
{
ClassLoader
ccl
=
ClassLoader
.
getCallerClassLoader
();
ClassLoader
ccl
=
ClassLoader
.
getCallerClassLoader
();
if
(
ccl
!=
null
&&
ccl
!=
cl
&&
!
cl
.
isAncestor
(
c
cl
))
{
if
(
ClassLoader
.
needsClassLoaderPermissionCheck
(
ccl
,
cl
))
{
sm
.
checkPermission
(
SecurityConstants
.
GET_CLASSLOADER_PERMISSION
);
sm
.
checkPermission
(
SecurityConstants
.
GET_CLASSLOADER_PERMISSION
);
}
}
}
}
...
@@ -2170,8 +2171,7 @@ public final
...
@@ -2170,8 +2171,7 @@ public final
if
(
s
!=
null
)
{
if
(
s
!=
null
)
{
s
.
checkMemberAccess
(
this
,
which
);
s
.
checkMemberAccess
(
this
,
which
);
ClassLoader
cl
=
getClassLoader0
();
ClassLoader
cl
=
getClassLoader0
();
if
((
ccl
!=
null
)
&&
(
ccl
!=
cl
)
&&
if
(
sun
.
reflect
.
misc
.
ReflectUtil
.
needsPackageAccessCheck
(
ccl
,
cl
))
{
((
cl
==
null
)
||
!
cl
.
isAncestor
(
ccl
)))
{
String
name
=
this
.
getName
();
String
name
=
this
.
getName
();
int
i
=
name
.
lastIndexOf
(
'.'
);
int
i
=
name
.
lastIndexOf
(
'.'
);
if
(
i
!=
-
1
)
{
if
(
i
!=
-
1
)
{
...
...
src/share/classes/java/lang/ClassLoader.java
浏览文件 @
fb96db84
...
@@ -1403,7 +1403,7 @@ public abstract class ClassLoader {
...
@@ -1403,7 +1403,7 @@ public abstract class ClassLoader {
SecurityManager
sm
=
System
.
getSecurityManager
();
SecurityManager
sm
=
System
.
getSecurityManager
();
if
(
sm
!=
null
)
{
if
(
sm
!=
null
)
{
ClassLoader
ccl
=
getCallerClassLoader
();
ClassLoader
ccl
=
getCallerClassLoader
();
if
(
ccl
!=
null
&&
!
isAncestor
(
ccl
))
{
if
(
needsClassLoaderPermissionCheck
(
ccl
,
this
))
{
sm
.
checkPermission
(
SecurityConstants
.
GET_CLASSLOADER_PERMISSION
);
sm
.
checkPermission
(
SecurityConstants
.
GET_CLASSLOADER_PERMISSION
);
}
}
}
}
...
@@ -1473,7 +1473,7 @@ public abstract class ClassLoader {
...
@@ -1473,7 +1473,7 @@ public abstract class ClassLoader {
SecurityManager
sm
=
System
.
getSecurityManager
();
SecurityManager
sm
=
System
.
getSecurityManager
();
if
(
sm
!=
null
)
{
if
(
sm
!=
null
)
{
ClassLoader
ccl
=
getCallerClassLoader
();
ClassLoader
ccl
=
getCallerClassLoader
();
if
(
ccl
!=
null
&&
ccl
!=
scl
&&
!
scl
.
isAncestor
(
c
cl
))
{
if
(
needsClassLoaderPermissionCheck
(
ccl
,
s
cl
))
{
sm
.
checkPermission
(
SecurityConstants
.
GET_CLASSLOADER_PERMISSION
);
sm
.
checkPermission
(
SecurityConstants
.
GET_CLASSLOADER_PERMISSION
);
}
}
}
}
...
@@ -1523,6 +1523,23 @@ public abstract class ClassLoader {
...
@@ -1523,6 +1523,23 @@ public abstract class ClassLoader {
return
false
;
return
false
;
}
}
// Tests if class loader access requires "getClassLoader" permission
// check. A class loader 'from' can access class loader 'to' if
// class loader 'from' is same as class loader 'to' or an ancestor
// of 'to'. The class loader in a system domain can access
// any class loader.
static
boolean
needsClassLoaderPermissionCheck
(
ClassLoader
from
,
ClassLoader
to
)
{
if
(
from
==
to
)
return
false
;
if
(
from
==
null
)
return
false
;
return
!
to
.
isAncestor
(
from
);
}
// Returns the invoker's class loader, or null if none.
// Returns the invoker's class loader, or null if none.
// NOTE: This must always be invoked when there is exactly one intervening
// NOTE: This must always be invoked when there is exactly one intervening
// frame from the core libraries on the stack between this method's
// frame from the core libraries on the stack between this method's
...
...
src/share/classes/java/lang/Thread.java
浏览文件 @
fb96db84
...
@@ -1449,8 +1449,7 @@ class Thread implements Runnable {
...
@@ -1449,8 +1449,7 @@ class Thread implements Runnable {
SecurityManager
sm
=
System
.
getSecurityManager
();
SecurityManager
sm
=
System
.
getSecurityManager
();
if
(
sm
!=
null
)
{
if
(
sm
!=
null
)
{
ClassLoader
ccl
=
ClassLoader
.
getCallerClassLoader
();
ClassLoader
ccl
=
ClassLoader
.
getCallerClassLoader
();
if
(
ccl
!=
null
&&
ccl
!=
contextClassLoader
&&
if
(
ClassLoader
.
needsClassLoaderPermissionCheck
(
ccl
,
contextClassLoader
))
{
!
contextClassLoader
.
isAncestor
(
ccl
))
{
sm
.
checkPermission
(
SecurityConstants
.
GET_CLASSLOADER_PERMISSION
);
sm
.
checkPermission
(
SecurityConstants
.
GET_CLASSLOADER_PERMISSION
);
}
}
}
}
...
...
src/share/classes/java/lang/management/ManagementFactory.java
浏览文件 @
fb96db84
...
@@ -576,16 +576,16 @@ public class ManagementFactory {
...
@@ -576,16 +576,16 @@ public class ManagementFactory {
Class
<
T
>
mxbeanInterface
)
Class
<
T
>
mxbeanInterface
)
throws
java
.
io
.
IOException
{
throws
java
.
io
.
IOException
{
final
Class
<?>
interfaceClass
=
mxbeanInterface
;
// Only allow MXBean interfaces from rt.jar loaded by the
// Only allow MXBean interfaces from rt.jar loaded by the
// bootstrap class loader
// bootstrap class loader
final
ClassLoader
loader
=
final
Class
<?>
cls
=
mxbeanInterface
;
ClassLoader
loader
=
AccessController
.
doPrivileged
(
new
PrivilegedAction
<
ClassLoader
>()
{
AccessController
.
doPrivileged
(
new
PrivilegedAction
<
ClassLoader
>()
{
public
ClassLoader
run
()
{
public
ClassLoader
run
()
{
return
interfaceClas
s
.
getClassLoader
();
return
cl
s
.
getClassLoader
();
}
}
});
});
if
(
loader
!=
null
)
{
if
(
!
sun
.
misc
.
VM
.
isSystemDomainLoader
(
loader
)
)
{
throw
new
IllegalArgumentException
(
mxbeanName
+
throw
new
IllegalArgumentException
(
mxbeanName
+
" is not a platform MXBean"
);
" is not a platform MXBean"
);
}
}
...
@@ -593,10 +593,10 @@ public class ManagementFactory {
...
@@ -593,10 +593,10 @@ public class ManagementFactory {
try
{
try
{
final
ObjectName
objName
=
new
ObjectName
(
mxbeanName
);
final
ObjectName
objName
=
new
ObjectName
(
mxbeanName
);
// skip the isInstanceOf check for LoggingMXBean
// skip the isInstanceOf check for LoggingMXBean
String
intfName
=
interfaceClass
.
getName
();
String
intfName
=
mxbeanInterface
.
getName
();
if
(!
connection
.
isInstanceOf
(
objName
,
intfName
))
{
if
(!
connection
.
isInstanceOf
(
objName
,
intfName
))
{
throw
new
IllegalArgumentException
(
mxbeanName
+
throw
new
IllegalArgumentException
(
mxbeanName
+
" is not an instance of "
+
interfaceClass
);
" is not an instance of "
+
mxbeanInterface
);
}
}
final
Class
[]
interfaces
;
final
Class
[]
interfaces
;
...
...
src/share/classes/java/lang/management/PlatformComponent.java
浏览文件 @
fb96db84
...
@@ -363,7 +363,8 @@ enum PlatformComponent {
...
@@ -363,7 +363,8 @@ enum PlatformComponent {
try
{
try
{
// Lazy loading the MXBean interface only when it is needed
// Lazy loading the MXBean interface only when it is needed
return
(
Class
<?
extends
PlatformManagedObject
>)
return
(
Class
<?
extends
PlatformManagedObject
>)
Class
.
forName
(
mxbeanInterfaceName
,
false
,
null
);
Class
.
forName
(
mxbeanInterfaceName
,
false
,
PlatformManagedObject
.
class
.
getClassLoader
());
}
catch
(
ClassNotFoundException
x
)
{
}
catch
(
ClassNotFoundException
x
)
{
throw
new
AssertionError
(
x
);
throw
new
AssertionError
(
x
);
}
}
...
...
src/share/classes/java/util/prefs/Preferences.java
浏览文件 @
fb96db84
...
@@ -300,7 +300,8 @@ public abstract class Preferences {
...
@@ -300,7 +300,8 @@ public abstract class Preferences {
}
}
try
{
try
{
return
(
PreferencesFactory
)
return
(
PreferencesFactory
)
Class
.
forName
(
platformFactory
,
false
,
null
).
newInstance
();
Class
.
forName
(
platformFactory
,
false
,
Preferences
.
class
.
getClassLoader
()).
newInstance
();
}
catch
(
Exception
e
)
{
}
catch
(
Exception
e
)
{
throw
new
InternalError
(
throw
new
InternalError
(
"Can't instantiate platform default Preferences factory "
"Can't instantiate platform default Preferences factory "
...
...
src/share/classes/javax/script/ScriptEngineManager.java
浏览文件 @
fb96db84
...
@@ -423,7 +423,7 @@ public class ScriptEngineManager {
...
@@ -423,7 +423,7 @@ public class ScriptEngineManager {
SecurityManager
sm
=
System
.
getSecurityManager
();
SecurityManager
sm
=
System
.
getSecurityManager
();
if
(
sm
!=
null
)
{
if
(
sm
!=
null
)
{
ClassLoader
callerLoader
=
getCallerClassLoader
();
ClassLoader
callerLoader
=
getCallerClassLoader
();
if
(
callerLoader
!=
null
)
{
if
(
!
sun
.
misc
.
VM
.
isSystemDomainLoader
(
callerLoader
)
)
{
if
(
loader
!=
callerLoader
||
!
isAncestor
(
loader
,
callerLoader
))
{
if
(
loader
!=
callerLoader
||
!
isAncestor
(
loader
,
callerLoader
))
{
try
{
try
{
sm
.
checkPermission
(
SecurityConstants
.
GET_CLASSLOADER_PERMISSION
);
sm
.
checkPermission
(
SecurityConstants
.
GET_CLASSLOADER_PERMISSION
);
...
...
src/share/classes/sun/management/MappedMXBeanType.java
浏览文件 @
fb96db84
...
@@ -803,7 +803,7 @@ public abstract class MappedMXBeanType {
...
@@ -803,7 +803,7 @@ public abstract class MappedMXBeanType {
Class
<?>
c
;
Class
<?>
c
;
try
{
try
{
c
=
Class
.
forName
(
t
.
getClassName
(),
false
,
c
=
Class
.
forName
(
t
.
getClassName
(),
false
,
String
.
class
.
getClassLoader
());
MappedMXBeanType
.
class
.
getClassLoader
());
MappedMXBeanType
.
newBasicType
(
c
,
t
);
MappedMXBeanType
.
newBasicType
(
c
,
t
);
}
catch
(
ClassNotFoundException
e
)
{
}
catch
(
ClassNotFoundException
e
)
{
// the classes that these predefined types declare
// the classes that these predefined types declare
...
...
src/share/classes/sun/misc/Unsafe.java
浏览文件 @
fb96db84
...
@@ -82,7 +82,7 @@ public final class Unsafe {
...
@@ -82,7 +82,7 @@ public final class Unsafe {
*/
*/
public
static
Unsafe
getUnsafe
()
{
public
static
Unsafe
getUnsafe
()
{
Class
<?>
cc
=
sun
.
reflect
.
Reflection
.
getCallerClass
(
2
);
Class
<?>
cc
=
sun
.
reflect
.
Reflection
.
getCallerClass
(
2
);
if
(
cc
.
getClassLoader
()
!=
null
)
if
(
!
VM
.
isSystemDomainLoader
(
cc
.
getClassLoader
())
)
throw
new
SecurityException
(
"Unsafe"
);
throw
new
SecurityException
(
"Unsafe"
);
return
theUnsafe
;
return
theUnsafe
;
}
}
...
...
src/share/classes/sun/misc/VM.java
浏览文件 @
fb96db84
...
@@ -217,6 +217,14 @@ public class VM {
...
@@ -217,6 +217,14 @@ public class VM {
return
allowArraySyntax
;
return
allowArraySyntax
;
}
}
/**
* Returns true if the given class loader is in the system domain
* in which all permissions are granted.
*/
public
static
boolean
isSystemDomainLoader
(
ClassLoader
loader
)
{
return
loader
==
null
;
}
/**
/**
* Returns the system property of the specified key saved at
* Returns the system property of the specified key saved at
* system initialization time. This method should only be used
* system initialization time. This method should only be used
...
...
src/share/classes/sun/reflect/misc/ReflectUtil.java
浏览文件 @
fb96db84
...
@@ -144,4 +144,38 @@ public final class ReflectUtil {
...
@@ -144,4 +144,38 @@ public final class ReflectUtil {
}
}
return
true
;
return
true
;
}
}
// Returns true if p is an ancestor of cl i.e. class loader 'p' can
// be found in the cl's delegation chain
private
static
boolean
isAncestor
(
ClassLoader
p
,
ClassLoader
cl
)
{
ClassLoader
acl
=
cl
;
do
{
acl
=
acl
.
getParent
();
if
(
p
==
acl
)
{
return
true
;
}
}
while
(
acl
!=
null
);
return
false
;
}
/**
* Returns true if package access check is needed for reflective
* access from a class loader 'from' to classes or members in
* a class defined by class loader 'to'. This method returns true
* if 'from' is not the same as or an ancestor of 'to'. All code
* in a system domain are granted with all permission and so this
* method returns false if 'from' class loader is a class loader
* loading system classes. On the other hand, if a class loader
* attempts to access system domain classes, it requires package
* access check and this method will return true.
*/
public
static
boolean
needsPackageAccessCheck
(
ClassLoader
from
,
ClassLoader
to
)
{
if
(
from
==
null
||
from
==
to
)
return
false
;
if
(
to
==
null
)
return
true
;
return
!
isAncestor
(
from
,
to
);
}
}
}
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录