Сохранение и отображение изображения из базы данных с использованием MySQL Workbench

0

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

Здесь мой код для загрузки изображения

String m_dataForImage;
public String getDataForImage() { return m_dataForImage; }
public void setDataForImage(String value) { this.m_dataForImage = value; }


String m_ShowPhoto;
public String getShowPhoto() { return m_ShowPhoto; }
public void setShowPhoto(String value) { this.m_ShowPhoto = value; }

String m_fileName;
public String getFileName() { return m_fileName; }
public void setFileName(String value) { this.m_fileName = value; }

public void onUploadFile(javax.faces.event.ActionEvent event) {
    if (event instanceof BaseActionEventUpload){
        try{
            ConnectionPool.getInstance();
            Base.open(ConnectionPool.dataSourcePooled);

            BaseActionEventUpload bae =(BaseActionEventUpload)event;
            setFileName(bae.getClientFileName());
            m_ShowPhoto = bae.getHexByteString();
            byte[] imageByte = bae.getHexBytes();
            setShowPhoto("/hex("+ValueManager.encodeHexString(imageByte)+")");//trying to convert byte to hex

            photo_storage photo = new photo_storage();
                photo.set("timestamp","ss");
                photo.set("Primary_Key", "123");
                photo.set("File_Name",getFileName());
                photo.set("Image_Data",getShowPhoto());

            photo.saveIt();



        }catch(Throwable t){
            t.printStackTrace();
            Statusbar.outputAlert(t.toString());
        }finally {
            Base.close();
        }
    }
}

и для показа изображения:

public void onShowImage(javax.faces.event.ActionEvent event) {
        try{
            ConnectionPool.getInstance();
            Base.open(ConnectionPool.dataSourcePooled);

            List<photo_storage> photo = photo_storage.where("Primary_Key = ?",123);
            for (photo_storage so:photo){ setShowPhoto("/hex("+ValueManager.encodeHexString(so.getBytes("Image_Data"))+")");
                setFileName(so.getString("File_Name"));
                setDataForImage(so.getString("Image_Data"));

        }catch(Throwable t){
            t.printStackTrace();
            Statusbar.outputAlert(t.toString());
        }finally {
            Base.close();
        }
}

В настоящее время я использую Intellij и CaptainCasa..

Может ли кто-нибудь помочь? Заранее спасибо.

Теги:
database

1 ответ

0
Лучший ответ

Кажется, что это должно быть

    photo.set("Image_Data",imageByte);

вместо

    photo.set("Image_Data",getShowPhoto());

потому что imageByte - это место, где загружено загруженное изображение.

Ещё вопросы

Сообщество Overcoder
Наверх
Меню