数据库存取图片 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控件,其路径指向该界面即可。
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控件,其路径指向该界面即可。
相关文章推荐
- asp.net中将图片或文件存入数据库并读取显示在image控件中
- ASP.NET 上传图片至数据库并读取图片显示
- ASP.NET 上传图片至数据库并读取图片显示
- ASP.NET中存取图片到数据库的示例
- asp.net显示图片到指定的Image控件中 具体实现
- ASP.NET中存取图片到数据库的示例(转载http://www.knowsky.com/3257.html)
- asp.net(c#)从数据库里读取图片并显示到页面
- Asp.net中图片存储数据库以及页面读取显示通用方法详解
- 怎样用asp.net存取并显示sql sever2000中的图片数据呀?(转)
- ASP.NET 上传图片至数据库并读取图片显示
- ASP.NET把图片存入数据库和使用文件流读取显示(转)
- ASP.NET中存取图片到数据库的示例
- Asp.net中图片存储数据库以及页面读取显示通用方法详解
- asp.net mvc 2.0 简单的上传图片到数据库和显示图片
- 在ASP.NET中存取图片到数据库的示例
- Asp.net中图片存储数据库以及页面读取显示通用方法详解
- ASP.net:上传图片以二进制插入到数据库,且读取显示
- Asp.net 中图片存储数据库以及页面读取显示通用方法详解
- ASP.NET数据库存取图片的方法
- ASP.Net数据库如何存取图片