提交 3c1270f5 编写于 作者: S sherman

8014217: Base64.getXDecoder().wrap(...).read() doesn't throw exception for an...

8014217: Base64.getXDecoder().wrap(...).read() doesn't throw exception for an incorrect number of padding chars in the final unit
Summary: to throw IOE for malformed final unit in base64 stream
Reviewed-by: chegar, alanb
上级 2de47b57
...@@ -625,7 +625,8 @@ public class Base64 { ...@@ -625,7 +625,8 @@ public class Base64 {
* character(s) padded), they are decoded as if followed by padding * character(s) padded), they are decoded as if followed by padding
* character(s). If there is padding character present in the * character(s). If there is padding character present in the
* final unit, the correct number of padding character(s) must be * final unit, the correct number of padding character(s) must be
* present, otherwise {@code IllegalArgumentException} is thrown * present, otherwise {@code IllegalArgumentException} (
* {@code IOException} when reading from a Base64 stream) is thrown
* during decoding. * during decoding.
* *
* <p> Instances of {@link Decoder} class are safe for use by * <p> Instances of {@link Decoder} class are safe for use by
...@@ -1306,7 +1307,12 @@ public class Base64 { ...@@ -1306,7 +1307,12 @@ public class Base64 {
return off - oldOff; return off - oldOff;
} }
if (v == '=') { // padding byte(s) if (v == '=') { // padding byte(s)
if (nextin != 6 && nextin != 0) { // = shiftto==18 unnecessary padding
// x= shiftto==12 invalid unit
// xx= shiftto==6 && missing last '='
// xx=y or last is not '='
if (nextin == 18 || nextin == 12 ||
nextin == 6 && is.read() != '=') {
throw new IOException("Illegal base64 ending sequence:" + nextin); throw new IOException("Illegal base64 ending sequence:" + nextin);
} }
b[off++] = (byte)(bits >> (16)); b[off++] = (byte)(bits >> (16));
......
...@@ -23,6 +23,7 @@ ...@@ -23,6 +23,7 @@
/** /**
* @test 4235519 8004212 8005394 8007298 8006295 8006315 8006530 8007379 8008925 * @test 4235519 8004212 8005394 8007298 8006295 8006315 8006530 8007379 8008925
* 8014217
* @summary tests java.util.Base64 * @summary tests java.util.Base64
*/ */
...@@ -110,6 +111,14 @@ public class TestBase64 { ...@@ -110,6 +111,14 @@ public class TestBase64 {
// illegal ending unit // illegal ending unit
checkIAE(new Runnable() { public void run() { Base64.getMimeDecoder().decode("$=#"); }}); checkIAE(new Runnable() { public void run() { Base64.getMimeDecoder().decode("$=#"); }});
checkIOE(new Testable() { public void test() throws IOException {
byte[] bytes = "AA=".getBytes("ASCII");
try (InputStream stream =
Base64.getDecoder().wrap(new ByteArrayInputStream(bytes))) {
while (stream.read() != -1);
}
}});
// test return value from decode(ByteBuffer, ByteBuffer) // test return value from decode(ByteBuffer, ByteBuffer)
testDecBufRet(); testDecBufRet();
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册