中国IT动力,最新最全的IT技术教程
最新100篇 | 推荐100篇 | 专题100篇 | 排行榜 | 搜索 | 在线API文档
首 页 | 程序开发 | 操作系统 | 软件应用 | 图形图象 | 网络应用 | 精文荟萃 | 教育认证 | 硬件维护 | 未整理篇 | 站长教程
ASP JS PHP工程 ASP.NET 网站建设 UML J2EESUN .NET VC VB VFP 网络维护 数据库 DB2 SQL2000 Oracle Mysql
服务器 Win2000 Office C DreamWeaver FireWorks Flash PhotoShop 上网宝典 CorelDraw 协议大全 网络安全 微软认证
硬件维护  CPU  主板  硬盘  内存  显卡  显示器  键盘鼠标  声卡音箱  打印机  机箱电源  BIOS  网卡  C#  Java  Delphi  vs.net2005
  当前位置:> 程序开发 > Web开发 > 临时文章
如何在jsp页面中显示BLOB保存的图片数据
作者:未知 时间:2005-07-27 23:33 出处:CSDN 责编:chinaitpower
              摘要:如何在jsp页面中显示BLOB保存的图片数据

 

在页面中使用图片在应用中是不可缺少的。很多时候我们都是把文件直接放在本地的文件系统上,这样就可以直接在页面中显示图片信息。现在我介绍的是如何在将保存在数据库中的图像信息检索出来并显示在页面中。所用的是oralce数据库的blob存放图片信息。
要显示图片首先在数据库中必须要有图片存放。第一步我们应该建立一张表。表结构如下:TEST_BLOB(id varchar2(20), blobcol BLOB)
第二步我们就必须将数据倒入到数据库中
编译运行下面的代码:
import java.io.*;
import java.sql.*;
import oracle.jdbc.OracleResultSet;
import oracle.sql.*;

public class TestOracle
{
String username,password;
Connection conn = null;
Statement stmt = null;

{
username="***";
password="***";
try
{
   Class.forName("oracle.jdbc.driver.OracleDriver");
   conn=DriverManager.getConnection("jdbc:oracle:thin:@10.150.6.160:1521:dbwind72",username,password);
   stmt=conn.createStatement();
}
catch(Exception ex)
{
System.out.println(ex);
}
}
public void blobInsert(String infile) throws Exception
{

boolean defaultCommit = conn.getAutoCommit();
conn.setAutoCommit(false);

try
{
System.out.println("try start");
stmt.executeUpdate("INSERT INTO test_blob VALUES('111',EMPTY_BLOB())");
System.out.println("stmt.executeUpdate");
//conn.commit();
ResultSet rs = stmt.executeQuery("SELECT BLOBCOL FROM TEST_BLOB WHERE ID='111' FOR UPDATE");
System.out.println("stmt.executeQuery");
while (rs.next())
{
oracle.sql.BLOB blob = (oracle.sql.BLOB)rs.getBlob("BLOBCOL");
System.out.println("rs.getBlob");
BufferedOutputStream out = new BufferedOutputStream(blob.getBinaryOutputStream());
System.out.println("out stream create");
BufferedInputStream  in = new BufferedInputStream(new FileInputStream(new File(infile)));
System.out.println("Create new input file");
int c;
while ((c=in.read())!=-1)
{
out.write(c);
}
in.close();
out.close();
}


conn.commit();
}
catch (Exception ex)
{
System.out.println("blobInsert's exception");
conn.rollback();
throw ex;
}

conn.setAutoCommit(defaultCommit);
}

public static void main(String[] args)
{
TestOracle test = new TestOracle();
try
{
test.blobInsert("r:\\onjava_logo.jpg");
}
catch(Exception ex)
{
System.out.println("main's test.blobInsert() Exception"+ex);
}

}
}

这样就把你的R盘下面的onjava_logo.jpg保存到了数据库中。注意:BLOB型的数据必须先插入一个空值然后UPDATE,不能直接往里面插值。

好了,准备工作基本完成,现在开始我们的主题。我在这里直接用了一个jsp文件传送从数据库中检索出来的图片信息。jsp文件代码如下:
//myimage.jsp
<%@ page contentType="image/jpeg" %>

<%@ page import="java.awt.image.*,java.sql.*,com.sun.image.codec.jpeg.*,java.util.*,javax.imageio.*,java.io.*"
%>

<%

// Create image
String username,password,url;
Connection conn = null;
Statement stmt = null;
BufferedInputStream inputimage=null;
username="***";
password="***";
url ="jdbc:oracle:thin:@10.150.6.160:1521:dbwind72";
Class.forName("oracle.jdbc.driver.OracleDriver");
conn=DriverManager.getConnection(url,username,password);
stmt=conn.createStatement();

boolean defaultCommit = conn.getAutoCommit();
conn.setAutoCommit(false);

try {

ResultSet rs = stmt.executeQuery("SELECT * FROM TEST_BLOB WHERE ID='111'");

while (rs.next()) {
oracle.sql.BLOB blob = (oracle.sql.BLOB)rs.getBlob("BLOBCOL");
inputimage = new BufferedInputStream(blob.getBinaryStream());
}
} catch (Exception ex) {
System.out.println("blobRead()'s exception"+ex);
conn.rollback();
throw ex;
}
conn.setAutoCommit(defaultCommit);


// Send back image
BufferedImage image = null;
try{
image = ImageIO.read(inputimage);
}catch(IOException e){
System.out.println(e);
}
ServletOutputStream sos = response.getOutputStream();
JPEGImageEncoder encoder = JPEGCodec.createJPEGEncoder(sos);
encoder.encode(image);
inputimage.close();
/*/**/
%>
这里我用到了com.sun.image.codec.jpeg包中的JPEGImageEncoder来构造图片。首先从数据库中检索到这个BLOB保存的数据。inputimage = new BufferedInputStream(blob.getBinaryStream());然后包装成一个BufferedInputStream。之后用这个BufferedInputStream构造一个BufferedImage:image = ImageIO.read(inputimage);剩下的事情就好办了,encode就行了。
简要的说完了,希望能对大家有点儿帮助。

关闭本页
 
首页 | 投资与合作 | 服务条款 | 隐私政策 | 收藏本站 | 设为首页 | 新用户注册 | 免责声明 | 使用帮助
Copyright ©2005-2008 chinaitpower.com All rights reserved. www.chinaitpower.com 版权所有