首页 > 代码库 > 基于SSH的数据库中图片的读写
基于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/iocs/iocs_bjhy/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); }
具体方法就是这些,如果有什么问题或者更好的方案可以留言分享
基于SSH的数据库中图片的读写
声明:以上内容来自用户投稿及互联网公开渠道收集整理发布,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任,若内容有误或涉及侵权可进行投诉: 投诉/举报 工作人员会在5个工作日内联系你,一经查实,本站将立刻删除涉嫌侵权内容。