Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
openanolis
dragonwell8_jdk
提交
42d025ef
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看板
提交
42d025ef
编写于
7月 28, 2017
作者:
A
apetcher
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
8182387: Improve PKCS usage
Reviewed-by: valeriep
上级
6689aae9
变更
1
隐藏空白更改
内联
并排
Showing
1 changed file
with
12 addition
and
5 deletion
+12
-5
src/share/classes/sun/security/util/DerValue.java
src/share/classes/sun/security/util/DerValue.java
+12
-5
未找到文件。
src/share/classes/sun/security/util/DerValue.java
浏览文件 @
42d025ef
...
@@ -491,20 +491,27 @@ public class DerValue {
...
@@ -491,20 +491,27 @@ public class DerValue {
* @return the octet string held in this DER value
* @return the octet string held in this DER value
*/
*/
public
byte
[]
getOctetString
()
throws
IOException
{
public
byte
[]
getOctetString
()
throws
IOException
{
byte
[]
bytes
;
if
(
tag
!=
tag_OctetString
&&
!
isConstructed
(
tag_OctetString
))
{
if
(
tag
!=
tag_OctetString
&&
!
isConstructed
(
tag_OctetString
))
{
throw
new
IOException
(
throw
new
IOException
(
"DerValue.getOctetString, not an Octet String: "
+
tag
);
"DerValue.getOctetString, not an Octet String: "
+
tag
);
}
}
bytes
=
new
byte
[
length
];
// Note: do not attempt to call buffer.read(bytes) at all. There's a
// Note: do not tempt to call buffer.read(bytes) at all. There's a
// known bug that it returns -1 instead of 0.
// known bug that it returns -1 instead of 0.
if
(
length
==
0
)
{
if
(
length
==
0
)
{
return
bytes
;
return
new
byte
[
0
]
;
}
}
if
(
buffer
.
read
(
bytes
)
!=
length
)
// Only allocate the array if there are enough bytes available.
// This only works for ByteArrayInputStream.
// The assignment below ensures that buffer has the required type.
ByteArrayInputStream
arrayInput
=
buffer
;
if
(
arrayInput
.
available
()
<
length
)
{
throw
new
IOException
(
"short read on DerValue buffer"
);
throw
new
IOException
(
"short read on DerValue buffer"
);
}
byte
[]
bytes
=
new
byte
[
length
];
arrayInput
.
read
(
bytes
);
if
(
isConstructed
())
{
if
(
isConstructed
())
{
DerInputStream
in
=
new
DerInputStream
(
bytes
,
0
,
bytes
.
length
,
DerInputStream
in
=
new
DerInputStream
(
bytes
,
0
,
bytes
.
length
,
buffer
.
allowBER
);
buffer
.
allowBER
);
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录