用ASP.NET 2.0在Oracle中存取图片(文件)的操作

asp.net|oracle

有时由于某种需要(如安全性)须将图片或文件存放在数据库中,当然一般情况下特别是文件比较大的时候很多人不提倡将文件以二进制的形式存放在数据库中的,现将Oracle中文件的存取整理如下(思路和在SQL Server2000中存取一样,存储时在数据中存放图片或文件的二进制字节流,读出时将数据库中对应字段读取到字节数据,然后输出):
       1、在TOAD或SQLPlus中创建一下数据库表。

1CREATE TABLE TEST_TABLE
2(
3  ID     VARCHAR2(36 BYTE),
4  NAME   VARCHAR2(50 BYTE),
5  PHOTO  BLOB
6)
7

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

保存图片(文件)到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

  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}
34

时间: 2024-09-17 04:35:21

用ASP.NET 2.0在Oracle中存取图片(文件)的操作的相关文章

如何在SQLite数据库中存取图片文件

前段时间在做一款嵌入式项目,用到了SQLite数据库,现在就SQLite数据库中存取图片问题来与大家共享一下,对于二进制数据我们自然是不能够直接进行存储,在SQLite中我们可以将其转换而后存储. 下面就言归正传 在对主句操作之前我们先要打开数据库,SQLite给用户提供了丰富的API,足以使我们来驾驭它,利用sqlite3_open()函数,打开我们所要操作的数据库,接下来就是对于我们的图片文件的操作了,我在这里的方法便是将图片文件转换成字符流,而后进行存储. 下面我就以一个简单的范例来说明问

“ASP.NET 2.0 正式版中无刷新页面的开发”中示例代码与Firefox兼容的解决

asp.net|解决|示例|刷新|无刷新|页面 这几天正着手开始写毕业设计,因为发生了一些事情,所以一直拖到现在才开始.其实我准备做一个ASP.NET 2.0并且使用AJAX的Web项目,于是到博客园到处寻着AJAX的文章,恰好翻到了Leon.Zhou的ASP.NET 2.0 正式版中无刷新页面的开发按照代码示例和讲解做了一个页面,确实不错啊.因为俺平时几乎都用Firefox,所以就顺手测试了一下Firefox下的效果,结果发现点了Button之后没有反应--于是打开Javascript控制台,

在WINDOWS 10 64位环境,实现 ASP.NET 4.0 连接ORACLE 11g

问题描述 在WINDOWS 10 64位环境,实现 ASP.NET 4.0 连接ORACLE 11g 如题 环境 window 10 64位 需要让ASP.NET 连接到 ORACLE 数据库 解决方案 关于redhat 6.3 环境下 安装模拟pl/sql developer连接oracle 11g的方法Windows 64位 PLSQL Developer 连接Oracle 11g 64位Win7 64位 的VS2010 ASP.NET连接 Oracle 11g

asp.net 4.0+ webform程序中集成mvc4_实用技巧

本文为大家分享了asp.net 4.0+ webform程序中集成mvc4的方法,供大家参考,具体内容如下 1.新建packages.config文件,里面加上必要的程序集  <?xml version="1.0" encoding="utf-8"?> <packages> <package id="Microsoft.AspNet.Mvc" version="4.0.20710.0" targe

在ORACLE中移动数据库文件

在ORACLE中移动数据库文件 ---- ORACLE数据库由数据文件,控制文件和联机日志文件三种文件组成.由于磁盘空间的变化,或者基于数据库磁盘I/O性能的调整等,数据库管理员可能会考虑移动数据库文件.下面以UNIX平台为例,分别讨论三种数据库文件的移动方法. ---- 一.移动数据文件: ---- 可以用ALTER DATABASE,ALTER TABLESPACE两种方法移动数据文件. ---- 1. ALTER DATABASE方法: ---- 用此方法,可以移动任何表空间的数据文件.

asp.net mvc4 如何向mysql 中实现 增删改查操作

问题描述 asp.net mvc4 如何向mysql 中实现 增删改查操作 如题,最近在写一个基于asp.net mvc4网站,后台要求使用mysql数据库,现在的情况是数据库可以连通,单独的sql也会写,但是我不知道按照规范应该在哪写,以及如何通过方法写对应实体的增删改查这些个基本操作,还望有经验的高手能够指点一二! 解决方案 mysql也有entity provider,如果你用它,那么编程和使用sql server没有什么不同. 解决方案二: http://ju.outofmemory.c

uri-Android中如何读入文件夹中的图片文件并得到该图片的名称

问题描述 Android中如何读入文件夹中的图片文件并得到该图片的名称 补充内容,我按照下面的方式读取了一张图片,能不能得到这个图片的名字?比如图片的名字为"XD0001.jpg",如何得到"XD0001"这个字符串? 我现在有一个程序,是从相册选择一张图片后裁剪,保存然后才能进入后面的处理,我现在想把裁剪功能去掉,并想实现读取文件夹中的所有图片,并能一张张的进行处理,我该怎么改? 现在的代码是: 这个是onActivityResult需要改的部分代码 protec

PowerPoint 2013中自定义图片边框怎么操作

  PowerPoint 2013中自定义图片边框怎么操作           1.启动PowerPoint 2013并打开演示文稿,在幻灯片中选择需要自定义边框的图片.然后在"图片工具-格式"选项卡的"图片样式"组中单击"图片边框"按钮,在打开的列表中选择"虚线"选项,再在级联列表中选择相应的选项设置线条样式,如图1所示. 图1 设置线条样式 2.单击"图片边框"按钮,在打开的列表中选择"粗细&

win7电脑中的图片文件无法显示缩略图怎么办?

  说起咱们w764位旗舰版电脑中的缩略图功能,想必大家是不会陌生的吧,因为缩略图功能是咱们win7旗舰版电脑中的一个特有的,创新的功能,这个功能是之前的winXP系统中所没有的.特别是图片文件,直接有这个缩略图,用户可以更加直观的查看到这个文件的内容,十分的方便.但是最近,却有使用win7旗舰版电脑的用户反映说,自己win7旗舰版电脑中的图片文件无法显示缩略图了,那么这个问题,咱们要如何解决呢?下面,小编就来详细的介绍一下吧! 1.首先,咱们返回到win7旗舰版电脑的桌面位置,在桌面上,咱们找