我有一个从客户端获取字节数组的服务器端Java代码。为了进行一些图像处理,我需要将字节数组转换为BufferedImage。我有一个应该在这里执行的代码:

public void processImage(byte[] data) {
    ByteArrayInputStream stream = new ByteArrayInputStream(data);
    BufferedImage bufferedImage;
    bufferedImage = ImageIO.read(stream);

    // bufferedImage is null
    //...
}

但这是行不通的。 bufferedImage为null。根据ImageIO文档:

如果没有注册的ImageReader声称能够读取结果流,则返回null

我如何告诉ImageReader它是什么图像类型。例如,如果我知道图像是JPEG(在我的情况下就是JPEG),我应该怎么做?

编辑:感谢您的建议,即文件很可能不是JPEG格式。这是我拥有的客户端代码,用于将数据作为String发送到服务器:
import org.json.JSONObject;

// Client-side code that sends image to server as String
public void sendImage() {
    FileInputStream inputStream = new FileInputStream(new File("myImage.jpg"));
    ByteArrayOutputStream byteStream = new ByteArrayOutputStream();
    byte[] b = new byte[1024];
    while ((bytesRead = inputStream.read(b)) != -1) {
        byteStream.write(b,0,bytesRead);
    }
    byte[] byteArray = byteStream.toByteArray();

    JSONObject jsonObject = new JSONObject();
    jsonObject.put("data",new String(byteArray));

    // ... more code here that sends jsonObject in HTTP post body
}

这是调用processImage()函数的服务器端代码:
// Server-side code that calls processImage() function
public void handleRequest(String jsonData) {
    JSONObject jsonObject = new JSONObject(jsonData);
    processImage(jsonObject.getString("data").getBytes());
}

最佳答案

最可能的解释是字节数组不包含JPEG图像。 (例如,如果您只是尝试下载它,则可能有一个HTML文档提供了错误诊断信息。)如果是这种情况,则需要找出造成此问题的原因并加以解决。

但是,如果您“知道”字节数组包含具有给定格式的图像,则可以执行以下操作:

  • 使用ImageIO.getImageReadersByFormatNameImageIO.getImageReadersByMIMEType获得Iterator<ImageReader>
  • ImageReader中拉出第一个Iterator
  • 创建用于包装类型的MemoryCacheImageInputStreamByteArrayInputStream
  • 使用ImageReader.setInput将阅读器连接到ImageInputStream
  • 使用ImageReader.read获取BufferedImage
  • 10-06 01:49