Hibernate实现将图片保存至数据库、显示在页面

一般而言我们并不推荐将图片保存至数据库,通常的做法是将图片上传至服务器的某个路径,然后在数据库中存储它的路径。但是有时候某些需求必须要将图片保存至数据库,例如多个项目共享一个数据库,这时我们就只能把图片文件上传保存到数据库中了。

在Oracle数据库中我一般都是使用Blob字段来存储二进制文件的,所以要将图片存储到Oracle数据库中,图片字段必须为Blob。同时在Java中的Hibernate提供了非常存储机制,同时这个存储机制对二进制Blob支持非常棒。实现代码如下:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
Blob blob = BlobUtils.file2Blob(file);   //将File转换为blob
    advertisement.setImage(blob);
 
    //入库处理
    dao.saveOrUpdate(advertisement);
 
    public static Blob file2Blob(File file) throws IOException, SerialException, SQLException {
        InputStream is = null;
        Blob blob = null;
        try {
            is = new FileInputStream(file);
            byte[] content = new byte[is.available()]; 
            is.read(content);
            blob = new SerialBlob(content);
        } catch (IOException e) {
            throw e;
        }finally{
            if(is != null){
                is.close();
            }
            if(file != null){
                file.delete();
            }
        }
        return blob;
    }

在这段代码中首先是将File转换为Blob(Java.sql.Blob),然后通过Hibernate的save()方法进行保存。这段简单的代码就可以实现将图片存储到Oracle数据库中。下面将展示如下在数据看看中将图片取出来。

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
//将图片显示在页面-----servlet
            Blob blob = advertisement.getImage();
                int length = (int)blob.length();     //取得流中的可用字节总数     
                byte[] buf = blob.getBytes(1,length);   //获取Blob字节数组     
                response.setContentType("image/jpeg");     
                OutputStream out = response.getOutputStream();//获取输出流     
                for (int i = 0; i < buf.length; i++) {     
                    out.write(buf[i]);//输出到页面     
                }     
                out.close();//关闭输出流
 
                        //将文件保存在服务器路径
 
            Blob blob = advertisement.getImage();
            InputStream is = blob.getBinaryStream(); 
             FileOutputStream fos = new FileOutputStream("D://advertisementImage.jpg"); 
             byte[] buffer = new byte[1024]; 
             int len = 0; 
             while((len = is.read(buffer) )!= -1){  
                 fos.write(buffer,0,len); 
             } 
             System.out.println("成功处理完毕"); 
             is.close();
             fos.close();

当然通过Hibernate非常容易实现图片的存储和获取显示,没有什么技术含量。在这里只是起到一个记录的作用!!!!

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值