提交 5840e558 编写于 作者: W weijun

8238804: Enhance key handling process

Reviewed-by: rriggs, mullan, ahgross, rhalade
上级 bfc9e8dc
/* /*
* Copyright (c) 1996, 2017, Oracle and/or its affiliates. All rights reserved. * Copyright (c) 1996, 2020, Oracle and/or its affiliates. All rights reserved.
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
* *
* This code is free software; you can redistribute it and/or modify it * This code is free software; you can redistribute it and/or modify it
...@@ -459,8 +459,10 @@ public abstract class MessageDigest extends MessageDigestSpi { ...@@ -459,8 +459,10 @@ public abstract class MessageDigest extends MessageDigestSpi {
* the same length and all bytes at corresponding positions are equal. * the same length and all bytes at corresponding positions are equal.
* *
* @implNote * @implNote
* If the digests are the same length, all bytes are examined to * All bytes in {@code digesta} are examined to determine equality.
* determine equality. * The calculation time depends only on the length of {@code digesta}.
* It does not depend on the length of {@code digestb} or the contents
* of {@code digesta} and {@code digestb}.
* *
* @param digesta one of the digests to compare. * @param digesta one of the digests to compare.
* *
...@@ -473,14 +475,22 @@ public abstract class MessageDigest extends MessageDigestSpi { ...@@ -473,14 +475,22 @@ public abstract class MessageDigest extends MessageDigestSpi {
if (digesta == null || digestb == null) { if (digesta == null || digestb == null) {
return false; return false;
} }
if (digesta.length != digestb.length) {
return false; int lenA = digesta.length;
int lenB = digestb.length;
if (lenB == 0) {
return lenA == 0;
} }
int result = 0; int result = 0;
result |= lenA - lenB;
// time-constant comparison // time-constant comparison
for (int i = 0; i < digesta.length; i++) { for (int i = 0; i < lenA; i++) {
result |= digesta[i] ^ digestb[i]; // If i >= lenB, indexB is 0; otherwise, i.
int indexB = ((i - lenB) >>> 31) * i;
result |= digesta[i] ^ digestb[indexB];
} }
return result == 0; return result == 0;
} }
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册