用ASP.NET 2.0在Oracle中存取图片(文件)的操作
2006-12-23 12:15
393 查看
[align=left]有时由于某种需要(如安全性)须将图片或文件存放在数据库中,当然一般情况下特别是文件比较大的时候很多人不提倡将文件以二进制的形式存放在数据库中的,现将Oracle中文件的存取整理如下(思路和在SQL Server2000中存取一样,存储时在数据中存放图片或文件的二进制字节流,读出时将数据库中对应字段读取到字节数据,然后输出):
1、在TOAD或SQLPlus中创建一下数据库表。[/align]
[align=left] [/align]
[align=left]
1CREATE TABLE TEST_TABLE
2(
3 ID VARCHAR2(36 BYTE),
4 NAME VARCHAR2(50 BYTE),
5 PHOTO BLOB
6)
7[/align]
[align=left] [/align]
[align=left]2、新建一个ASPX页面,在页面上放一个FileUpload控件,命名为fileUp,放置两个按钮分布为btnSave(保存),btnRead(读取)。
3、在btnSave的事件中执行一下代码,用来保存图片或文件:[/align]
[align=left] [/align]
[align=left]
保存图片(文件)到Oracle
1StringBuilder sbSQL = new StringBuilder("insert into Test_Table(ID,Name,Photo) values(:ID,:Name,:Photo)");
2 OracleConnection cn = new OracleConnection(strCn);
3 OracleCommand cmd = cn.CreateCommand();
4 cmd.CommandText = sbSQL.ToString();
5 cmd.Parameters.Add(":ID", OracleType.VarChar, 36).Value = Guid.NewGuid().ToString();
6 cmd.Parameters.Add(":Name", OracleType.VarChar, 50).Value = fileUp.FileName; ;
7 int intLen = fileUp.PostedFile.ContentLength;
8 byte[] pic = new byte[intLen];
9 fileUp.PostedFile.InputStream.Read(pic, 0, intLen);
10 cmd.Parameters.Add(":Photo", OracleType.Blob).Value = pic;
11 try
12 {
13 cn.Open();
14 cmd.ExecuteNonQuery();
15 }
16 catch (Exception ex)
17 {
18 Response.Write(ex.Message);
19 }
20 finally
21 {
22 cn.Close();
23 }
24[/align]
[align=left] [/align]
[align=left] 4、读取方法如下:[/align]
[align=left] [/align]
[align=left]
从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}
34
http://www.cnblogs.com/weiweictgu/archive/2006/11/17/563761.html[/align]
[align=left]
参考示例 : http://www.5h6.com/article/28011.html[/align]
相关文章推荐
- 照葫芦画瓢,用ASP.NET 2.0在Oracle中存取图片(文件)的操作
- 用asp.net 2.0在oracle中存取图片(文件)的操作
- IBatis存取图片在Oracle Blob大字段中Asp.Net
- [译]ASP.NET Core 2.0 本地文件操作
- ASP.NET的一般处理程序对图片文件的基本操作
- 在ASP.NET 2.0中操作数据之五十二:使用FileUpload上传文件
- 在ASP.NET 2.0中操作数据之五十四:添加新记录时包含一个文件上传选项
- IBatis存取图片在Oracle Blob大字段中Asp.Net
- Asp.Net Core 2.0 生成操作数据库文件需要的文件
- 在ASP.NET 2.0中操作数据之五十二:使用FileUpload上传文件
- 在ASP.NET 2.0中操作数据之五十四:添加新记录时包含一个文件上传选项
- ASP.NET SignalR 与 LayIM2.0 配合轻松实现Web聊天室(三) 之 实现单聊,群聊,发送图片,文件。
- IBatis存取图片在Oracle Blob大字段中Asp.Net
- IBatis存取图片在Oracle Blob大字段中Asp.Net
- ASP.NET SignalR 与 LayIM2.0 配合轻松实现Web聊天室(七) 之 历史记录查询(时间,关键字,图片,文件),关键字高亮显示。
- ASP.NET Core 2.0 本地文件操作问题及解决方案
- Asp.Net 文件操作基类(读取,删除,批量拷贝,删除,写入,获取文件夹大小,文件属性,遍历目录)
- Asp.net 2.0 关于Header/title/Meta tages/Style操作的一点小技巧
- asp.net 2.0中文件编码问题
- Asp.Net文件和文件夹操作大全