使用MySQL工作台从数据库保存和显示图像

时间:2018-04-06 07:56:21

标签: java mysql database

美好的一天,我试图测试将图像上传到我的数据库但是当我试图检索图像时,没有任何显示...

这是我上传图片的代码

<router-outlet>

并显示图片:

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();
        }
    }
}

我目前正在使用Intellij和CaptainCasa ..

有人可以帮忙吗? 提前致谢。

1 个答案:

答案 0 :(得分:0)

似乎应该是

    photo.set("Image_Data",imageByte);

而不是

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

因为imageByte是存储上传图像的地方。