8182387: Improve PKCS usage

Reviewed-by: valeriep
This commit is contained in:
Adam Petcher 2017-07-28 18:20:43 +00:00
parent 5069e85826
commit 72e7522e88

View File

@ -490,20 +490,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);