Загрузка изображения в базу данных с помощью javafx - PullRequest
0 голосов
/ 19 ноября 2018

Я пытаюсь загрузить изображение в базу данных mysql, используя phpmyadmin, и, несмотря на то, что программа работает и сохраняет остальные данные, изображение хранится неправильно.

Если я загружаю изображение напрямую в phpmyadmin, размер изображения в типе Blob составляет 26,6 КБ, но если я пытаюсь загрузить с помощью javafx, размер изображения составляет около 10 B, поэтому я думаю, что загружаю не правильно.

@Override
public void guardarMonstruo(MonstruoDTO monstruo) {
    con= ConexionBDA.getInstance().getCon();
    try {
    if (con != null){
        byte[] blob = imagenToByte(monstruo.getImagen());
        System.out.println(blob.toString());
        statement = con.createStatement();
        statement.executeUpdate("INSERT INTO monstruos (Nombre,Habitat,Estado,ColaCercenable,DragonAnciano,DebilidadFuego,DebilidadAgua,Debilidadrayo,DebilidadHielo,DebilidadDraco,ImagenMonstruo) VALUES ('"+monstruo.getNombre()+"'"+","+"'"+monstruo.getHabitat()+"'"+","+"'"+monstruo.getEstado()+"'"+","+"'"+monstruo.getColaCercenable()+"'"+","+"'"+monstruo.getDragonAnciano()+"'"+","+"'"+monstruo.getDebilidadFuego()+"'"+","+"'"+monstruo.getDebilidadAgua()+"'"+","+"'"+monstruo.getDebilidadRayo()+"'"+","+"'"+monstruo.getDebilidadHielo()+"'"+","+"'"+monstruo.getDebilidadDraco()+"'"+","+"'"+blob+"');");
        con.close();
        statement.close();


    }
    }
    catch(Exception e) {
        e.printStackTrace();
    }


}

И метод imagenToByte () используется для передачи изображения в байт:

private byte[] imagenToByte(Image imagen) {
    BufferedImage bufferimage = SwingFXUtils.fromFXImage(imagen, null);
      ByteArrayOutputStream output = new ByteArrayOutputStream();
      try {
        ImageIO.write(bufferimage, "jpg", output );
    } catch (IOException e) {
        // TODO Auto-generated catch block
        e.printStackTrace();
    }
      byte [] data = output.toByteArray();
      return data;
}

Я не знаю, что я делаю неправильно, не могли бы вы мне помочь?

1 Ответ

0 голосов
/ 19 ноября 2018

Вы вставляете результат метода toString в строку запроса, что не приведет к желаемому результату. Используйте PreparedStatement и установите вместо него параметр Blob:

try (PreparedStatement ps = con.prepareStatement("INSERT INTO monstruos (Nombre,Habitat,Estado,ColaCercenable,DragonAnciano,DebilidadFuego,DebilidadAgua,Debilidadrayo,DebilidadHielo,DebilidadDraco,ImagenMonstruo) VALUES (?,?,?,?,?,?,?,?,?,?,?)")) {
    ps.setString(1, monstruo.getNombre());
    ps.setString(2, monstruo.getHabitat());
    ps.setString(3, monstruo.getEstado());
    ps.setString(4, monstruo.getColaCercenable());
    ps.setString(5, monstruo.getDragonAnciano());
    ps.setString(6, monstruo.getDebilidadFuego());
    ps.setString(7, monstruo.getDebilidadAgua());
    ps.setString(8, monstruo.getDebilidadRayo());
    ps.setString(9, monstruo.getDebilidadHielo());
    ps.setString(10, monstruo.getDebilidadDraco());

    // upload the data, not the toString result of the array
    ps.setBlob(11, new SerialBlob(blob));

    ps.executeUpdate();
}
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...