数据库运用程序,特殊是基于WEB的数据库运用程序,常会涉及到图片信息的存储和显示。
常日我们利用的方法是将所要显示的图片存在特定的目录下,在数据库中保存相应的图片的名称,在JSP中建立相应的数据源,利用数据库访问技能处理图片信息。
但是,如果我们想动态的显示图片,上述方法就不能知足须要了。
我们必须把图片存入数据库,然后通过编程动态地显示我们须要的图片。
实际操作中,可以利用JSP的编程模式来实现图片的数据库存储和显示。

2、建立后台数据库

假定处理的是图片新闻,那么我们可以建立相应的数据库及数据表工具。
我们要存取的数据表构造的SQL脚本如下所示:

将数据库中的表显示在jsp页面基于JSP实现数据库中图片的存储与显示 Ruby

if exists (select from dbo.sysobjects where id =

object_id(N'[dbo].[picturenews]') andOBJECTPROPERTY(id, N'IsUserTable') = 1)

drop table [dbo].[picturenews]

GO

CREATE TABLE [dbo].[picturenews] (

[id] [int] IDENTITY (1, 1) NOT NULL ,

[image] [image] NULL ,

[content] [varchar] (500) COLLATE Chinese_PRC_CI_AS NULL ,

[detail] [varchar] (5000) COLLATE Chinese_PRC_CI_AS NULL

) ON [PRIMARY] TEXTIMAGE_ON [PRIMARY]

GO

表picturenews中,字段id作为标识,每存储一行数据,自动增加1。
字段image

用于存储图片信息,其数据类型为“image”。

3、向数据库存储二进制图片

启动Dreamweaver MX后,新建一个JSP文件。
代码如下所示。

<%@ page contentType=\"大众text/html;charset=gb2312\"大众%>

<HTML>

<HEAD>

<TITLE>存储图片</TITLE>

</HEAD>

<body>

<!-- 下面的窗体将以Post方法,将数据通报给testimage.jsp文件 -->

<FORM METHOD=POST ACTION=\公众testimage.jsp\"大众>

新 闻 标 题:<INPUT TYPE=\公众text\"大众 NAME=\"大众content\"大众><BR>

新 闻 图 片:<INPUT TYPE=\公众file\"大众 NAME=\"大众image\"大众><BR>

新闻内容:

<TEXTAREA name=\公众txtmail\"大众 rows=\"大众15\"大众 cols=\"大众90\公众

style=\公众BORDER-BOTTOM: #000000 1px solid; BORDER-LEFT: #000000 1px solid;

BORDER-RIGHT: #000000 1px solid; BORDER-TOP: #000000 1px solid; FONT-SIZE: 9pt;

HEIGHT: 200px; WIDTH: 100%\"大众 wrap=\"大众physical\公众 ></TEXTAREA><br>

<INPUT TYPE=\公众submit\"大众></form>

</body>

</HTML>

将此文件保存为InputImage.jsp文件,个中testimage.jsp文件是用来将图片数据存入数据库的,详细代码如下所示:

<%@ page contentType=\"大众text/html;charset=gb2312\"大众%>

<%@ page import=\"大众java.sql.\公众 %>

<%@ page import=\"大众java.util.\"大众%>

<%@ page import=\"大众java.text.\"大众%>

<%@ page import=\公众java.io.\"大众%>

<html>

<body>

<%

Class.forName(\公众sun.jdbc.odbc.JdbcOdbcDriver\"大众);

//加载驱动程序类

Connection con=DriverManager.getConnection(\"大众jdbc:odbc:denglu\"大众,\"大众sa\"大众,\"大众sa\"大众);

//建立数据库联机,个中denglu为数据库名,sa为连接数据库的帐号及密码。

Statement stmt=con.createStatement();

//建立Statement工具

String content=request.getParameter(\"大众content\公众);

content=new String(content.getBytes(\"大众8859_1\"大众),\"大众gb2312\"大众);

String filename=request.getParameter(\"大众image\公众);

filename=new String(filename.getBytes(\"大众8859_1\"大众),\"大众gb2312\公众);

String detail=request.getParameter(\"大众txtmail\公众);

detail=new String(detail.getBytes(\公众8859_1\公众),\"大众gb2312\"大众);

//得到所要显示图片的标题、存储路径、内容,并进行中文编码

FileInputStream str=new FileInputStream(filename);

String sql=\"大众insert into picturenews(content,image,detail) values(?,?,?)\"大众;

PreparedStatement pstmt=con.prepareStatement(sql);

pstmt.setString(1,content);

pstmt.setBinaryStream(2,str,str.available());

pstmt.setString(3,detail);

pstmt.execute();

//将数据存入数据库

out.println(\"大众Success,You Have Insert an Image Successfully\公众);

%>

4、网页中动态显示图片

接下来我们要编程从数据库中取出图片,其代码如下所示。

<%@ page contentType=\公众text/html;charset=gb2312\"大众%>

<%@ page import=\公众java.sql.\公众 %>

<%@ page import=\"大众java.util.\"大众%>

<%@ page import=\"大众java.text.\公众%>

<%@ page import=\公众java.io.\公众%>

<html>

<body>

<%

Class.forName(\"大众sun.jdbc.odbc.JdbcOdbcDriver\公众);

//加载驱动程序类

Connection con=DriverManager.getConnection(\公众jdbc:odbc:denglu\"大众,\"大众sa\"大众,\公众sa\"大众);

Statement stmt=con.createStatement();

ResultSet rs=null;

//建立ResultSet(结果集)工具

int id= Integer.parseInt(request.getParameter(\"大众id\"大众));

//得到所要显示图片的编号id,并转换为整型

String sql = \"大众select image from picturenews WHERE id=\"大众+id+\"大众\"大众;

//要实行查询的SQL语句

rs=stmt.executeQuery(sql);

while(rs.next()) {

ServletOutputStream sout = response.getOutputStream();

//图片输出的输出流

InputStream in = rs.getBinaryStream(1);

byte b[] = new byte[0x7a120];

for(int i = in.read(b); i != -1;)

{

sout.write(b);

//将缓冲区的输入输出到页面

in.read(b);

}

sout.flush();

//输入完毕,打消缓冲

sout.close();

}

%>

</body>

</html>

将此文件保存为testimageout.jsp文件。
下一步要做的事情便是利用HTML标记:

<IMG src=\公众testimageout.jsp?id=<%=rs.getInt(\"大众id\公众)%>\"大众 width=100 height=100>

取出所要显示的图片,个中id是所要取出图片的编号。
本例中我们输出了第一个和末了一个图片信息,详细的程序代码如下所示。

<%@ page contentType=\公众text/html;charset=gb2312\公众%>

<%@ page import=\"大众java.sql.\"大众 %>

<html>

<head>

<title>动态显示数据库图片</title>

</head>

<body>

<%

Class.forName(\公众sun.jdbc.odbc.JdbcOdbcDriver\公众);

Connection con=DriverManager.getConnection(\公众jdbc:odbc:denglu\"大众,\"大众sa\公众,\"大众sa\"大众);

Statement stmt=con.createStatement();

String sql=new String();

sql= \"大众select from picturenews\"大众;

ResultSet rs=stmt.executeQuery(sql);

rs.last();

//将指针移至末了一条记录

%>

<table>

<tr><td><IMG height=99 src=\"大众testimageout.jsp?id=1\"大众 width=136></td>

//取出第一个图片

<td><IMG height=99 src=\公众testimageout.jsp?id=<%=rs.getInt(\"大众id\"大众)%>\"大众 width=136></td>

//取出末了一个图片

</tr></table>

</body>

</html>

以上WEB运用程序在Windows 2000 Professional/SQL Server 2000/ Apache Tomcat 4.0/JDK 1.4 JAVA环境下调试通过。