大学最近作出相关的需求进行上传和下载文件的网站(求为:站点发布的通知,在后台要能给每一个通知加入附件。在前台要能显示并下载附件),之前仅仅是学习过关于上传的 理论知识,这里实践了一下下,与大家分享一下成果。

事先说明:这个样例採用的是简单的三层结构,层与层之间是用实体来传值。

并且这样的方法不但在本地測试时能够成功,并且能够部署在server上,供异地上传和下载文件。

专门做了一个数据库表用来存储附件的相关信息:

字段 说明
AnnexID 附件ID
AnnexName 附件名称
AnnexAddress 存储附件的地址
NoticeID 附件所属“通知”的ID

ASP.NET实现上传文件

前端

界面十分简单。仅仅是放一个file类型的<input>和一个button,而且为这个button加入点击事件(btnUpLoad_Click),例如以下图:

代码:

    <input id="UpLoad" type="file" runat="server" />
<asp:Button runat="server" Text="上传" ID="btnUpLoad" OnClick="btnUpLoad_Click" />

后台

再就是在后台编写上传button点击事件UpLoad_Click里的代码,先大体说一下思路:

1、依据file类型的<input>控件获得将要上传文件在本机的物理路径。

2、在这个物理路径中用截取字符串的方法获得文件名称(第一步中取得的路径为本机的绝对路径,在server上是无效的,所以这里我们仅仅须要获取文件名称)。

3、利用file类型的<input>控件属性PostedFile的SaveAs()方法将对应文件存储到server中指定的目录中。

核心代码:

    protected void btnUpLoad_Click(object sender, EventArgs e)
{
//取出所选文件的本地路径
string fullFileName = this.UpLoad.PostedFile.FileName;
//从路径中截取出文件名称
string fileName = fullFileName.Substring(fullFileName.LastIndexOf("\\") + 1);
//限定上传文件的格式
string type = fullFileName.Substring(fullFileName.LastIndexOf(".") + 1);
if (type == "doc" || type == "docx" || type == "xls" || type == "xlsx" || type == "ppt" || type == "pptx" || type == "pdf" || type == "jpg" || type == "bmp" || type == "gif" || type == "png" || type == "txt" || type == "zip" || type == "rar")
{
//将文件保存在server中根文件夹下的files文件夹中
string saveFileName = Server.MapPath("/files") + "\\" + fileName;
UpLoad.PostedFile.SaveAs(saveFileName);
Page.ClientScript.RegisterStartupScript(Page.GetType(), "message", "<script language='javascript' defer>alert('文件上传成功。');</script>"); //向数据库中存储对应通知的附件的文件夹
BLL.news.InsertAnnexBLL insertAnnex = new BLL.news.InsertAnnexBLL();
AnnexEntity annex=new AnnexEntity(); //创建附件的实体
annex.AnnexName=fileName; //附件名
annex.AnnexContent=saveFileName; //附件的存储路径
annex.NoticeId = noticeId; //附件所属“通知”的ID在这里为已知
insertAnnex.InsertAnnex(annex); //将实体存入数据库(事实上就是讲实体的这些属性insert到数据库中的过程。详细BLL层和DAL层的代码这里不再多说)
}
else
{
Page.ClientScript.RegisterStartupScript(Page.GetType(), "message", "<script language='javascript' defer>alert('请选择正确的格式');</script>");
}
}

ASP.NET实现下载文件

上述操作已经能够实现将一个个附件存入数据库,在数据库中存储的情况给大家截了个图:

watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQvaHV5dXlhbmc2Njg4/font/5a6L5L2T/fontsize/400/fill/I0JBQkFCMA==/dissolve/70/gravity/Center">

以下就要把这些附件在页面上显示,页面显示效果为:

点击附件,浏览器提示下载:

watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQvaHV5dXlhbmc2Njg4/font/5a6L5L2T/fontsize/400/fill/I0JBQkFCMA==/dissolve/70/gravity/Center">

前台

依照需求来说,每则公布的通知能够包括若干个附件,所一前台用了repeter控件来显示多个附件:

代码:

    <asp:Repeater ID="rptAnnex" runat="server">
<ItemTemplate>
<%--为repeter加入序号--%>
附件:<%#Container.ItemIndex + 1 %>
<asp:LinkButton ID="lbtnDownLoad" runat="server" OnCommand="lbtnDownLoad_Command" CommandArgument="<%#((Model.AnnexEntity)Container.DataItem).AnnexContent %>"><%#((Model.AnnexEntity)Container.DataItem).AnnexName %></asp:LinkButton>
<br />
</ItemTemplate>
</asp:Repeater>

后台

ASP.NET能够採用多种方式下载文件(详情可參考《ASP.NET下载文件的几种方式》),这里採用了流式的下载方式(參考文章《Asp.net下载实例》):

 using System.IO;
protected void lbtnDownLoad_Command(object sender, CommandEventArgs e)
{
// 定义文件名称
string fileName = "";
// 获取文件在server的地址
string url = e.CommandArgument.ToString(); // 推断传输地址是否为空
if (url == "")
{
// 提示“该文件暂不提供下载”
Page.ClientScript.RegisterStartupScript(Page.GetType(), "message", "<script defer>alert('该文件暂不提供下载! ');</script>");
return;
}
// 推断获取的是否为地址。而非文件名称
if (url.IndexOf("\\") > -1)
{
// 获取文件名称
fileName = url.Substring(url.LastIndexOf("\\") + 1);
}
else
{
// url为文件名称时,直接获取文件名称
fileName = url;
}
// 以字符流的方式下载文件
FileStream fileStream = new FileStream(@url, FileMode.Open);
byte[] bytes = new byte[(int)fileStream.Length];
fileStream.Read(bytes, 0, bytes.Length);
fileStream.Close();
Response.ContentType = "application/octet-stream"; // 通知浏览器下载
Response.AddHeader("Content-Disposition", "attachment; filename=" + fileName);
Response.BinaryWrite(bytes);
Response.Flush();
Response.End();
}

控制上传文件的大小

前面的两个步骤基本上已经能够实现文件的上传和下载。除了这些,还须要控制上传文件的大小,默认情况下上传文件限制大小为4M,这里能够在配置文件web.config中改动,在httpRuntime节点中增加例如以下属性就可以:

<configuration>
<system.web>
<httpRuntime executionTimeout="300" maxRequestLength="51200" useFullyQualifiedRedirectUrl="false" />
</system.web>
</configuration>

executionTimeout 属性的值是 ASP.NET 关闭前同意发生的上载秒数,maxRequestLength指限制上传文件的大小,useFullyQualifiedRedirectUrl指示client重定向是否是全然限定的,或者指示是否代之以将相对重定向发送到client。

到这里就大功告成了,欢迎分享更好的方法!

版权声明:本文博客原创文章。博客,未经同意,不得转载。

ASP.NET文件上传和下载的更多相关文章

  1. ASP.NET 文件上传于下载

    本文主要介绍一下,在APS.NET中文件的简单上传于下载,上传是将文件上传到服务器的指定目录下,下载是从存入数据库中的路径,从服务器上下载. 1.上传文件 (1)页面代码 <table alig ...

  2. 2014-07-23 利用ASP.NET自带控件实现单文件上传与下载

    效果图 上传文件页面: 下载文件页面:  1.母版页site.Master <%@ Master Language="C#" AutoEventWireup="tr ...

  3. [转载]ASP.NET Core文件上传与下载(多种上传方式)

    ASP.NET Core文件上传与下载(多种上传方式)   前言 前段时间项目上线,实在太忙,最近终于开始可以研究研究ASP.NET Core了. 打算写个系列,但是还没想好目录,今天先来一篇,后面在 ...

  4. C# 之 FTPserver中文件上传与下载(二)

            通过上一篇博客<C# 之 FTPserver中文件上传与下载(一)>,我们已经创建好了一个FTPserver,而且该server须要username和password的验证 ...

  5. java web学习总结(二十四) -------------------Servlet文件上传和下载的实现

    在Web应用系统开发中,文件上传和下载功能是非常常用的功能,今天来讲一下JavaWeb中的文件上传和下载功能的实现. 对于文件上传,浏览器在上传的过程中是将文件以流的形式提交到服务器端的,如果直接使用 ...

  6. (转载)JavaWeb学习总结(五十)——文件上传和下载

    源地址:http://www.cnblogs.com/xdp-gacl/p/4200090.html 在Web应用系统开发中,文件上传和下载功能是非常常用的功能,今天来讲一下JavaWeb中的文件上传 ...

  7. JavaWeb学习总结,文件上传和下载

    在Web应用系统开发中,文件上传和下载功能是非常常用的功能,今天来讲一下JavaWeb中的文件上传和下载功能的实现. 对于文件上传,浏览器在上传的过程中是将文件以流的形式提交到服务器端的,如果直接使用 ...

  8. java文件上传和下载

    简介 文件上传和下载是java web中常见的操作,文件上传主要是将文件通过IO流传放到服务器的某一个特定的文件夹下,而文件下载则是与文件上传相反,将文件从服务器的特定的文件夹下的文件通过IO流下载到 ...

  9. 使用jsp/servlet简单实现文件上传与下载

    使用JSP/Servlet简单实现文件上传与下载    通过学习黑马jsp教学视频,我学会了使用jsp与servlet简单地实现web的文件的上传与下载,首先感谢黑马.好了,下面来简单了解如何通过使用 ...

随机推荐

  1. 【Arduino】8地点LED数码管(3461BS)

    淘宝买了一块3461BS的8地点LED数码管,婴儿就迫不及待地尝试,结果看到了文件,好家伙无Arduino测试程序. 莫急~莫急~无论如何串行操作,大不了呗瞎蒙! 以下几点是在更有趣的点瞎蒙: 1.须 ...

  2. ArcGIS For Flex报错

    1.错误描写叙述 2.错误原因 3.解决的方法

  3. 飘逸的python - 发送带各种类型附件的邮件

    上一篇博文演示了如何发送简单的邮件,这一篇将演示如何发送各种类型的附件. 基本思路就是,使用MIMEMultipart来标示这个邮件是多个部分组成的,然后attach各个部分.如果是附件,则add_h ...

  4. 二十7天 春雨滋润着无形 —Spring依赖注入

    6月11日,明确."夏条绿已密,朱萼缀明鲜.炎炎日正午,灼灼火俱燃." IT人习惯把详细的事物加工成的形状一致的类.正是这种一致,加上合适的规范.才干彰显对象筋道的牙感和bean清 ...

  5. 重新想象 Windows 8 Store Apps (7) - 控件之布局控件: Canvas, Grid, StackPanel, VirtualizingStackPanel, WrapGrid, VariableSizedWrapGrid

    原文:重新想象 Windows 8 Store Apps (7) - 控件之布局控件: Canvas, Grid, StackPanel, VirtualizingStackPanel, WrapGr ...

  6. 2014在辛星Javascript口译科

    ***************概要*************** 1.Javascript是一种原型化继承的基于对象的动态类型的脚本语言,它区分大写和小写.主要执行在client,用户即使响应用户的操 ...

  7. yum使用总结(转)

    安装一个软件时yum -y install httpd安装多个相类似的软件时yum -y install httpd*安装多个非类似软件时yum -y install httpd php php-gd ...

  8. 初探ExtJS(2)

    二.建立第一个Demo.实现查数据库显示到页面 步骤:1.建立MySQL数据库表 2.整合SSH框架 3.用ExtJS显示 关键注意事项: Ext.data.JsonReader中root的含义,比如 ...

  9. OTN&互换amp; P-OTN有效降低100G 网络成本 (两)

    OTN互换& P-OTN有效降低100G 网络成本 (两) 在全球范围内.网流量的增长速度是空前的,导致此现象的缘由包含云服务的增长.移动宽带和基于互联网的视频点播服务的增长. Cisco估计 ...

  10. c# 通过配置自动附加数据库

    using System; using System.Collections.Generic; using System.Windows.Forms; using System.Data.SqlCli ...