基于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);
    }

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

时间: 2024-12-16 09:10:34

基于SSH的数据库中图片的读写的相关文章

Mysql数据库中图片字段Blob类型和String类型相互转换

1.Blob-->String String result = ""; if (blob != null) { InputStream is = blob.getBinaryStream(); ByteArrayInputStream bais = (ByteArrayInputStream) is; byte[] byte_data = new byte[bais.available()]; // bais.available()返回此输入流的字节数 bais.read(byt

Android 通过API获取数据库中的图片文件

Overview 今天复习了一下Android 如何将我们数据库中图片获取出来,并且将其转换为bitmap进行显示. 开发环境以及技术 使用Visual Studio 2019 Android Studio 3.5 API 使用 ASP .NET WEB API 开发 数据库操作只用Entity Framework 使用本地数据库作为数据源 如果你是一个需要开发软件和API的程序员,那么你可以看一下,如果你不是可以选择跳过 $\color{#6995C2}{API开发}$. API 开发 这里我

C#中使用FileUpload上传图片到SQL数据库中以image类型存储并使用Image控件显示注意事项

当我们需要以数据流存储图片到数据库中(而不是文件路径),需要考虑很多因素,不同的环境决定了采取不同方法. 1.将图片存入数据库.首先,当我们决定使用FileUpload上传图片,需要考虑,FileUpload的功能主要是在客户端选取图片,然后使用FileUpload的SaveAs方法将选取的图片的地址保存到服务器端保存,因为我们使用的数据流存储图片,所以没有必要将图片保存到服务器端. 其次,FileUpload没有像OpenDialog的.Filter方法过滤图片的格式,即实现打开对话框,只能选

读取保存文件、图片在数据库中的上传读取

一.输入输出流 1.概念: 输入输出流主要用于保存.读取文件,其内容保存在内存中. 2.使用方法: using System.IO; //System.IO 命名空间包含允许读写文件和数据流的类型以及提供基本文件和目录支持的类型. 3.代码段实现读取和保存功能: 读取文字: OpenFileDialog op = new OpenFileDialog(); op.ShowDialog();//打开文件对话框 //将选择的东西读取到文档里 StreamReader sd = new StreamR

基于 EntityFramework 的数据库主从读写分离服务插件

基于 EntityFramework 的数据库主从读写分离服务插件 1.       版本信息和源码 1.1 版本信息 v1.0 beta(2015-04-02),基于 EF 6.1 开发,支持 EF 6.1 之后的所有 EF6 版本. 1.2 开放源码地址 https://github.com/cjw0511/NDF.Infrastructure 关于该 EF 数据库主从读写分离服务核心源码位于文件夹: src\ NDF.Data.EntityFramework\MasterSlaves 文件

集合差集 哈希表 比较数据库中的图片和服务器上的图片,将服务器上的垃圾图片删除

SSH 框架下code: public String deleRubbishAd(){ int deleADcount = 0; rubbishADtp = configDao.rubbishADtp(); //数据库中的广告图片集合 Map<Object,Object> shujuku= new HashMap<Object,Object>(); File adfile = new File("C://Program Files//Apache Software Fou

基于 EntityFramework 的数据库主从读写分离架构 - 目录

基于 EntityFramework 的数据库主从读写分离架构 回到目录,完整代码请查看(https://github.com/cjw0511/NDF.Infrastructure)中的目录: src\ NDF.Data.EntityFramework\MasterSlaves 基于 EntityFramework 的数据库主从读写分离架构 - 需求/功能概述 基于 EntityFramework 的数据库主从读写分离架构(1)- 原理概述和基本功能实现 基于 EntityFramework 的

基于 EntityFramework 的数据库主从读写分离架构(2)- 改进配置和添加事务支持

回到目录,完整代码请查看(https://github.com/cjw0511/NDF.Infrastructure)中的目录: src\ NDF.Data.EntityFramework\MasterSlaves 上一回中(http://www.cnblogs.com/cjw0511/p/4398267.html),我们简单讲述了基于 EF 来实现数据库读写分离的原理.当然,这只是一个 demo 级别的简单实现,实际上,在我们工作环境中,碰到的情况远比这复杂多了,例如数据库连接的配置是通过 c

[转]asp.net mvc 从数据库中读取图片

本文转自:http://www.cnblogs.com/mayt/archive/2010/05/20/1740358.html 首先是创建一个类,继承于ActionResult,记住要引用System.Web.Mvc命名空间,如下: public class ImageResult : ActionResult { public ImageFormat ContentType { get; set; } public Image image { get; set; } public strin