`

Asp.Net文件上传之多文件上传

阅读更多

固定数量的多文件上传:

 

界面参考:

 

    //单击执行多文件上传
    protected void btnFileUpload_Click(object sender, EventArgs e)
    {
        //判断是否存在上传文件
        /*bool flag = false; ;
        bool[] b = { FileUpload1.HasFile, FileUpload2.HasFile, FileUpload3.HasFile };
        foreach (bool item in b)
        {
            if (item)
            {
                flag = true;
            }
        }*/

        //判断是否存在上传文件
        if (!FileUpload1.HasFile && !FileUpload2.HasFile && !FileUpload3.HasFile)
        {
            lblMessage.Text = "至少选择一个上传的文件!";
        }
        else
        {
            /*提供对客户端上载文件的访问,并组织这些文件,它是一个文件的集合.
            Request.Files获取客户端上载文件的集合*/
            HttpFileCollection filecoll = Request.Files;

            //循环上传文件的集合,并上传每一个文件
            for (int i = 0; i < filecoll.Count; i++)
            {
                /*得到上传的单个文件,
                 * 通过HttpPostedFile实例来处理单个上传文件的访问*/
                HttpPostedFile myfile = filecoll[i];

                //得到上传文件大小判断文件是否存在
                if (myfile.ContentLength > 0)
                {
                    if (myfile.ContentLength < 10485760)
                    {
                        try
                        {
                            //得到上传的文件名
                            myfile.SaveAs(Page.MapPath("~/Files/") + 
                            myfile.FileName.Substring(myfile.FileName.LastIndexOf(@"\") + 1));
                            
                            //这里得到上传文件名的方式还可以是:
                            /* myfile.SaveAs(Page.MapPath("~/Files/") 
                            + System.IO.Path.GetFileName(myfile.FileName));*/

                            lblMessage.Text = "文件上传成功!";
                        }
                        catch (Exception)
                        {
                            lblMessage.Text = "上传文件发生错误!";
                        }
                    }
                    else
                    {
                        lblMessage.Text = "上传文件不能大于10MB";
                    }
                }
            }
        }
    }

 

   动态的添加多文件上传:

   1.服务器端实现(动态添加FileUpload控件)

   2.客户端实现(javascript)

   

   服务器端实现(动态添加FileUpload控件)示例:

   界面参考:

  

  

  /*设置添加FileUpLoad控件的个数,
    保存FileUpload控件的个数也可以用Session实现*/
    private int Count
    {
        get { return Convert.ToInt32(ViewState["count"]); }
        set { ViewState["count"] = value; }
    }

    protected void Page_Load(object sender, EventArgs e)
    {
        //设置添加FileUpLoad控件的个数初始值为:0;
        if (!IsPostBack)
        {
            ViewState["count"] = 0;
        }
    }

    //创建FileUpLoad控件
    private void CreateOrDeleteFileUpload(int count)
    {
        FileUpload fileupload = null;
        //遍历创建FileUpload
        for (int i = 0; i < count; i++)
        {
            fileupload = new FileUpload();
            //设置FileUpload的Id
            fileupload.ID = "fileupLoad" + i.ToString();
            //将FileUpload添加到Panel控件中
            Panel1.Controls.Add(fileupload);
        }
    }

    //点击添加上传控件
    protected void btnAddUpload_Click(object sender, EventArgs e)
    {
        CreateOrDeleteFileUpload(++Count);
    }

    //点击添加更新控件
    protected void btnDeleteFileUpload_Click(object sender, EventArgs e)
    {
        CreateOrDeleteFileUpload(--Count);
    }

    //点击上传
    protected void btnUpload_Click(object sender, EventArgs e)
    {
        HttpFileCollection fileColl = Request.Files;

        for (int i = 0; i < fileColl.Count; i++)
        {
            HttpPostedFile gpf = fileColl[i];
            if (gpf.ContentLength > 0)
            {
                try
                {
                    gpf.SaveAs(Page.MapPath("~/Files/") + 
                    gpf.FileName.Substring(gpf.FileName.LastIndexOf(@"\") + 1));
                    lblMessage.Text = "上传文件成功!";
                }
                catch (Exception)
                {
                    lblMessage.Text = "文件上传发生错误!";
                }
            }
        }
    }

 

   客户端实现(javascript)示例:

   推荐使用客户端方式,因为服务端方式每次点击删除按钮都会向服务器提交一次.

  

<body>
    <!--HTML的文件上传控件上传需要修改enctype属性-->
    <form id="form1" runat="server" enctype="multipart/form-data">
    <div>
        <div id="panel">
        </div>
        <input type="hidden" value="1" id="filecount" />
        <input type="button" value="添加上传组件" onclick="javascript:AddFileUpLoad();" />
        <asp:Button ID="btnUpLoad" runat="server" onclick="btnUpLoad_Click" 
            Text="文件上传" />
        <asp:Label ID="lblMessage" runat="server"></asp:Label>
    </div>
    </form>
</body>

 

   

 <script type="text/javascript">
    //添加上传控件
    function AddFileUpLoad(){
        //得到上传文件控件的文件名.
        var name="file"+document.form1.filecount.value;
        
        //设置隐藏表单域的值加1,下次得到上传控件的名字就不会相同
        document.form1.filecount.value=parseInt(document.form1.filecount.value)+1;
        
        /*在id为panel的div元素的标签结束之前添加上传控件和删除按钮
         <button onclick='javascirpt:removeFile(this);'>删除</button>
         删除按钮把当前对象传给删除上传控件的函数
        */
        panel.insertAdjacentHTML("beforeEnd","<div><input type='file' name="+name
        +"><button onclick='javascirpt:removeFile(this);'>删除</button></div>");
    }
    
    //删除控件
    function removeFile(obj){
        //得到该对象的父节点元素然后删除该父节点
        obj.parentElement.removeNode(true);
    }
    </script>

 

 

   

 //单击上传文件
    protected void btnUpLoad_Click(object sender, EventArgs e)
    {
        HttpFileCollection fileColl = Request.Files;

        for (int i = 0; i < fileColl.Count; i++)
        {
            HttpPostedFile gpf = fileColl[i];
            if (gpf.ContentLength > 0)
            {
                try
                {
                    gpf.SaveAs(Page.MapPath("~/Files/") +
                    gpf.FileName.Substring(gpf.FileName.LastIndexOf(@"\") + 1));
                    lblMessage.Text = "上传文件成功!";
                }
                catch (Exception)
                {
                    lblMessage.Text = "文件上传发生错误!";
                }
            }
        }
    }

 

JS实现带图片预览功能的FileUpload控件

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

<!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>
    <script type="text/javascript">
    var timeOut;
    function previewImage(upload){
        //判断选择的文件是否为空
        if(!upload||!upload.value){
            return;
        }
        
        //验证是否是以.jpg等后缀名结尾
      var extend=/\.jpg$|\.jpeg$|\.gif$/i; 
      
      if(extend.test(upload.value)){
      
           var img=document.getElementById("img");
          
           if(img){
                clearTimeout(timeOut);
                img.src='file://localhost/'+upload.value;
                img.style.display="block";
                //设置5秒后图片隐藏
                timeOut=setTimeout("hidden()",5000);
           }else{
            clearTimeout(timeOut);
            var img=document.createElement("img");
            img.setAttribute('src','file://localhost/'+upload.value);
            img.setAttribute("width",'120');
            img.setAttribute('height','90');
            img.setAttribute('id','img');
            document.getElementById('form1').appendChild(img);
            timeOut=setTimeout("hidden()",5000);
           }
      }else{
        alert("你似乎选择的不是图像文件");
      }
    }
    //隐藏图片
    function hidden(){
        clearTimeout(timeOut);
        var img=document.getElementById("img");
        if(img){
            img.style.display="none";
        }
    }
   
    </script>
</head>
<body>
    <form id="form1" runat="server">
    <div>
        <asp:FileUpload ID="FileUpload1" runat="server" onchange="javascript:previewImage(this);" />
        <asp:Button ID="Button1" runat="server" Text="上传" />
    </div>
    </form>
</body>
</html>

 

  • 大小: 6.3 KB
  • 大小: 13.8 KB
分享到:
评论
1 楼 天闲降世 2010-03-29  
好是好,但是如果只用一个控件实现多个文件上传的化是不是更好些呢?

相关推荐

    asp.net文件上传示例

    ASP.NET文件上传是Web开发中的常见功能,尤其在企业级应用和社交网络中,用户可能需要上传图片、文档等各类文件。在这个“asp.net文件上传示例”中,我们可以学习到如何在ASP.NET环境中实现这一功能。这个示例是用...

    asp.net 批量上传文件

    在ASP.NET中实现批量文件上传是一项常见的需求,尤其在处理大量用户数据时。在这个场景下,我们可以使用jQuery库中的`jquery.form`插件来增强页面的交互性,并结合ASP.NET后端技术,实现异步、无刷新的批量文件上传...

    asp.net文件上传

    #### 一、ASP.NET文件上传概述 在ASP.NET应用程序中,文件上传是一项常用的功能。用户可以将本地计算机上的文件发送到服务器进行存储或处理。这通常通过HTML表单中的`&lt;input type="file"&gt;`元素实现,并在服务器端...

    asp.net ajax 多文件上传

    ASP.NET AJAX 多文件上传是一种在Web应用中实现高效、用户友好的文件上传方式,它结合了ASP.NET技术和AJAX(Asynchronous JavaScript and XML)的优势,提供了异步上传功能,使得用户无需等待整个页面刷新就能完成...

    asp.net 超大文件上传,带进度条源码,亲测能用

    在处理大文件上传时,ASP.NET需要特别的处理,因为默认情况下,它对上传文件的大小有限制,通常为4MB左右。针对超大文件上传的需求,开发者通常需要采取一些策略来优化和扩展这一功能,同时加入进度条显示可以提升...

    asp.net 文件上传源码

    接下来,我们将深入探讨ASP.NET文件上传的核心概念、实现步骤以及可能遇到的问题。 1. **文件上传基础** ASP.NET中的文件上传主要通过`HttpPostedFileBase`类来处理。当用户在表单中包含一个`&lt;input type="file"&gt;`...

    【ASP.NET编程知识】asp.net单文件带进度条上传的解决方案.docx

    本文主要讲述了ASP.NET单文件带进度条上传的解决方案,通过使用jquery框架和ASP.NET缓存机制,实现了文件上传和进度条显示的功能。 知识点1:使用jquery框架实现文件上传 在本文中,我们使用jquery框架来实现文件...

    asp.net 文件上传demo

    在ASP.NET环境中,文件上传是一项常见的功能,尤其在构建交互性强、用户友好的Web应用程序时。本示例“asp.net 文件上传demo”是基于.NET框架3.5的一个演示项目,它利用了Flash技术来增强文件上传体验,同时支持大...

    asp.net自定义固定格式多文件批量上传

    在ASP.NET中,实现自定义固定格式的多文件批量上传是一项常见的需求,这涉及到Web开发中的文件上传控件、服务器端处理以及客户端交互等多个技术环节。以下是对这一知识点的详细阐述: 1. **文件上传控件**:在ASP...

    asp.net文件上传源码

    下面我们将深入探讨ASP.NET文件上传的相关知识点。 首先,`uploadpic_zpfj.aspx` 是一个ASP.NET Web Form页面,它通常包含HTML元素,如表单(`&lt;form&gt;`)和输入元素(`&lt;input type="file"&gt;`),用于用户选择要上传的...

    asp.net文件上传下载程序 有数据库 下载可用

    ASP.NET文件上传下载程序是一个基于微软的ASP.NET技术构建的应用,用于实现用户在Web端上传和下载文件。这种程序通常包含后端服务器处理逻辑和前端用户界面,与数据库结合以存储文件元数据,如文件名、大小、上传...

    Extjs结合Asp.net文件上传

    标题中的“Extjs结合Asp.net文件上传”指的是在Web应用程序开发中,使用Ext JS(一个JavaScript库)和ASP.NET(Microsoft的服务器端技术)来实现文件上传功能。这一组合可以提供用户友好的界面和强大的后台处理能力...

    asp.net+flash批量上传

    asp.net上传 多文件上传 批量上传 上传代码 上载asp.net上传 多文件上传 批量上传 上传代码 上载asp.net上传 多文件上传 批量上传 上传代码 上载asp.net上传 多文件上传 批量上传 上传代码 上载asp.net上传 多文件...

    基于ASP.NET文件上传、下载的网络硬盘系统 源码

    【ASP.NET文件上传与下载系统】是一个典型的Web应用程序,它允许用户通过网络进行文件的上传和下载操作。这个系统基于微软的ASP.NET框架构建,利用了ASP.NET的强大功能和高效性能,为用户提供了一种安全、便捷的方式...

    asp.net同时上传多个文件

    在ASP.NET中,同时上传多个文件是常见的功能需求,尤其在构建交互性强的Web应用程序时。这个功能使得用户能够一次性上传多个文件...理解并掌握这些知识点,可以帮助你有效地实现在ASP.NET应用中处理多文件上传的需求。

    ASP.NET通过HTML的上传文件标签来上传文件

    在ASP.NET中处理文件上传是常见的需求,尤其是在用户需要提交图片、文档或其他数据文件时。这篇博客文章“ASP.NET通过HTML的上传文件标签来上传文件”将引导我们了解如何在ASP.NET环境中实现文件上传功能。 首先,...

    asp.net文件上传带进度条

    1. **ASP.NET文件上传基础**: ASP.NET提供了多种文件上传方式,如HTML `&lt;input type="file"&gt;` 元素配合Form表单提交,或者使用控件如ASP.NET FileUpload控件。但是,这两种方法都无法在上传过程中显示进度条。 2....

    【ASP.NET编程知识】ASP.NET Core文件上传与下载实例(多种上传方式).docx

    使用 ASP.NET Core 的文件上传机制,可以实现多文件上传、文件大小限制、文件类型限制等功能。此外,还可以使用 TagHelper 来简化表单的编写。 知识点6: 文件下载的实现 文件下载的实现可以使用 FileResult 来返回...

    ASP.NET多文件上传

    ASP.NET多文件上传是Web开发中的一个重要功能,它允许用户一次性上传多个文件,极大地提高了用户交互性和效率。在ASP.NET框架中,实现这一功能需要掌握一些核心知识点。 首先,了解HTTP协议的基础至关重要。HTTP...

Global site tag (gtag.js) - Google Analytics