您的位置:首页 > 编程语言 > ASP

数据库存取图片 asp.net 显示到Image控件

2008-03-19 12:15 543 查看
1、在TOAD或SQLPlus中创建一下数据库表。

CREATE TABLE TEST_TABLE
(
ID VARCHAR2(36 BYTE),
NAME VARCHAR2(50 BYTE),
PHOTO BLOB
)

2、新建一个ASPX页面,在页面上放一个FileUpload控件,命名为fileUp,放置两个按钮分布为btnSave(保存),btnRead(读取)。
3、在btnSave的事件中执行一下代码,用来保存图片或文档:

保存图片(文档)到Oracle
StringBuilder sbSQL = new StringBuilder("insert into Test_Table(ID,Name,Photo) values(:ID,:Name,:Photo)");
OracleConnection cn = new OracleConnection(strCn);
OracleCommand cmd = cn.CreateCommand();
cmd.CommandText = sbSQL.ToString();
cmd.Parameters.Add(":ID", OracleType.VarChar, 36).Value = Guid.NewGuid().ToString();
cmd.Parameters.Add(":Name", OracleType.VarChar, 50).Value = fileUp.FileName; ;
int intLen = fileUp.PostedFile.ContentLength;
byte[] pic = new byte[intLen];
fileUp.PostedFile.InputStream.Read(pic, 0, intLen);
cmd.Parameters.Add(":Photo", OracleType.Blob).Value = pic;
try
{
cn.Open();
cmd.ExecuteNonQuery();
}
catch (Exception ex)
{
Response.Write(ex.Message);
}
finally
{
cn.Close();
}

4、读取方法如下:

从Oracle中读取图片(文档)
1OracleConnection cn = new OracleConnection(strCn);
2OracleCommand cmd = cn.CreateCommand();
3cmd.CommandText = "select photo from test_table";
4try
5{
6 cn.Open();
7 MemoryStream stream = new MemoryStream();
8 IDataReader reader = cmd.ExecuteReader();
9 if (reader.Read())
10 {
11 byte[] pic = (byte[])reader[0];
12 //byte[] pic = (byte[])cmd.ExecuteScalar();
13 stream.Write(pic, 0, pic.Length);
14 //Bitmap bitMap = new Bitmap(stream);
15 //Response.ContentType = "image/Jpeg";
16 //bitMap.Save(Response.OutputStream, ImageFormat.Jpeg);
17 //注释部分能够将图片显示在IE中,而不是下载图片,
18 //下面的方法直接下载文档
19 Response.ContentType = "application/octet-stream";
20 Response.AddHeader("Content-Disposition", "attachment;FileName= demo.JPG");
21 Response.BinaryWrite(pic);
22 Response.End();
23 }
24
25}
26catch (Exception ex)
27{
28 Response.Write(ex.Message);
29}
30finally
31{
32 cn.Close();
33}

显示时可以在新建一个界面,专门用来显示图片,在需要显示到界面上添加一个Image控件,其路径指向该界面即可。
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: