asp.net实现大文件上传

需要下载NeatUpload插件

上传页面:

<%@ Page Language="C#" AutoEventWireup="true" CodeFile="index.aspx.cs" Inherits="_Default" %>

<%@ Register Assembly="Brettle.Web.NeatUpload" Namespace="Brettle.Web.NeatUpload"
    TagPrefix="Upload" %>

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">

<html xmlns="http://www.w3.org/1999/xhtml">
<head runat="server">
    <title></title>
     <link href="easyui/themes/default/easyui.css" rel="stylesheet" type="text/css" />
    <link href="easyui/themes/icon.css" rel="stylesheet" type="text/css" />
    <script src="easyui/jquery.min.js" type="text/javascript"></script>
    <script src="easyui/jquery.easyui.min.js" type="text/javascript"></script>
</head>
<body>
    <form id="form1" runat="server">
    <div class="easyui-panel" style="padding:5px;">
        <Upload:ProgressBar ID="ProgressBar1" runat=‘server‘>
        </Upload:ProgressBar>
      <br />
    <Upload:InputFile ID="AttachFile" runat="server" />
    <br />
    <br />
    <asp:LinkButton ID="BtnUP" runat="server" class="easyui-linkbutton" data-options="iconCls:‘icon-add‘" onclick="BtnUP_Click">上 传</asp:LinkButton><br /><br />
    <a href="Down.aspx">查看下载</a>
    </div>
    </form>
</body>
</html>

后台源码:

protected void BtnUP_Click(object sender, EventArgs e)
    {
        if (AttachFile.HasFile)
        {
            string FileName = this.AttachFile.FileName;//获取上传文件的文件名,包括后缀
            string ExtenName = System.IO.Path.GetExtension(FileName);//获取扩展名
            string SaveFileName = System.IO.Path.Combine(System.Web.HttpContext.Current.Request.MapPath("UpLoads/"), DateTime.Now.ToLongDateString().ToString() + "-" + FileName);//合并两个路径为上传到服务器上的全路径
            AttachFile.MoveTo(SaveFileName, Brettle.Web.NeatUpload.MoveToOptions.Overwrite);
            string url = "UpLoads/" + DateTime.Now.ToString("yyyyMMddhhmmss") + ExtenName; //文件保存的路径
            float FileSize = (float)System.Math.Round((float)AttachFile.ContentLength / 1024000, 1); //获取文件大小并保留小数点后一位,单位是M
            Response.Write("<script>alert(‘恭喜您,上传成功!‘)</script>");
        }
        else
        {
            Response.Write("<script>alert(‘请选择文件!‘)</script>");
        }
    }

这里直接获取上传文件夹文件名称提供下载

<%@ Page Language="C#" AutoEventWireup="true" CodeFile="Down.aspx.cs" Inherits="Down" %>

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head runat="server">
    <title></title>
    <link href="easyui/themes/default/easyui.css" rel="stylesheet" type="text/css" />
    <link href="easyui/themes/icon.css" rel="stylesheet" type="text/css" />
    <script src="easyui/jquery.min.js" type="text/javascript"></script>
    <script src="easyui/jquery.easyui.min.js" type="text/javascript"></script>
    <style type="text/css">
        .div_style  ul li
        {
             list-style-type: decimal;
             border-bottom:1px dashed #E3E3E3;
             margin-bottom:5px;
        }
        .div_style ul li a
        {
            text-decoration: none;
            cursor: pointer;
            font-size: 16px;
        }
    </style>
</head>
<body>
    <form id="form1" runat="server">
    <div class="div_style easyui-panel" style="padding: 5px;">
    <a href="index.aspx">上传文件</a>
        <asp:Label ID="Label1" runat="server" Text=""></asp:Label>
        <ul  id="www_zzjs_net">
            <%if (files.Length == 0) { Label1.Text = "暂无文件"; }
              else
              {

                  foreach (System.IO.FileInfo item in files)
                  {%>
            <li><a href="Default2.aspx?1=<%=item%>">
                <%=item %></a> &nbsp;&nbsp; &nbsp;<a href="delete.aspx?1=<%=item%>" onclick="javascript:return confirm(‘确定删除吗?‘);" >删除附件</a>
            </li>
            <% }
          }%>
        </ul>
    </div>
    <div id="changpage"></div>
    <%--js分页--%>
<%--<script language="javascript">
    var obj, j;
    var page = 0;
    var nowPage = 0; //当前页
    var listNum = 25; //每页显示<ul>数
    var PagesLen; //总页数
    var PageNum = 4; //分页链接接数(5个)
    onload = function () {
        obj = document.getElementById("www_zzjs_net").getElementsByTagName("li");
        j = obj.length
        PagesLen = Math.ceil(j / listNum);
        upPage(0)
    }
    function upPage(p) {
        nowPage = p
        //内容变换
        for (var i = 0; i < j; i++) {
            obj[i].style.display = "none"
        }
        for (var i = p * listNum; i < (p + 1) * listNum; i++) {
            if (obj[i]) obj[i].style.display = "block"
        } //欢迎来到站长特效网,我们的网址是www.zzjs.net,很好记,zz站长,js就是js特效,本站收集大量高质量js代码,还有许多广告代码下载。
        //分页链接变换
        strS = ‘<a href="###" onclick="upPage(0)">首页</a>  ‘
        var PageNum_2 = PageNum % 2 == 0 ? Math.ceil(PageNum / 2) + 1 : Math.ceil(PageNum / 2)
        var PageNum_3 = PageNum % 2 == 0 ? Math.ceil(PageNum / 2) : Math.ceil(PageNum / 2) + 1
        var strC = "", startPage, endPage;
        if (PageNum >= PagesLen) { startPage = 0; endPage = PagesLen - 1 }
        else if (nowPage < PageNum_2) { startPage = 0; endPage = PagesLen - 1 > PageNum ? PageNum : PagesLen - 1 } //首页
        else { startPage = nowPage + PageNum_3 >= PagesLen ? PagesLen - PageNum - 1 : nowPage - PageNum_2 + 1; var t = startPage + PageNum; endPage = t > PagesLen ? PagesLen - 1 : t }
        for (var i = startPage; i <= endPage; i++) {
            if (i == nowPage) strC += ‘<a href="###" style="color:red;font-weight:700;" onclick="upPage(‘ + i + ‘)">‘ + (i + 1) + ‘</a> ‘
            else strC += ‘<a href="###" onclick="upPage(‘ + i + ‘)">‘ + (i + 1) + ‘</a> ‘
        } //欢迎来到站长特效网,我们的网址是www.zzjs.net,很好记,zz站长,js就是js特效,本站收集大量高质量js代码,还有许多广告代码下载。
        strE = ‘ <a href="###" onclick="upPage(‘ + (PagesLen - 1) + ‘)">尾页</a>  ‘
        strE2 = nowPage + 1 + "/" + PagesLen + "页" + "  共" + j + "条"
        document.getElementById("changpage").innerHTML = strS + strC + strE + strE2
    }
</script>--%>
    </form>
</body>
</html>

//下面是后台代码

public FileInfo[] files { set; get; }
protected void Page_Load(object sender, EventArgs e)
{
string dirPath = HttpContext.Current.Server.MapPath("~/UpLoads");
if (Directory.Exists(dirPath))
{
DirectoryInfo dir = new DirectoryInfo(dirPath);
files = dir.GetFiles("*.*");
}
if (files.Length == 0) { Label1.Text = "暂无文件"; }
}

//这是新建另一个页面提供下载的代码

if (Request.QueryString["1"] != null)
{

string _filename = Request.QueryString["1"].ToString(), _filepath = System.IO.Path.Combine(MapPath("~/UpLoads"), _filename);
if (System.IO.File.Exists(_filepath))
{
Response.Clear();
Response.Buffer = true;

Response.AddHeader("Content-Disposition", "attachment;filename=" + _filename);
Response.ContentType = "application/unknow";
Response.TransmitFile(_filepath);
Response.End();
}
}

//这是新建另一个页面提供删除操作(后台)

string _filename = Request.QueryString["1"].ToString(), _filepath = System.IO.Path.Combine(MapPath("~/UpLoads"), _filename);
if (System.IO.File.Exists(_filepath))
{
File.Delete(_filepath);
Response.Write("<script language=javascript>alert(‘删除成功!‘);window.location = ‘Down.aspx‘;</script>");
//Response.Redirect("Down.aspx");
}

时间: 2024-07-28 18:18:09

asp.net实现大文件上传的相关文章

asp.net mvc大文件上传、断点续传功能。

文件夹数据库处理逻辑 publicclass DbFolder { JSONObject root; public DbFolder() { this.root = new JSONObject(); this.root.put("f_id", ""); this.root.put("f_nameLoc", "根目录"); this.root.put("f_pid", ""); this

asp.net web大文件上传带进度条实例代码

using System; using System.Data; using System.Configuration; using System.Collections; using System.Web; using System.Web.Security; using System.Web.UI; using System.Web.UI.WebControls; using System.Web.UI.WebControls.WebParts; using System.Web.UI.Ht

ASP.NET 中对大文件上传的简单处理

ASP.NET 中对大文件上传的简单处理 在 ASP.NET 开发的过程中,文件上传往往使用自带的 FileUpload 控件,可是用过的人都知道,这个控件的局限性十分大,最大的问题就在于上传大文件时让开发者尤为的头疼,而且,上传时无法方便的做到多线程的操控和上传进度的显示.笔者在此给大家推荐一款简单易用的上传组件,从而快速便捷得解决了 ASP.NET 中的大文件上传问题. 首先,我们需要下载这个名为 RanUpLoad 的组件,可以去我的百度云盘下载: http://pan.baidu.com

ASP.NET 大文件上传的简单处理

在 ASP.NET 开发的过程中,文件上传往往使用自带的 FileUpload 控件,可是用过的人都知道,这个控件的局限性十分大,最大的问题就在于上传大文件时让开发者尤为的头疼,而且,上传时无法方便的做到多线程的操控和上传进度的显示.在此给大家推荐一款简单易用的上传组件,从而快速便捷得解决了 ASP.NET 中的大文件上传问题. 首先,我们需要这个名为 RanUpLoad 的组件(下面例子中附带),这两个 dll 文件添加到项目的引用中区,xml 文件也要复制在项目中的 bin 文件夹下,也就是

C# 大文件上传

IHttpModule 分块上传大文件 IHttpModule 分块上传大文件 来源:http://www.cnblogs.com/HeroBeast/archive/2008/03/18/1084874.html 1.一般的在Asp.net里上传文件都是10m左右,要做到大文件上传,必须要改web.config,不过改了web.config有时候也上传不成功,那是每次上传的文件太大,浏览器在这个过程中会超时,采用分块上传的方法就可以避免这种情况. 2.分块上传就是利用post的方法,把数据分块

C#大文件上传(转--待验证)

几种常见的方法,本文主要内容包括:    第一部分:首先我们来说一下如何解决ASP.net中的文件上传大小限制的问题,我们知道在默认情况下ASP.NET的文件上传大小限制为2M,一般情况下,我们可以采用更改Web.Config文件来自定义最大文件大小,如下: 这样上传文件的最大值就变成了4M,但这样并不能让我们无限的扩大 MaxRequestLength的值,因为ASP.NET会将全部文件载入内存后,再加以处理.解决的方法是利用隐含的 HttpWorkerRequest,用它的GetPreloa

大文件上传问题

http://blog.csdn.net/tsinfeng/article/details/5865566 C#文件上传 分类: C#语言2010-09-06 09:33 4454人阅读 评论(1) 收藏 举报 c#stringasp.netbyteinternetstream 文件的上传下载是我们在实际项目开发过程中经常需要用到的技术,这里给出几种常见的方法,本文主要内容包括: 1.如何解决文件上传大小的限制 2.以文件形式保存到服务器 3.转换成二进制字节流保存到数据库以及下载方法 4.上传

基于Nodejs的大文件上传之断点续传

接着<扒一扒Nodejs formidable的onPart>和<也说文件上传之兼容IE789的进度条---丢掉flash>:前面已完成兼容IE789的大文件上传:无flash的低版本进度条,高版本的分段上传,并已为断点续传做好铺垫: 说什么做好铺垫,原本以为Nodejs端已没问题,只剩前端依靠HTML5接着监听abort事件,保存中断时上传到第几块了(断点续传只支持文件比较大,然后意外上传中断了,暂时定50M开启断点续传吧),通过文件内容hash和该文件唯一上传token来记录断

【原创】用JAVA实现大文件上传及显示进度信息

用JAVA实现大文件上传及显示进度信息 ---解析HTTP MultiPart协议 一. 大文件上传基础描述: 各种WEB框架中,对于浏览器上传文件的请求,都有自己的处理对象负责对Http MultiPart协议内容进行解析,并供开发人员调用请求的表单内容. 比如: Spring 框架中使用类似CommonsMultipartFile对象处理表二进制文件信息. 而.NET 中使用HtmlInputFile/ HttpPostedFile对象处理二进制文件信息. 优点:使用框架内置对象可以很方便的