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

转载自:http://blog.csdn.net/javadwr/article/details/9065989

 

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

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

 

[java]  view plain copy print ?
 
  1. <servlet>  
  2.     <servlet-name>ImageServlet</servlet-name>  
  3.     <servlet-class>ImagerServlet</servlet-class>  
  4. </servlet>  
  5.   
  6. <servlet-mapping>  
  7.     <servlet-name>ImageServlet</servlet-name>  
  8.     <url-pattern>*.img</url-pattern>  
  9. </servlet-mapping>  


JSP页面获取标签:

 

 

[html]  view plain copy print ?
 
  1. <IMG SRC="/show.img" />  


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

 

 

[java]  view plain copy print ?
 
  1. import java.io.IOException;  
  2. import java.io.InputStream;  
  3. import java.sql.Blob;  
  4.   
  5. import javax.servlet.ServletException;  
  6. import javax.servlet.ServletOutputStream;  
  7. import javax.servlet.http.HttpServlet;  
  8. import javax.servlet.http.HttpServletRequest;  
  9. import javax.servlet.http.HttpServletResponse;  
  10.   
  11.   
  12. public class ImagerServlet extends HttpServlet {  
  13.   
  14.     private static final long serialVersionUID = -5665985198720593386L;  
  15.       
  16.     public ImagerServlet() {  
  17.         super();  
  18.     }  
  19.   
  20.       
  21.     public void doGet(HttpServletRequest request, HttpServletResponse response)  
  22.             throws ServletException, IOException {  
  23.         doPost(request,response);  
  24.     }  
  25.   
  26.       
  27.     public void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {  
  28.         InputStream in = null;  
  29.         ServletOutputStream oStream = null;  
  30.         try {  
  31.             response.reset();  
  32.             response.setContentType("image/jpeg"); //设置repose返回类型,这个很重要  
  33.             request.setCharacterEncoding("gbk");  
  34.               
  35.             oStream =response.getOutputStream();  
  36.             Blob blob = null;//通过java获取到oracle数据库中的blob字段  
  37.             in = blob.getBinaryStream();  
  38.             int blobsize = (int) blob.length();//获取blob长度  
  39.             byte[] blobbytes = new byte[blobsize];  
  40.             int bytesRead = 0;  
  41.             while ((bytesRead = in.read(blobbytes)) != -1) {//循环写入outputstream  
  42.                 oStream.write(blobbytes, 0, bytesRead);  
  43.             }   
  44.         } catch (IOException e) {  
  45.             throw e;  
  46.         } catch (Exception e) {  
  47.         } finally{  
  48.             if (in != null) {  
  49.                 in.close();  
  50.             }  
  51.             if (oStream != null) {  
  52.                 oStream.close();  
  53.             }  
  54.         }  
  55.     }  
  56. }  
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值