Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
openanolis
dragonwell8_jdk
提交
c49e2e93
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看板
提交
c49e2e93
编写于
10月 02, 2008
作者:
O
okutsu
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
6734167: Calendar.readObject allows elevation of privileges
Reviewed-by: peytoia
上级
bcb54426
变更
1
隐藏空白更改
内联
并排
Showing
1 changed file
with
42 addition
and
12 deletion
+42
-12
src/share/classes/java/util/Calendar.java
src/share/classes/java/util/Calendar.java
+42
-12
未找到文件。
src/share/classes/java/util/Calendar.java
浏览文件 @
c49e2e93
...
...
@@ -41,9 +41,14 @@ package java.util;
import
java.io.IOException
;
import
java.io.ObjectInputStream
;
import
java.io.ObjectOutputStream
;
import
java.io.OptionalDataException
;
import
java.io.Serializable
;
import
java.security.AccessControlContext
;
import
java.security.AccessController
;
import
java.security.PermissionCollection
;
import
java.security.PrivilegedActionException
;
import
java.security.PrivilegedExceptionAction
;
import
java.security.ProtectionDomain
;
import
java.text.DateFormat
;
import
java.text.DateFormatSymbols
;
import
sun.util.BuddhistCalendar
;
...
...
@@ -2626,6 +2631,18 @@ public abstract class Calendar implements Serializable, Cloneable, Comparable<Ca
}
}
private
static
class
CalendarAccessControlContext
{
private
static
final
AccessControlContext
INSTANCE
;
static
{
RuntimePermission
perm
=
new
RuntimePermission
(
"accessClassInPackage.sun.util.calendar"
);
PermissionCollection
perms
=
perm
.
newPermissionCollection
();
perms
.
add
(
perm
);
INSTANCE
=
new
AccessControlContext
(
new
ProtectionDomain
[]
{
new
ProtectionDomain
(
null
,
perms
)
});
}
}
/**
* Reconstitutes this object from a stream (i.e., deserialize it).
*/
...
...
@@ -2655,17 +2672,30 @@ public abstract class Calendar implements Serializable, Cloneable, Comparable<Ca
serialVersionOnStream
=
currentSerialVersion
;
// If there's a ZoneInfo object, use it for zone.
ZoneInfo
zi
=
null
;
try
{
ZoneInfo
zi
=
(
ZoneInfo
)
AccessController
.
doPrivileged
(
new
PrivilegedExceptionAction
()
{
public
Object
run
()
throws
Exception
{
return
input
.
readObject
();
}
});
if
(
zi
!=
null
)
{
zone
=
zi
;
zi
=
AccessController
.
doPrivileged
(
new
PrivilegedExceptionAction
<
ZoneInfo
>()
{
public
ZoneInfo
run
()
throws
Exception
{
return
(
ZoneInfo
)
input
.
readObject
();
}
},
CalendarAccessControlContext
.
INSTANCE
);
}
catch
(
PrivilegedActionException
pae
)
{
Exception
e
=
pae
.
getException
();
if
(!(
e
instanceof
OptionalDataException
))
{
if
(
e
instanceof
RuntimeException
)
{
throw
(
RuntimeException
)
e
;
}
else
if
(
e
instanceof
IOException
)
{
throw
(
IOException
)
e
;
}
else
if
(
e
instanceof
ClassNotFoundException
)
{
throw
(
ClassNotFoundException
)
e
;
}
throw
new
RuntimeException
(
e
);
}
}
catch
(
Exception
e
)
{
}
if
(
zi
!=
null
)
{
zone
=
zi
;
}
// If the deserialized object has a SimpleTimeZone, try to
...
...
@@ -2674,9 +2704,9 @@ public abstract class Calendar implements Serializable, Cloneable, Comparable<Ca
// implementation as much as possible.
if
(
zone
instanceof
SimpleTimeZone
)
{
String
id
=
zone
.
getID
();
TimeZone
zi
=
TimeZone
.
getTimeZone
(
id
);
if
(
zi
!=
null
&&
zi
.
hasSameRules
(
zone
)
&&
zi
.
getID
().
equals
(
id
))
{
zone
=
zi
;
TimeZone
tz
=
TimeZone
.
getTimeZone
(
id
);
if
(
tz
!=
null
&&
tz
.
hasSameRules
(
zone
)
&&
tz
.
getID
().
equals
(
id
))
{
zone
=
tz
;
}
}
}
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录