oracle 显示图片,jsp页面通过java调用oracle blob字段显示图片

项目中的图片资源一般建议存储到独立的静态服务器中。为了不让图片、文档等文件资源管理零碎,不能被有心人事删除,最好选择存储oracle的大字段blob类型。这里对于java怎么存储、获取blob类型不多介绍,重点讲解jsp页面img标签显示blob字段。

首先需要通过java代码获取到oracle中的blob字段,对应java类型是java.sql.Blob。

配置web.xml配置一个获取图片的servlet:源码如下。

ImageServlet

ImagerServlet

ImageServlet

*.img

JSP页面获取标签:

show.img

java类Servlet,通过获取到blob字节,通过“image/jpeg”类型返回图片。

import java.io.IOException;

import java.io.InputStream;

import java.sql.Blob;

import javax.servlet.ServletException;

import javax.servlet.ServletOutputStream;

import javax.servlet.http.HttpServlet;

import javax.servlet.http.HttpServletRequest;

import javax.servlet.http.HttpServletResponse;

public class ImagerServlet extends HttpServlet {

private static final long serialVersionUID = -5665985198720593386L;

public ImagerServlet() {

super();

}

public void doGet(HttpServletRequest request, HttpServletResponse response)

throws ServletException, IOException {

doPost(request,response);

}

public void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {

InputStream in = null;

ServletOutputStream oStream = null;

try {

response.reset();

response.setContentType("image/jpeg"); //设置repose返回类型,这个很重要

request.setCharacterEncoding("gbk");

oStream =response.getOutputStream();

Blob blob = null;//通过java获取到oracle数据库中的blob字段

in = blob.getBinaryStream();

int blobsize = (int) blob.length();//获取blob长度

byte[] blobbytes = new byte[blobsize];

int bytesRead = 0;

while ((bytesRead = in.read(blobbytes)) != -1) {//循环写入outputstream

oStream.write(blobbytes, 0, bytesRead);

}

} catch (IOException e) {

throw e;

} catch (Exception e) {

} finally{

if (in != null) {

in.close();

}

if (oStream != null) {

oStream.close();

}

}

}

}

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值