Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
openanolis
dragonwell11
提交
9dda70fc
D
dragonwell11
项目概览
openanolis
/
dragonwell11
通知
7
Star
2
Fork
0
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
D
dragonwell11
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
提交
Issue看板
体验新版 GitCode,发现更多精彩内容 >>
提交
9dda70fc
编写于
4月 09, 2018
作者:
A
apetcher
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
8200332: Improve GCM counting
Reviewed-by: ascarpino
上级
5291c2d3
变更
1
隐藏空白更改
内联
并排
Showing
1 changed file
with
31 addition
and
2 deletion
+31
-2
src/java.base/share/classes/com/sun/crypto/provider/GCTR.java
...java.base/share/classes/com/sun/crypto/provider/GCTR.java
+31
-2
未找到文件。
src/java.base/share/classes/com/sun/crypto/provider/GCTR.java
浏览文件 @
9dda70fc
/*
* Copyright (c) 2013, 201
7
, Oracle and/or its affiliates. All rights reserved.
* Copyright (c) 2013, 201
8
, Oracle and/or its affiliates. All rights reserved.
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
*
* This code is free software; you can redistribute it and/or modify it
...
...
@@ -29,6 +29,8 @@
package
com.sun.crypto.provider
;
import
java.nio.ByteBuffer
;
import
java.nio.ByteOrder
;
import
javax.crypto.IllegalBlockSizeException
;
import
static
com
.
sun
.
crypto
.
provider
.
AESConstants
.
AES_BLOCK_SIZE
;
...
...
@@ -68,6 +70,15 @@ final class GCTR extends CounterMode {
return
"GCTR"
;
}
// return the number of blocks until the lower 32 bits roll over
private
long
blocksUntilRollover
()
{
ByteBuffer
buf
=
ByteBuffer
.
wrap
(
counter
,
counter
.
length
-
4
,
4
);
buf
.
order
(
ByteOrder
.
BIG_ENDIAN
);
long
ctr32
=
0xFFFFFFFF
L
&
buf
.
getInt
();
long
blocksLeft
=
(
1L
<<
32
)
-
ctr32
;
return
blocksLeft
;
}
// input must be multiples of 128-bit blocks when calling update
int
update
(
byte
[]
in
,
int
inOfs
,
int
inLen
,
byte
[]
out
,
int
outOfs
)
{
if
(
inLen
-
inOfs
>
in
.
length
)
{
...
...
@@ -80,7 +91,25 @@ final class GCTR extends CounterMode {
throw
new
RuntimeException
(
"output buffer too small"
);
}
return
encrypt
(
in
,
inOfs
,
inLen
,
out
,
outOfs
);
long
blocksLeft
=
blocksUntilRollover
();
int
numOfCompleteBlocks
=
inLen
/
AES_BLOCK_SIZE
;
if
(
numOfCompleteBlocks
>=
blocksLeft
)
{
// Counter Mode encryption cannot be used because counter will
// roll over incorrectly. Use GCM-specific code instead.
byte
[]
encryptedCntr
=
new
byte
[
AES_BLOCK_SIZE
];
for
(
int
i
=
0
;
i
<
numOfCompleteBlocks
;
i
++)
{
embeddedCipher
.
encryptBlock
(
counter
,
0
,
encryptedCntr
,
0
);
for
(
int
n
=
0
;
n
<
AES_BLOCK_SIZE
;
n
++)
{
int
index
=
(
i
*
AES_BLOCK_SIZE
+
n
);
out
[
outOfs
+
index
]
=
(
byte
)
((
in
[
inOfs
+
index
]
^
encryptedCntr
[
n
]));
}
GaloisCounterMode
.
increment32
(
counter
);
}
return
inLen
;
}
else
{
return
encrypt
(
in
,
inOfs
,
inLen
,
out
,
outOfs
);
}
}
// input can be arbitrary size when calling doFinal
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录