`
yangmeng_3331
  • 浏览: 88066 次
  • 性别: Icon_minigender_1
  • 来自: 天津
社区版块
存档分类
最新评论

从Oracle中读取blob类型存储的图片

阅读更多
    最近做个项目使用S2SH和Oracle数据库,其中photo表使用blob类型存储的图片。在网上搜了很多资料,现在把实例代码发一下。
Photo实体类
public class Photo implements java.io.Serializable {

	// Fields

	private Integer id;
	private Album album;
	private Date createtime;
	private String name;
	private String contentType;
	private Blob thumbnail;
	private Blob content;
	private Integer orderid;
	private Set facelookmarks = new HashSet(0);
	private Set facelookactivities = new HashSet(0);
	private Set facelookcomments = new HashSet(0);
        /*setter,getter省略*/
}

Photo映射文件
<class name="org.facelook.model.Photo" table="FACELOOKPHOTO" schema="YANGMENG">
/*其他省略*/
<property name="content" type="java.sql.Blob">
     <column name="CONTENT" />
</property>
<property name="thumbnail" type="java.sql.Blob">
     <column name="THUMBNAIL" />
</property>

    oracle中的blob类型,在实体类中使用java.sql.Blob对应。
从数据库查询数据时正常写查询方法就可以,在页面中输出图片时,在img标签的src属性写要访问的路径,我这里是PhotoAction的thumb方法。
[img]photo_thumb?id=<s:property value='photo.id'/>[/img]

PhotoAction的thumb方法
public String thumb(){
		try {
			this.photo = this.pService.getById(this.id);
			this.contentType = this.photo.getContentType();
			this.inputStream = this.photo.getContent().getBinaryStream();
		} catch (SQLException e) {
			e.printStackTrace();
		}
		return "thumb";
	}

struts.xml
<action name="photo_*" class="PhotoAction" method="{1}">
			<result name="thumb" type="stream">
			  <param name="contentType">${contentType}</param>
              <param name="bufferSize">1024</param>
			</result>
		</action>

    其中contentType是下载类型,读取的图片所以${contentType}值为image/jpeg。 
    这样图片就从数据库中读取出来了。以上是使用struts2的方法。如果不使用struts2来实现也可以使用流输出出来。代码如下:
this.photo = this.pService.getById(this.id);
response.setContentType(this.photo.getContentType());//this.photo.getContentType()值为image/jpeg
ServletOutputStream op = response.getOutputStream();
InputStream is = this.photo.getContent().getBinaryStream();
BufferedInputStream bis = new BufferedInputStream(is);
BufferedImage bi = ImageIO.read(bis);
JPEGImageEncoderImpl jpeg = new JPEGImageEncoderImpl(op);
jpeg.encode(bi);
op.close();
response.flushBuffer();
out.clear();
out = pageContext.pushBody();
1
0
分享到:
评论

相关推荐

    图片存入Oracle中,用clob和blob两种方式

    简单写的一个小工具,把图片存入oracle中,按clob和blob两种方式存储,并读取图片

    深入浅析mybatis oracle BLOB类型字段保存与读取

    本文给大家浅析mybatis oracle blob类型字段的保存与读取,blob字段是指二进制大对象,用来存储大量文本数据。感兴趣的朋友一起学习吧

    Oracle BLOB,BFILE大文件存储和FTP传输文件

    使用Oracle的大对象存储类型BLOB,BFILE存储和读取大文件,也包括使用FTP传输文件,如果使用FTP传输文件,需要在服务器端安装Serv-U软件。数据库为Oracle 10g,代码为Visual Studio 2008 VC++开发,软件中的代码有BLOB...

    hibernate保存图片

    二是数据库中只存储图片的在服务器上的路径信息 ,图片存放在分门别类的文件中,使用的时候从数据库读取路径信息到页面img元素即可.在此不讨论两种方案的优劣,我只是写了个hibernate的例子来实现第一种策略.例子...

    oracle数据库修复

    支持从ASM中直接抽取出数据文件和其他任意存储在ASM中的文件(包括控制文件、日志文件和归档日志等),即使相关的磁盘组不能成功mount 支持的Oracle数据库版本包括7,8i,9i,10g,11g 支持多种平台的数据库,包括AIX...

    赤兔Oracle数据库恢复软件 v11.6.zip

    2.支持从ASM中直接抽取出数据文件和其他任意存储在ASM中的文件(包括控制文件2.日志文件和归档日志等),即使相关的磁盘组不能成功mount 3.在ASM磁盘损坏严重的情况下,EOR可以扫描ASM磁盘,提取出没有被覆盖的数据...

    oracle学习文档 笔记 全面 深刻 详细 通俗易懂 doc word格式 清晰 连接字符串

    从就业与择业的角度来讲,计算机相关专业的大学生从事oracle方面的技术是职业发展中的最佳选择。 其一、就业面广:全球前100强企业99家都在使用ORACLE相关技术,中国政府机构,大中型企事业单位都能有ORACLE技术的...

    PRM-DUL Oracle(数据库恢复工具) v4.1.zip

    》》支持LOB字段(CLOB, NCLOB和BLOB)恢复,并支持同一个表中,不同LOB列使用不同CHUNK SIZE的情况 》》支持多种Big Endian/Little Endian操作平台(AIX/HPUX/SOLARIS/Linux/Windows)数据库数据恢复 》》支持...

    ssh(structs,spring,hibernate)框架中的上传下载

     文件数据存储在Blob类型的FILE_CONTENT表字段上,在Spring中采用OracleLobHandler来处理Lob字段(包括Clob和Blob),由于在程序中不需要引用到oracle数据驱动程序的具体类且屏蔽了不同数据库处理Lob字段方法上的...

    Spring中文帮助文档

    使用@SessionAttributes指定存储在会话中的属性 13.12.7. 自定义WebDataBinder初始化 13.13. 更多资源 14. 集成视图技术 14.1. 简介 14.2. JSP和JSTL 14.2.1. 视图解析器 14.2.2. 'Plain-old' JSPs versus ...

    Java JDK 7学习笔记(国内第一本Java 7,前期版本累计销量5万册)

    必须要时从Java SE API的源代码分析,了解各种语法在Java SE API中如何应用。  《Java JDK 7学习笔记》将IDE操作纳为教学内容之一,使读者能与实践结合,提供的视频教学能更清楚地帮助读者掌握操作步骤。 内容简介 ...

    mysql数据库my.cnf配置文件

    # 如果线程重新被请求,那么请求将从缓存中读取,如果缓存中是空的或者是新的请求,那么这个线程将被重新创建,如果有很多新的线程, # 增加这个值可以改善系统性能.通过比较Connections和Threads_created状态的变量,...

    Spring API

    使用@SessionAttributes指定存储在会话中的属性 13.12.7. 自定义WebDataBinder初始化 13.13. 更多资源 14. 集成视图技术 14.1. 简介 14.2. JSP和JSTL 14.2.1. 视图解析器 14.2.2. 'Plain-old' JSPs versus ...

Global site tag (gtag.js) - Google Analytics