8066904: NullPointerException when calling ImageIO.read(InputStream) with corrupt BMP
Reviewed-by: serb, prr
This commit is contained in:
parent
0d765d8e4c
commit
059474a6ee
@ -290,6 +290,8 @@ public class BMPImageReader extends ImageReader implements BMPConstants {
|
|||||||
imageType = VERSION_2_8_BIT;
|
imageType = VERSION_2_8_BIT;
|
||||||
} else if (bitsPerPixel == 24) {
|
} else if (bitsPerPixel == 24) {
|
||||||
imageType = VERSION_2_24_BIT;
|
imageType = VERSION_2_24_BIT;
|
||||||
|
} else {
|
||||||
|
throw new IIOException(I18N.getString("BMPImageReader8"));
|
||||||
}
|
}
|
||||||
|
|
||||||
// Read in the palette
|
// Read in the palette
|
||||||
@ -364,6 +366,9 @@ public class BMPImageReader extends ImageReader implements BMPConstants {
|
|||||||
metadata.redMask = redMask;
|
metadata.redMask = redMask;
|
||||||
metadata.greenMask = greenMask;
|
metadata.greenMask = greenMask;
|
||||||
metadata.blueMask = blueMask;
|
metadata.blueMask = blueMask;
|
||||||
|
} else {
|
||||||
|
throw new
|
||||||
|
IIOException(I18N.getString("BMPImageReader8"));
|
||||||
}
|
}
|
||||||
|
|
||||||
metadata.bmpVersion = VERSION_3;
|
metadata.bmpVersion = VERSION_3;
|
||||||
@ -375,6 +380,9 @@ public class BMPImageReader extends ImageReader implements BMPConstants {
|
|||||||
imageType = VERSION_3_NT_16_BIT;
|
imageType = VERSION_3_NT_16_BIT;
|
||||||
} else if (bitsPerPixel == 32) {
|
} else if (bitsPerPixel == 32) {
|
||||||
imageType = VERSION_3_NT_32_BIT;
|
imageType = VERSION_3_NT_32_BIT;
|
||||||
|
} else {
|
||||||
|
throw new
|
||||||
|
IIOException(I18N.getString("BMPImageReader8"));
|
||||||
}
|
}
|
||||||
|
|
||||||
// BitsField encoding
|
// BitsField encoding
|
||||||
@ -493,6 +501,9 @@ public class BMPImageReader extends ImageReader implements BMPConstants {
|
|||||||
greenMask = 0x0000FF00;
|
greenMask = 0x0000FF00;
|
||||||
blueMask = 0x000000FF;
|
blueMask = 0x000000FF;
|
||||||
}
|
}
|
||||||
|
} else {
|
||||||
|
throw new
|
||||||
|
IIOException(I18N.getString("BMPImageReader8"));
|
||||||
}
|
}
|
||||||
|
|
||||||
metadata.redMask = redMask;
|
metadata.redMask = redMask;
|
||||||
|
@ -23,6 +23,7 @@ BMPImageReader4=No ImageIO-style reader is found for
|
|||||||
BMPImageReader5=Input has not been set.
|
BMPImageReader5=Input has not been set.
|
||||||
BMPImageReader6=Unable to read the image header.
|
BMPImageReader6=Unable to read the image header.
|
||||||
BMPImageReader7=Invalid bitmap offset.
|
BMPImageReader7=Invalid bitmap offset.
|
||||||
|
BMPImageReader8=Invalid bits per pixel in image header.
|
||||||
BMPImageWriter0=Output is not an ImageOutputStream.
|
BMPImageWriter0=Output is not an ImageOutputStream.
|
||||||
BMPImageWriter1=The image region to be encoded is empty.
|
BMPImageWriter1=The image region to be encoded is empty.
|
||||||
BMPImageWriter2=Only 1 or 3 band image is encoded.
|
BMPImageWriter2=Only 1 or 3 band image is encoded.
|
||||||
|
65
jdk/test/javax/imageio/plugins/bmp/Bug8066904.java
Normal file
65
jdk/test/javax/imageio/plugins/bmp/Bug8066904.java
Normal file
@ -0,0 +1,65 @@
|
|||||||
|
/*
|
||||||
|
* Copyright (c) 2015, 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
|
||||||
|
* under the terms of the GNU General Public License version 2 only, as
|
||||||
|
* published by the Free Software Foundation.
|
||||||
|
*
|
||||||
|
* This code is distributed in the hope that it will be useful, but WITHOUT
|
||||||
|
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
|
||||||
|
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
|
||||||
|
* version 2 for more details (a copy is included in the LICENSE file that
|
||||||
|
* accompanied this code).
|
||||||
|
*
|
||||||
|
* You should have received a copy of the GNU General Public License version
|
||||||
|
* 2 along with this work; if not, write to the Free Software Foundation,
|
||||||
|
* Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
|
||||||
|
*
|
||||||
|
* Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
|
||||||
|
* or visit www.oracle.com if you need additional information or have any
|
||||||
|
* questions.
|
||||||
|
*/
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @test
|
||||||
|
* @bug 8066904
|
||||||
|
* @summary Test verifies whether Bits per Pixel in BMP
|
||||||
|
* Header is corrupted or not
|
||||||
|
* @run main Bug8066904
|
||||||
|
*/
|
||||||
|
|
||||||
|
import java.io.ByteArrayInputStream;
|
||||||
|
import java.io.IOException;
|
||||||
|
import javax.imageio.ImageIO;
|
||||||
|
|
||||||
|
public class Bug8066904 {
|
||||||
|
|
||||||
|
public static void main(String[] args) throws IOException {
|
||||||
|
// corrupted byte array with improper Bits per pixel in header
|
||||||
|
byte[] corruptedBmp = { (byte) 0x42, (byte) 0x4d, (byte) 0x7e,
|
||||||
|
(byte) 0x06, (byte) 0x00, (byte) 0x00, (byte) 0x00, (byte) 0x00,
|
||||||
|
(byte) 0x00, (byte) 0x00, (byte) 0x3e, (byte) 0x00, (byte) 0x00,
|
||||||
|
(byte) 0x00, (byte) 0x28, (byte) 0x00, (byte) 0x00, (byte) 0x00,
|
||||||
|
(byte) 0x64, (byte) 0x00, (byte) 0x00, (byte) 0x00, (byte) 0x64,
|
||||||
|
(byte) 0x00, (byte) 0x40, (byte) 0x06, (byte) 0x00, (byte) 0x00,
|
||||||
|
(byte) 0x00, (byte) 0x00, (byte) 0x00, (byte) 0x00, (byte) 0x00,
|
||||||
|
(byte) 0x00, (byte) 0x00, (byte) 0x00, (byte) 0x00, (byte) 0x00,
|
||||||
|
(byte) 0x00, (byte) 0x00, (byte) 0x00, (byte) 0x00, (byte) 0x00,
|
||||||
|
(byte) 0x00, (byte) 0x00, (byte) 0x00, (byte) 0x00, (byte) 0x00,
|
||||||
|
(byte) 0xff, (byte) 0xff, (byte) 0xff, (byte) 0x00, (byte) 0xff,
|
||||||
|
(byte) 0xff, (byte) 0xff, (byte) 0xff, (byte) 0xff, (byte) 0xff,
|
||||||
|
(byte) 0xff, (byte) 0xff, (byte) 0xff, (byte) 0xff, (byte) 0xff,
|
||||||
|
(byte) 0xff };
|
||||||
|
|
||||||
|
/** if IOException is caught then test will
|
||||||
|
* pass otherwise throws a different exception.
|
||||||
|
*/
|
||||||
|
try {
|
||||||
|
ImageIO.read(new ByteArrayInputStream(corruptedBmp));
|
||||||
|
} catch(Exception ex) {
|
||||||
|
if (!(ex instanceof IOException))
|
||||||
|
throw ex;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
Loading…
x
Reference in New Issue
Block a user