Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
openanolis
dragonwell8_jdk
提交
8cbb29a9
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看板
提交
8cbb29a9
编写于
4月 22, 2013
作者:
S
smarks
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
8008132: Better serialization support
Reviewed-by: alanb, hawtin
上级
944c3a8c
变更
3
隐藏空白更改
内联
并排
Showing
3 changed file
with
45 addition
and
0 deletion
+45
-0
src/share/classes/java/io/ObjectOutputStream.java
src/share/classes/java/io/ObjectOutputStream.java
+13
-0
src/share/classes/java/io/ObjectStreamClass.java
src/share/classes/java/io/ObjectStreamClass.java
+8
-0
src/share/classes/java/io/ObjectStreamField.java
src/share/classes/java/io/ObjectStreamField.java
+24
-0
未找到文件。
src/share/classes/java/io/ObjectOutputStream.java
浏览文件 @
8cbb29a9
...
...
@@ -36,6 +36,7 @@ import java.util.concurrent.ConcurrentHashMap;
import
java.util.concurrent.ConcurrentMap
;
import
static
java
.
io
.
ObjectStreamClass
.
processQueue
;
import
java.io.SerialCallbackContext
;
import
sun.reflect.misc.ReflectUtil
;
/**
* An ObjectOutputStream writes primitive data types and graphs of Java objects
...
...
@@ -1228,6 +1229,12 @@ public class ObjectOutputStream
}
}
private
boolean
isCustomSubclass
()
{
// Return true if this class is a custom subclass of ObjectOutputStream
return
getClass
().
getClassLoader
()
!=
ObjectOutputStream
.
class
.
getClassLoader
();
}
/**
* Writes class descriptor representing a dynamic proxy class to stream.
*/
...
...
@@ -1245,6 +1252,9 @@ public class ObjectOutputStream
}
bout
.
setBlockDataMode
(
true
);
if
(
isCustomSubclass
())
{
ReflectUtil
.
checkPackageAccess
(
cl
);
}
annotateProxyClass
(
cl
);
bout
.
setBlockDataMode
(
false
);
bout
.
writeByte
(
TC_ENDBLOCKDATA
);
...
...
@@ -1271,6 +1281,9 @@ public class ObjectOutputStream
Class
<?>
cl
=
desc
.
forClass
();
bout
.
setBlockDataMode
(
true
);
if
(
isCustomSubclass
())
{
ReflectUtil
.
checkPackageAccess
(
cl
);
}
annotateClass
(
cl
);
bout
.
setBlockDataMode
(
false
);
bout
.
writeByte
(
TC_ENDBLOCKDATA
);
...
...
src/share/classes/java/io/ObjectStreamClass.java
浏览文件 @
8cbb29a9
...
...
@@ -50,6 +50,7 @@ import java.util.concurrent.ConcurrentHashMap;
import
java.util.concurrent.ConcurrentMap
;
import
sun.misc.Unsafe
;
import
sun.reflect.ReflectionFactory
;
import
sun.reflect.misc.ReflectUtil
;
/**
* Serialization's descriptor for classes. It contains the name and
...
...
@@ -259,6 +260,13 @@ public class ObjectStreamClass implements Serializable {
* @return the <code>Class</code> instance that this descriptor represents
*/
public
Class
<?>
forClass
()
{
if
(
cl
==
null
)
{
return
null
;
}
ClassLoader
ccl
=
ObjectStreamField
.
getCallerClassLoader
();
if
(
ReflectUtil
.
needsPackageAccessCheck
(
ccl
,
cl
.
getClassLoader
()))
{
ReflectUtil
.
checkPackageAccess
(
cl
);
}
return
cl
;
}
...
...
src/share/classes/java/io/ObjectStreamField.java
浏览文件 @
8cbb29a9
...
...
@@ -26,6 +26,8 @@
package
java.io
;
import
java.lang.reflect.Field
;
import
sun.reflect.Reflection
;
import
sun.reflect.misc.ReflectUtil
;
/**
* A description of a Serializable field from a Serializable class. An array
...
...
@@ -158,9 +160,31 @@ public class ObjectStreamField
* serializable field
*/
public
Class
<?>
getType
()
{
ClassLoader
ccl
=
getCallerClassLoader
();
if
(
ReflectUtil
.
needsPackageAccessCheck
(
ccl
,
type
.
getClassLoader
()))
{
ReflectUtil
.
checkPackageAccess
(
type
);
}
return
type
;
}
// Returns the invoker's class loader.
// This is package private because it is accessed from ObjectStreamClass.
// NOTE: This must always be invoked when there is exactly one intervening
// frame from the core libraries on the stack between this method's
// invocation and the desired invoker. The frame count of 3 is determined
// as follows:
//
// 0: Reflection.getCallerClass
// 1: getCallerClassLoader()
// 2: ObjectStreamField.getType() or ObjectStreamClass.forClass()
// 3: the caller we want to check
//
// NOTE: copied from java.lang.ClassLoader and modified.
static
ClassLoader
getCallerClassLoader
()
{
Class
caller
=
Reflection
.
getCallerClass
(
3
);
return
caller
.
getClassLoader
();
}
/**
* Returns character encoding of field type. The encoding is as follows:
* <blockquote><pre>
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录