Maison >base de données >tutoriel mysql >Pourquoi mon « BufferedImage » est-il nul lors de la conversion d'un Blob à partir d'une base de données ?

Pourquoi mon « BufferedImage » est-il nul lors de la conversion d'un Blob à partir d'une base de données ?

Patricia Arquette
Patricia Arquetteoriginal
2024-11-10 12:28:02901parcourir

Why is my `BufferedImage` null when converting a Blob from a database?

Convertir BufferedInputStream en une image

Vous rencontrez un problème lors de la conversion d'un blob à partir d'une base de données, que vous supposez être une image au format JPEG , dans un BufferedImage pour un traitement ultérieur. La conversion échoue et votre variable Image reste nulle.

Raisons possibles de l'échec de la conversion

Lors de l'examen de votre code, plusieurs problèmes potentiels peuvent entraîner l'échec de la conversion :

  1. Récupération de données : Le code récupère les données blob en utilisant blob.getBytes(1, blobLength). Cependant, blobLength est obtenu sous la forme d'un long (entier de 64 bits), tandis que getBytes attend un int (entier de 32 bits). Cette incompatibilité pourrait entraîner une troncature des données et une récupération d'image incorrecte.
  2. Vérification de l'image : S'assurer que le flux UploadedInputStream contient une image valide serait un bon point de départ. Vous pouvez temporairement écrire l'image dans un fichier à l'aide de ImageIO.write, puis la relire pour vérifier son intégrité.
  3. Gestion du contenu Blob : Selon la documentation de la base de données H2, le contenu du Blob ne sont pas stockés en mémoire. Par conséquent, au lieu d'utiliser blob.getBytes, vous devez utiliser blob.getBinaryStream pour récupérer une représentation de flux du blob.

Solution

Pour résoudre les problèmes , essayez de modifier votre code comme suit :

public Response post(@PathParam("id") String id) throws IOException {
    Connection con = connection();
    Blob blob = getPhoto(con);
    BufferedImage image = null;
    InputStream blobStream = null;
    int blobLength = 0;
    try {
        blobLength = (int) blob.length();
        blobStream = blob.getBinaryStream(1, blobLength);
        image = ImageIO.read(blobStream);
    } catch (SQLException e2) {
        e2.printStackTrace();
    }  

    return Response.ok(image).build();
}

De plus, vous devez vérifier la validité du uploadedInputStream en l'écrivant dans un fichier et en le relisant pour s'assurer qu'il contient une image.

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Déclaration:
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn