zoukankan      html  css  js  c++  java
  • 基于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);
        }

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

  • 相关阅读:
    【AGC010E】Rearranging(博弈,图论,拓扑排序)
    【ARC074F】Lotus Leaves(最小割)
    【ARC069F】Flags(2-SAT,Tarjan,线段树优化建图)
    [CTS 2019] 氪金手游
    HDU
    LOJ
    LOJ
    [TJOI 2015] 概率论
    [AGC 018F] Two Trees
    LOJ
  • 原文地址:https://www.cnblogs.com/aotian/p/3976099.html
Copyright © 2011-2022 走看看