Heim >Datenbank >MySQL-Tutorial >Wie konvertiere ich einen BufferedInputStream von einer Datenbank in ein BufferedImage?
Problem:
Wie kann ich ein aus einer Datenbank abgerufenes BufferedInputStream-Objekt konvertieren? in ein BufferedImage? Der vorhandene Code gibt ein Nullbild zurück.
Lösung:
Beispiel:
Der folgende Java-Code verwendet Blob#getBinaryStream, um ein Bild zu lesen aus der Datenbank und konvertieren Sie es in ein BufferedImage:
import java.awt.image.BufferedImage; import java.io.ByteArrayInputStream; import java.io.ByteArrayOutputStream; import java.io.File; import java.io.IOException; import java.sql.Blob; import java.sql.Connection; import java.sql.PreparedStatement; import java.sql.ResultSet; import java.sql.SQLException; import javax.imageio.ImageIO; public class ImageDatabaseHelper { private Connection con; public BufferedImage loadImage(int imageId) throws IOException, SQLException { PreparedStatement stmt = null; ResultSet rs = null; BufferedImage image = null; try { stmt = con.prepareStatement("select image from images where id = ?"); stmt.setInt(1, imageId); rs = stmt.executeQuery(); while (rs.next()) { Blob blob = rs.getBlob(1); ByteArrayOutputStream baos = new ByteArrayOutputStream(); try (ByteArrayInputStream bais = new ByteArrayInputStream(blob.getBinaryStream())) { ImageIO.read(bais).writeTo(baos); } image = ImageIO.read(new ByteArrayInputStream(baos.toByteArray())); } } finally { try { rs.close(); } catch (Exception e) { } try { stmt.close(); } catch (Exception e) { } } return image; } }
Das obige ist der detaillierte Inhalt vonWie konvertiere ich einen BufferedInputStream von einer Datenbank in ein BufferedImage?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!