基于SSH的数据库中图片的读写

近期项目中遇到了这个问题,网上查了一些资料所谓是零零散散,这里写篇博文做个笔记。

注:这篇博文中部分类的属性声明未列出,应该不算难,基本都是以private 类型 名称 格式声明,然后配getter setter方法

首先是图片入库的过程,这里是固定的图片入库,项目应用中根据需要可以调整图片的URL

对应实体类:

 1 @Entity
 2 @Table(name = "xxx")
 3 public class Image {
 4 
 5     private long id;
 6     private byte[] photo;
 7     
 8     @Id
 9     @Column(name = "ID", unique = true, nullable = false, length = 11)
10     public long getId() {
11         return id;
12     }
13     public void setId(long id) {
14         this.id= id;
15     }
16     @Column(name = "PHOTO")
17     public byte[] getPhoto() {
18         return photo;
19     }
20     public void setPhoto(byte[] photo) {
21         this.photo = photo;
22     }
23     
24 }

入库方法:(这里的perDao是用的Hibernate经过一层封装,基本方法是调用HibernateTemplate中的saveOrUpdate)

 1 public void insertPhoto(long id) throws IOException{
 2         Image image = new Image();
 3         File file = new File("E:/workspace/xxxx/src/test.png");
 4         InputStream a = new FileInputStream(file);
 5         byte[] b = new byte[a.available()];
 6         a.read(b);
 7         image.setId(id);
 8         image.setPhoto(b);
 9         System.out.println(b.length);
10         perDao.save(personImage);
11         a.close();
12     }


接下来是读取的过程:

页面代码:

图片的src指向返回流的action,可以带参数

<img id="empImg" src="person_getPhotoById.action?id=<%=id %>" />

struts2配置文件中的配置如下

    <package name="person" extends="json-default">
        <action name="person_*" class="personAction" method="{1}">
            <result name="getPhotoById" type="stream">
                <param name="root">inputStream</param>
            </result>
        </action>
    </package>

action层方法:

public String getPhotoById(){try {
            Blob blob = Hibernate.createBlob(personService.getPhotoById(id));
            inputStream = blob.getBinaryStream();
        } catch (Exception e) {
            e.printStackTrace();
        }
        return "getPhotoById";
    }

service层方法:

public byte[] getPhotoById(long id){
        List<PersonImage> result = personDao.getPhotoById(id);
        return result.get(0).getPhoto();
    }

dao层方法:

public List getPhotoById(long id){
        String hql = "FROM Image WHERE id = ?";
        Long[] items = {id};
        return perDao.findByHql(hql, items);
    }

具体方法就是这些,如果有什么问题或者更好的方案可以留言分享

 

转载于:https://www.cnblogs.com/aotian/p/3976099.html

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值