提交 014f03cc 编写于 作者: A andrew

8044289: In ImageIO.write() and ImageIO.read() null stream is not handled properly.

Reviewed-by: prr, serb, psadhukhan
上级 25d5529e
......@@ -1291,7 +1291,8 @@ public final class ImageIO {
*
* @exception IllegalArgumentException if <code>input</code> is
* <code>null</code>.
* @exception IOException if an error occurs during reading.
* @exception IOException if an error occurs during reading or when not
* able to create required ImageInputStream.
*/
public static BufferedImage read(File input) throws IOException {
if (input == null) {
......@@ -1341,7 +1342,8 @@ public final class ImageIO {
*
* @exception IllegalArgumentException if <code>input</code> is
* <code>null</code>.
* @exception IOException if an error occurs during reading.
* @exception IOException if an error occurs during reading or when not
* able to create required ImageInputStream.
*/
public static BufferedImage read(InputStream input) throws IOException {
if (input == null) {
......@@ -1349,6 +1351,9 @@ public final class ImageIO {
}
ImageInputStream stream = createImageInputStream(input);
if (stream == null) {
throw new IIOException("Can't create an ImageInputStream!");
}
BufferedImage bi = read(stream);
if (bi == null) {
stream.close();
......@@ -1381,7 +1386,8 @@ public final class ImageIO {
*
* @exception IllegalArgumentException if <code>input</code> is
* <code>null</code>.
* @exception IOException if an error occurs during reading.
* @exception IOException if an error occurs during reading or when not
* able to create required ImageInputStream.
*/
public static BufferedImage read(URL input) throws IOException {
if (input == null) {
......@@ -1395,6 +1401,14 @@ public final class ImageIO {
throw new IIOException("Can't get input stream from URL!", e);
}
ImageInputStream stream = createImageInputStream(istream);
if (stream == null) {
/* close the istream when stream is null so that if user has
* given filepath as URL he can delete it, otherwise stream will
* be open to that file and he will not be able to delete it.
*/
istream.close();
throw new IIOException("Can't create an ImageInputStream!");
}
BufferedImage bi;
try {
bi = read(stream);
......@@ -1507,7 +1521,8 @@ public final class ImageIO {
*
* @exception IllegalArgumentException if any parameter is
* <code>null</code>.
* @exception IOException if an error occurs during writing.
* @exception IOException if an error occurs during writing or when not
* able to create required ImageOutputStream.
*/
public static boolean write(RenderedImage im,
String formatName,
......@@ -1515,7 +1530,6 @@ public final class ImageIO {
if (output == null) {
throw new IllegalArgumentException("output == null!");
}
ImageOutputStream stream = null;
ImageWriter writer = getWriter(im, formatName);
if (writer == null) {
......@@ -1525,13 +1539,11 @@ public final class ImageIO {
return false;
}
try {
output.delete();
stream = createImageOutputStream(output);
} catch (IOException e) {
throw new IIOException("Can't create output stream!", e);
output.delete();
ImageOutputStream stream = createImageOutputStream(output);
if (stream == null) {
throw new IIOException("Can't create an ImageOutputStream!");
}
try {
return doWrite(im, writer, stream);
} finally {
......@@ -1559,7 +1571,8 @@ public final class ImageIO {
*
* @exception IllegalArgumentException if any parameter is
* <code>null</code>.
* @exception IOException if an error occurs during writing.
* @exception IOException if an error occurs during writing or when not
* able to create required ImageOutputStream.
*/
public static boolean write(RenderedImage im,
String formatName,
......@@ -1567,13 +1580,10 @@ public final class ImageIO {
if (output == null) {
throw new IllegalArgumentException("output == null!");
}
ImageOutputStream stream = null;
try {
stream = createImageOutputStream(output);
} catch (IOException e) {
throw new IIOException("Can't create output stream!", e);
ImageOutputStream stream = createImageOutputStream(output);
if (stream == null) {
throw new IIOException("Can't create an ImageOutputStream!");
}
try {
return doWrite(im, getWriter(im, formatName), stream);
} finally {
......
/*
* Copyright (c) 2016, 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 8044289
* @summary Test verifies that when some of the read() and write() methods
* are not able to get stream from createImageInputStream() and
* createImageOutputStream() are we doing null check for stream
* and throwing IOException as per specification.
* @run main NullStreamCheckTest
*/
import java.awt.image.BufferedImage;
import java.io.File;
import java.io.IOException;
import java.io.InputStream;
import java.io.OutputStream;
import java.net.MalformedURLException;
import java.net.URL;
import javax.imageio.ImageIO;
import javax.imageio.spi.IIORegistry;
import javax.imageio.spi.ImageInputStreamSpi;
import javax.imageio.spi.ImageOutputStreamSpi;
public class NullStreamCheckTest {
// get ImageIORegistry default instance.
private static final IIORegistry localRegistry = IIORegistry.
getDefaultInstance();
// stream variables needed for input and output.
static LocalOutputStream outputStream = new LocalOutputStream();
static LocalInputStream inputStream = new LocalInputStream();
static final int width = 50, height = 50;
// input and output BufferedImage needed while read and write.
static BufferedImage inputImage = new BufferedImage(width, height,
BufferedImage.TYPE_INT_ARGB);
// creates test file needed for read and write in local directory.
private static File createTestFile(String name) throws IOException {
String sep = System.getProperty("file.separator");
String dir = System.getProperty("test.src", ".");
String filePath = dir+sep;
File directory = new File(filePath);
File tmpTestFile = File.createTempFile(name, ".png", directory);
directory.delete();
return tmpTestFile;
}
/* if we catch expected IOException message return
* false otherwise return true.
*/
private static boolean verifyOutputExceptionMessage(IOException ex) {
String message = ex.getMessage();
return (!message.equals("Can't create an ImageOutputStream!"));
}
/* if we catch expected IOException message return
* false otherwise return true.
*/
private static boolean verifyInputExceptionMessage(IOException ex) {
String message = ex.getMessage();
return (!message.equals("Can't create an ImageInputStream!"));
}
private static void verifyFileWrite() throws IOException {
File outputTestFile = createTestFile("outputTestFile");
try {
ImageIO.write(inputImage, "png", outputTestFile);
} catch (IOException ex) {
if (verifyOutputExceptionMessage(ex))
throw ex;
} finally {
outputTestFile.delete();
}
}
private static void verifyStreamWrite() throws IOException {
try {
ImageIO.write(inputImage, "png", outputStream);
} catch (IOException ex) {
if (verifyOutputExceptionMessage(ex))
throw ex;
} finally {
try {
outputStream.close();
} catch (IOException ex) {
throw ex;
}
}
}
private static void verifyFileRead() throws IOException {
File inputTestFile = createTestFile("inputTestFile");
try {
ImageIO.read(inputTestFile);
} catch (IOException ex) {
if (verifyInputExceptionMessage(ex))
throw ex;
} finally {
inputTestFile.delete();
}
}
private static void verifyStreamRead() throws IOException {
try {
ImageIO.read(inputStream);
} catch (IOException ex) {
if (verifyInputExceptionMessage(ex))
throw ex;
} finally {
try {
inputStream.close();
} catch (IOException ex) {
throw ex;
}
}
}
private static void verifyUrlRead() throws IOException {
URL url;
File inputTestUrlFile = createTestFile("inputTestFile");
try {
try {
url = inputTestUrlFile.toURI().toURL();
} catch (MalformedURLException ex) {
throw ex;
}
try {
ImageIO.read(url);
} catch (IOException ex) {
if (verifyInputExceptionMessage(ex))
throw ex;
}
} finally {
inputTestUrlFile.delete();
}
}
public static void main(String[] args) throws IOException,
MalformedURLException {
/* deregister ImageOutputStreamSpi so that we creatImageOutputStream
* returns null while writing.
*/
localRegistry.deregisterAll(ImageOutputStreamSpi.class);
/* verify possible ImageIO.write() scenario's for null stream output
* from createImageOutputStream() API in ImageIO class.
*/
verifyFileWrite();
verifyStreamWrite();
/* deregister ImageInputStreamSpi so that we creatImageInputStream
* returns null while reading.
*/
localRegistry.deregisterAll(ImageInputStreamSpi.class);
/* verify possible ImageIO.read() scenario's for null stream output
* from createImageInputStream API in ImageIO class.
*/
verifyFileRead();
verifyStreamRead();
verifyUrlRead();
}
static class LocalOutputStream extends OutputStream {
@Override
public void write(int i) throws IOException {
}
}
static class LocalInputStream extends InputStream {
@Override
public int read() throws IOException {
return 0;
}
}
}
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册