ASP.NET附件上传和下载

【背景和需求要求】

  1. ASP.NET+DevExpress第三方控件实现Web Form应用(在线公证服务)
  2. 附件有多种类型,doc/sql/jpg/png/….,目前没有限制附件类型,不过真实情况下应该会限制,这种限制既可以在附件上传控件的属性上做限制,也可以在代码中用正则表达式做限制,当然这种限制是由管理员提出的。
  3. 不同的公证可能需要上传不同的附件,因此前台需要动态生成n个附件上传的控件(FileUpload或者其他),点击上传后,附件上传到数据库中或者服务器上
  4. 附件的下载支持单文件下载,也支持多文件打包压缩后下载。下载到客户端机器上

【附件上传】
1. 思路一
文件上传,将文件内容转换为二进制流(byte[]字符串),然后将二进制流写入到Insert方法中
将文件转换为字节数组,并作为一个字段保存到数据库中,在Oracle数据库中相应字段为BLOB(二进制的大数据对象),在MS SQLServer中是image类型。
实现步骤:
① 

--1.建表
CREATE TABLE TA_附件( 附件编号 VARCHAR2(5) CONSTRAINTS PK_附件_编号 PRIMARY KEY, 附件名称 VARCHAR2(100) NOT NULL, 附件内容 BLOB NOT NULL, 附件类型 VARCHAR2(20), 附件大小 INTEGER, 附件上传时间 DATE, 是否上传成功 VARCHAR2(2) DEFAULT '0' );

-- Add comments to the columns 
comment on column TA_附件.附件类型
  is 'jpg|gif|doc|*';
comment on column TA_附件.是否上传成功
  is '0-上传失败,1-上传成功,默认失败';

--2.建序列
CREATE SEQUENCE SEQ_附件编号 START WITH 1 INCREMENT BY 1 MINVALUE 1 NOMAXVALUE NOCYCLE NOCACHE --3.建触发器 CREATE OR REPLACE TRIGGER TR_附件编号 BEFORE INSERT ON TA_附件 FOR EACH ROW BEGIN SELECT SEQ_附件编号.Nextval INTO :NEW.附件编号 FROM dual;
END;

ASP.NET附件上传和下载_第1张图片
② 动态生成附件上传控件
③ 将控件包含的文件插入到数据库中,这里也有两种方法,面向连接和面向无连接的ADO.NET操作。
注意:
ASP.NET附件上传和下载_第2张图片
2.思路二
将附件上传到服务器上(即在服务器上建个存放附件的文件夹),然后数据库里只需存放文件名称和文件的地址(服务器上的地址),这个待做
【附件下载】
要实现的效果是:首先勾选复选框,选择要下载的附件(可以是多个),然后“下载附件”按钮,最后多个文件以一个压缩包的形式下载到本地。

1. 思路一:对应于附件内容保存在数据库中
可以实现下载一个文件到本地

List<Object> selectItems = gvFJXZ.GetSelectedFieldValues("附件编号");
  foreach (object item in selectItems)
            {
                TA_附件TableAdapter ada = new TA_附件TableAdapter();
                DataSet1.TA_附件DataTable dt = new DataSet1.TA_附件DataTable();
                ada.FillByBH(dt, item.ToString());
                //根据附件编号取出数据库中对应的附件名称和附件内容
                string name = "";
                byte[] binaryData;
                name = dt.Rows[0]["附件名称"].ToString();
                binaryData = (byte[])dt.Rows[0]["附件内容"];
           //单个文件下载到本地方法二
        BinaryWriter bw = new BinaryWriter(File.Open("D:\\Projects\\ASP.NET_Controls\\fj", FileMode.OpenOrCreate));
        bw.Write(binaryData);
        bw.Close();

        //单个文件下载到本地方法一
        Response.Buffer = true;
        Response.Clear();
        Response.ContentType = dt.Rows[0]["附件类型"].ToString();
        Response.AddHeader("Content-Disposition", "attachment;filename=" + HttpUtility.UrlEncode(dt.Rows[0]["附件名称"].ToString()));
        Response.BinaryWrite((byte[])dt.Rows[0]["附件内容"]);
        Response.Flush();
        Response.End();
            }

如果要实现多个文件一次性下载到本地,就需要首先将文件下载到服务器上特定文件夹中,然后在打包多个文件后删除服务器上的多个单文件,最后在将压缩包从服务器下载到本地后,删除服务器上的压缩包。(需要程序集 ICSharpCode.SharpZipLib.dll)http://download.csdn.net/download/njxiaogui/8251031
2.思路二:对应于附件路径保存在数据库中,而文件本身保存在服务器上,待做

【参考文章】
asp.net 多个文件同时下载
http://www.cnblogs.com/smile-wei/p/4159213.html
ASP.NET附件上传下载
http://blog.csdn.net/muximuxi_kgsecond/article/details/8374260
Winform开发框架之附件管理应用(伍华聪)
http://www.cnblogs.com/wuhuacong/p/3360997.html
c#数据库存取图片的三种方式
http://blog.csdn.net/llftc/article/details/7099663
DevExpress GridView使用教程:列表中显示该记录是否包含附件
https://www.evget.com/article/2014/3/27/20736.html
C#实现文件与二进制互转并存入数据库
http://www.jb51.net/article/68443.htm
http://blog.csdn.net/fairyeye/article/details/6970266
【下载地址】
ASP.NET附件上传和下载_第3张图片
ASP.NET附件上传和下载_第4张图片

你可能感兴趣的:(asp.net,DevExpress,附件上传下载)